АвтоАвтоматизацияАрхитектураАстрономияАудитБиологияБухгалтерияВоенное делоГенетикаГеографияГеологияГосударствоДомДругоеЖурналистика и СМИИзобретательствоИностранные языкиИнформатикаИскусствоИсторияКомпьютерыКулинарияКультураЛексикологияЛитератураЛогикаМаркетингМатематикаМашиностроениеМедицинаМенеджментМеталлы и СваркаМеханикаМузыкаНаселениеОбразованиеОхрана безопасности жизниОхрана ТрудаПедагогикаПолитикаПравоПриборостроениеПрограммированиеПроизводствоПромышленностьПсихологияРадиоРегилияСвязьСоциологияСпортСтандартизацияСтроительствоТехнологииТорговляТуризмФизикаФизиологияФилософияФинансыХимияХозяйствоЦеннообразованиеЧерчениеЭкологияЭконометрикаЭкономикаЭлектроникаЮриспунденкция

SocketAddress address)

Читайте также:
  1. DETACHMENT
  2. F.Канальный уровень
  3. He was granted a pension.
  4. Street: Knorina 56
  5. Адресна доступність
  6. В текстовых блоках нельзя использовать символы
  7. Глобальная компьютерная сеть INTERNET (Лабораторная работа № 4)
  8. Запрос принадлежности (Membership Query Message)
  9. Лекция: Режимы адресации и форматы команд 16-разрядного процессора
  10. Листинг 10.2. Оригинальный стартовый адрес Lead-Out (слева) и стартовый адрес первого трека диска (справа)
  11. Листинг 5.2. Интерфейс с прерыванием BIOS INT13h
  12. Настройка сетевого адаптера и трансивера

Первый конструктор используется в тех случаях когда датаграмма только принимает в себя пришедшие данные, так как созданный с его помощью объект не имеет информации об адресе и порте получателя. Остальные конструкторы используются для отправки датаграм.

Класс DatagramSocket может выступать в роли клиента и сервера, то есть он способен получать и отправлять пакеты. Отправить пакет можно с помощью метода send(DatagramPacket pac), для получения пакета используется метод receive(DatagramPacket pac).

/* пример # 9: отправка файла по UDP протоколу: Sender.java */

package chapt15;

import java.io.*;

import java.net.*;

public class Sender {

public static void main(String[] args) {

try {

byte [] data = new byte [1000];

DatagramSocket s = new DatagramSocket();

InetAddress addr =

InetAddress.getLocalHost();

/*файл с именем toxic.mp3 должен лежать в корне проекта*/

FileInputStream fr =

new FileInputStream(

new File("toxic.mp3"));

DatagramPacket pac;

 

while (fr.read(data)!= -1) {

//создание пакета данных

pac = new DatagramPacket(data, data.length, addr, 8033);

s.send(pac); //отправление пакета

}

fr.close();

System. out. println("Файл отправлен");

} catch (UnknownHostException e) {

// неверный адрес получателя

e.printStackTrace();

} catch (SocketException e) {

// возникли ошибки при передаче данных

e.printStackTrace();

} catch (FileNotFoundException e) {

// не найден отправляемый файл

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

/* пример # 10: прием данных по протоколу UDP: Recipient.java */

package chapt15;

import java.io.*;

import java.net.*;

public class Recipient {

public static void main(String[] args) {

File file = new File("toxic2.mp3");

System. out. println("Прием данных...");

try { // прием файла

acceptFile (file, 8033, 1000);

} catch (IOException e) {

e.printStackTrace();

}

}

private static void acceptFile (File file, int port,

int pacSize) throws IOException {

byte data[] = new byte[pacSize];

DatagramPacket pac =

new DatagramPacket(data, data.length);

DatagramSocket s = new DatagramSocket(port);

FileOutputStream os =

new FileOutputStream(file);

try {

/* установка времени ожидания: если в течение 10 секунд
не принято ни одного пакета, прием данных заканчивается*/

s.setSoTimeout(60000);

while (true) {

s.receive(pac);

os.write(data);

os.flush();

}

} catch (SocketTimeoutException e) {

// если время ожидания вышло

os.close();

System. out. println(

"Истекло время ожидания, прием данных закончен");

}

}

}

Задания к главе 15

Вариант А

Создать на основе сокетов клиент/серверное визуальное приложение:

1. Клиент посылает через сервер сообщение другому клиенту.

2. Клиент посылает через сервер сообщение другому клиенту, выбранному из списка.

3. Чат. Клиент посылает через сервер сообщение, которое получают все клиенты. Список клиентов хранится на сервере в файле.

4. Клиент при обращении к серверу получает случайно выбранный сонет Шекспира из файла.

5. Сервер рассылает сообщения выбранным из списка клиентам. Список хранится в файле.

6. Сервер рассылает сообщения в определенное время определенным клиентам.

7. Сервер рассылает сообщения только тем клиентам, которые в настоящий момент находятся в on-line.

8. Чат. Сервер рассылает всем клиентам информацию о клиентах, вошедших в чат и покинувших его.

9. Клиент выбирает изображение из списка и пересылает его другому клиенту через сервер.

10. Игра по сети в “Морской бой”.

11. Игра по сети в “21”.

12. Игра по сети “Го”. Крестики-нолики на безразмерном (большом) поле. Для победы необходимо выстроить пять в один ряд.

13. Написать программу, сканирующую сеть в указанном диапазоне IP адресов на наличие активных компьютеров.

14. Прокси. Программа должна принимать сообщения от любого клиента, работающего на протоколе TCP, и отсылать их на соответствующий сервер. При передаче изменять сообщение.

15. Телнет. Создать программу, которая соединяется с указанным сервером по указанному порту и производит обмен текстовой информацией.

Вариант B

Для заданий варианта В главы 4 на базе сокетных соединений разработать сетевой вариант системы. Для каждого пользователя должно быть создано клиентское приложение, соединяющееся с сервером.

Тестовые задания к главе 15


1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 |

Поиск по сайту:



Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Студалл.Орг (0.014 сек.)