Сетевой обмен данными в Java

  • Вид работы:
    Практическое задание
  • Предмет:
    Информационное обеспечение, программирование
  • Язык:
    Русский
    ,
    Формат файла:
    MS Word
    101,3 Кб
  • Опубликовано:
    2013-11-27
Вы можете узнать стоимость помощи в написании студенческой работы.
Помощь в написании работы, которую точно примут!

Сетевой обмен данными в Java

МИНИСТЕРСТВО ОБРАЗОВАНИЯ И НАУКИ РЕСПУБЛИКИ КАЗАХСТАН

Казахский национальный технический университет имени К.И. Сатпаева

Институт информационных и телекоммуникационных технологий

Кафедра программного обеспечения систем и сетей







Лабораторная работа

На тему: "Сетевой обмен данными в JAVA"

В060200- Информатика










Алматы 2013

На тему: "Сетевой обмен данными в JAVA"

Инструмент измерения выполнения лабораторной работы №1

Качество выполнения работ

Диапазон оценки

Получено %

1 Не выполнено

0%


Отсутствие на занятиях без уважительных причин



2 Выполнение и активность обучающегося

0-50%


3 Оформление работы

0-20%


4 Умение пользоваться справочниками, технической литературой, учебно-методическим комплексом дисциплины, конспектами лекций

0-5%


5 Умение пользоваться техническими средствами

0-5%


6 Защита лабораторной работы

0-20%


Итого:

0-100%



Цель: Изучение сетевых средств JAVA

В Java существует специальный пакет "java.net", содержащий класс java.net.Socket. Socket в переводе означает "гнездо", название это было дано по аналогии с гнёздами на аппаратуре, теми самыми, куда подключают штепсели. Соответственно этой аналогии, можно связать два "гнезда", и передавать между ними данные. Каждое гнездо принадлежит определённому хосту (Host - хозяин, держатель). Каждый хост имеет уникальный IP (Internet Packet) адрес. На данный момент интернет работает по протоколу IPv4, где IP адрес записывается 4 числами от 0 до 255 - например, 127.0.0.1

Гнёзда монтируются на порт хоста (port). Порт обозначается числом от 0 до 65535 и логически обозначает место, куда можно пристыковать (bind) сокет. Если порт на этом хосте уже занят каким-то сокетом, то ещё один сокет туда пристыковать уже не получится. Таким образом, после того, как сокет установлен, он имеет вполне определённый адрес, символически записывающийся так [host]:[port], к примеру - 127.0.0.1:8888 (означает, что сокет занимает порт 8888 на хосте 127.0.0.1)

Рис. 1 - Логическая структура соединений через сокеты

Для того, чтобы облегчить жизнь, чтобы не использовать неудобозапоминаемый IP адрес, была придумана система DNS (DNS - Domain Name Service). Цель этой системы - сопоставлять IP адресам символьные имена. К примеру, адресу "127.0.0.1" в большинстве компьютеров сопоставленно имя "localhost" (в просторечье - "локалхост").

Локалхост, фактически, означает сам компьютер, на котором выполняется программа, он же - локальный компьютер. Вся работа с локалхостом не требует выхода в сеть и связи с какими-либо другими хостами.

TCP/IP-сокеты используются для реализации надежных двунаправленных, ориентированных на работу с потоками соединений точка-точка между узлами Internet. Сокеты можно использовать для соединения системы ввода-вывода Java с программами, которые могут выполняться либо на локальной машине, либо на любом другом узле Internet. В отличие от класса DatagramSocket, объекты класса Socket реализуют высоконадежные устойчивые соединения между клиентом и сервером.

В пакете java.net классы Socket и ServerSocket сильно отличаются друг от друга. Первое отличие в том, что ServerSocket ждет, пока клиент не установит с ним соединение, в то время, как обычный Socket трактует недоступность чего-либо, с чем он хочет соединиться, как ошибку. Одновременно с созданием объекта Socket устанавливается соединение между узлами Internet. Для создания сокетов вы можете использовать два конструктора:(String host, int port) устанавливает соединение между локальной машиной и указанным портом узла Internet, имя которого было передано конструктору. Этот конструктор может возбуждать исключения UnknownHostException и IOException.(InetAddress address, int port) выполняет ту же работу, что и первый конструктор, но узел, с которым требуется установить соединение, задается не строкой, а объектом InetAddress. Этот конструктор может возбуждать только IOException.поддерживает адреса абонентов, принятые в Internet, с помощью класса InetAddress. Для адресации в Internet используются служебные функции, работающие с обычными, легко запоминающимися символическими именами, эти функции преобразуют символические имена в 32-битные адреса.

В классе InetAddress нет доступных пользователю конструкторов. Для создания объектов этого класса нужно воспользоваться одним из его фабричных методов. Фабричные методы - это обычные статические методы, которые возвращают ссылку на объект класса, которому они принадлежат. В данном случае, у класса InetAddress есть три метода, которые можно использовать для создания представителей. Это методы getLocalHost, getByName и getAllByName.

У класса InetAddress также есть несколько нестатических методов, которые можно использовать с объектами, возвращаемыми только что названными фабричными методами:() возвращает строку, содержащую символическое имя узла, соответствующее хранящемуся в данном объекте адресу Internet.() возвращает байтовый массив из четырех элементов, в котором в порядке, используемом в сети, записан адрес Internet, хранящийся в данном объекте.() возвращает строку, в которой записано имя узла и его адрес.

После того, как объект Socket создан, им можно воспользоваться для того, чтобы получить доступ к связанным с ним входному и выходному потокам. Эти потоки используются для приема и передачи данных точно так же, как и обычные потоки ввода-вывода, которые мы видели в предыдущей главе:() возвращает InputStream, связанный с данным объектом.() возвращает OutputStream, связанный с данным объектом.() закрывает входной и выходной потоки объекта Socket.

Как уже упоминалось ранее, Java поддерживает сокеты серверов. Для создания серверов Internet надо использовать объекты класса ServerSocket. Когда вы создаете объект ServerSocket, он регистрирует себя в системе, говоря о том, что он готов обслуживать соединения клиентов. У этого класса есть один дополнительный метод accept(), вызов которого блокирует подпроцесс до тех пор, пока какой-нибудь клиент не установит соединение по соответствующему порту. После того, как соединение установлено, метод accept() возвращает вызвавшему его подпроцессу обычный объект Socket.

Два конструктора класса ServerSocket позволяют задать, по какому порту вы хотите соединяться с клиентами, и (необязательный параметр) как долго вы готовы ждать, пока этот порт не освободится.(int port) создает сокет сервера для заданного порта.(int port, int count) создает сокет сервера для заданного порта. Если этот порт занят, метод будет ждать его освобождения максимум count миллисекунд.

Самый простой способ создания потока - это объявление класса, реализующего интерфейс Runnable. Runnable абстрагирует единицу исполняемого кода. Можно конструировать поток из любого объекта, реализующего интерфейс Runnable. Чтобы реализовать Runnable, класс нужно объявить единственный метод run (). Внутри run () вы определяете код, который, собственно, составляет новый поток. Важно понимать, что run () может вызывать другие методы, использовать другие классы, объявлять переменные - точно так же, как это делает главный поток. Единственным отличием является то, что run () устанавливает точку входа для другого, параллельного потока внутри вашей программы. Этот поток завершится, когда run () вернет управление.

После того как будет объявлен класс, реализующий интерфейс Runnable, вы создадите объект типа Thread из этого класса. В Thread определено несколько конструкторов. Тот, который должен использоваться в данном случае, выглядит следующим образом:(Runnable объект_потока, String имя_потока)

В этом конструкторе объект_потока - это экземпляр класса, реализующего интерфейс Runnable. Он определяет, где начнется выполнение потока. Имя нового потока передается в иия_потока.

После того, как новый поток будет создан, он не запускается до тех пор, пока вы не вызовете метод start (), объявленный в классе Thread. По сути, start () выполняет вызов run (). Метод start () показан ниже:

Внутри конструктора NewThread в следующем операторе создается новый объект Thread:= new Thread(this, "Демонстрационный поток");

Передача this в первом аргументе означает, что вы хотите, чтобы новый поток вызвал run () метод объекта this. Далее вызывается start (), чем запускается выполнение потока, начиная с метода run (). Это запускает цикл for дочернего потока. После вызова start () конструктор NewThread возвращает управление main (). Когда главный поток продолжает свою работу, он входит в свой цикл for. После этого оба потока выполняются параллельно, разделяя ресурсы центрального процессора, вплоть до завершения своих циклов. Вывод, генерируемый этой программой, показан ниже (ваш вывод может варьироваться, в зависимости от скорости процессора и загрузки).

Сервер - это специальная программа, обычно запущенная на отдельном компьютере (хосте, от слова host(eng.) - хозяин), и выполняющая некий круг задач. Клиент, в свою очередь - программа, которая запрашивает сервер выполнить то или иное действие (задачу) и вернуть полученные данные клиенту. На хосте для работы сервера обычно выделяется порт (port). К этому порту и должен будет обращаться клиент. Клиент для связи с портом хоста, который соединен в свою очередь с нужным сервером (программой), создает сокет.

В целом алгоритм работы системы клиент-сервер выглядит следующим образом:

Сервер подключается к порту на хосте и ждет соединения с клиентом;

Клиент создает сокет и пытается соединить его с портом на хосте;

Если создание сокета прошло успешно, то сервер переходит в режим ожидания команд от клиента;

Клиент формирует команду и передает ее серверу, переходит в режим ожидания ответа;

Сервер принимает команду, выполняет ее и пересылает ответ клиенту и т.д.

Создаем сервер

Для создания сокетов и управления ими в Java есть специальные классы java.net.Socket и java.net.ServerSocket. Первый для клиента, второй для сервера. Так же будут необходимы два класса из пакета java.io.*: BufferedReader и PrintWriter для чтения/записи в сокет.

Листинг ServerForm.java

import java.net.*;

import java.io.*;class ServerForm extends java.awt.Frame implements Runnable {final static int PORT = 220;sock = null;in = null;fw = null;out = null;t = new Thread(this);

/** Создаем новое окно сервера */ServerForm() { initComponents(); }void initComponents() {= new java.awt.List();= new java.awt.TextField();= new java.awt.Button();= new java.awt.Button();= new java.awt.Button();("Сервер");(new java.awt.event.WindowAdapter() {void windowClosing(java.awt.event.WindowEvent evt) {(evt); } });(null);(list1);.setBounds(30, 90, 160, 150);(textField1);.setBounds(30, 50, 160, 20);.setLabel("Отправить");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt);} });(button1);.setBounds(240, 50, 110, 24);.setLabel("Соединение");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt); } });(button2);.setBounds(250, 200, 110, 24);.setLabel("Закрыть");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt); }});(button3);.setBounds(250, 150, 100, 24);(500, 500, 400, 300); }

/** Завершение приложения */void exitForm(java.awt.event.WindowEvent evt) {.exit(0); }void button1ActionPerformed(java.awt.event.ActionEvent evt) {

// Получаем строку от пользователя и передаем клиенту

try{data = textField1.getText();.write(data);.newLine();.flush(); }(Exception e){}}void button2ActionPerformed(java.awt.event.ActionEvent evt) {

// Устанавливаем соединение(); }void button3ActionPerformed(java.awt.event.ActionEvent evt) {

// Закрываем файл данных, потоки и соединение

try{.close();.close();.close();.close(); }(Exception e){} }void run(){indata_;

try {

//Читаем в цикле данные(true){_ = in.readLine();

//Отображаем в компоненте.add(indata_);

fw.write(indata_); } }(Exception e){} }void connect() {{

//Создаем серверный сокет

Для подключения к порту хоста с помощью конструктора класса ServerSocket. Конструктор выбрасывает исключение типа IOException, т.е.понадобится блок try - catch:

ServerSocket ss = new ServerSocket(PORT);= ss.accept();

Метод ss.accept() позволяет серверу следить за портом, или иначе говоря ждать подключения клиента.

//Получаем потоки

in = new BufferedReader(new(sock.getInputStream()));= new BufferedWriter(new(sock.getOutputStream()));

сокет java поток сервер

//Запускаем подпроцесс

Как только клиент подключается - сокет для клиента сразу же создается. В противном случае выбрасывается исключение IOException.

Как только клиент подключился к серверу, сервер должен создать потоки ввода и вывода для связи с ним. Это можно сделать следующим образом:

t.start();

//Открываем файл данных= new FileWriter("messageServ.txt");}(Exception ex) {.out.println("ошибка "); } }static void main(String args[]) {.awt.EventQueue.invokeLater(new Runnable() {void run() {ServerForm().setVisible(true); } }); }java.awt.Button button1;java.awt.Button button2;java.awt.Button button3;java.awt.List list1;java.awt.TextField textField1; }

Создаем клиент

Для создания клиента достаточно класса Socket и двух классов для ввода/вывода. Также необходимо знать имя компьютера (хоста), на котором запущен сервер и номер порта.

Листинг ClientForm.java

//** Создаем новое окно клиента */

public ClientForm() {();}void initComponents() {= new java.awt.List();= new java.awt.TextField();= new java.awt.Button();= new java.awt.Button();= new java.awt.Button();("Client");("Клиент");(new java.awt.event.WindowAdapter() {void windowClosing(java.awt.event.WindowEvent evt) {(evt);}});(null);(list1);.setBounds(30, 110, 170, 170);(textField1);.setBounds(30, 70, 170, 20);.setActionCommand("button3");.setLabel("Соединение");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt);}});(button1);.setBounds(260, 250, 100, 24);.setLabel("Отправить");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt);}});(button2);.setBounds(250, 70, 110, 24);.setLabel("Закрыть");.addActionListener(new java.awt.event.ActionListener() {void actionPerformed(java.awt.event.ActionEvent evt) {ActionPerformed(evt);}});(button3);.setBounds(260, 200, 90, 24);(200, 200, 408, 338);}

/** Выход из приложения */void exitForm(java.awt.event.WindowEvent evt) {.exit(0);}void button1ActionPerformed(java.awt.event.ActionEvent evt) {

// Устанавливаем соединение с с хостом();}

private void button2ActionPerformed(java.awt.event.ActionEvent evt) {

// Получаем строку от пользователя и пересылаем серверу

try{data = textField1.getText();.write(data);.newLine();.flush();}(Exception e){}}void button3ActionPerformed(java.awt.event.ActionEvent evt) {

// Закрываем файл, потоки и соединение{

fw.close();.close();.close();.close();}(Exception e){}}void run(){s1;

try{

//В цикле читаем данные из потока

while(true){= in.readLine();

//Отображаем в компоненте.add(s1);

//Записываем в файл.write(s1);}}

catch(Exception e){}}void connect() {

try{

//Устанавливаем соединение с локальным хостом

InetAddress addr = InetAddress.getByName(“192.168.43.142”);= new Socket(addr, 220);

//Получаем потоки ввода_вывода= new BufferedReader(new InputStreamReader(ss.getInputStream()));= new BufferedWriter(new OutputStreamWriter(ss.getOutputStream()));

//Запускаем новый подпроцесс.start();

//Открываем файл= new FileWriter("messageCli.txt");}(Exception e){.out.println("ошибка ");}}static void main(String args[]) {.awt.EventQueue.invokeLater(new Runnable() {void run() {ClientForm().setVisible(true);}});}java.awt.Button button1;java.awt.Button button2;java.awt.Button button3;java.awt.List list1;java.awt.TextField textField1;}

Клиент подключенный к Серверу отправляет сообщение

Рис. 2

Сервер получает сообщение от Клиента

Рис. 3

И наоборот, Клиент получает сообщение от Сервера

Рис. 4

Похожие работы на - Сетевой обмен данными в Java

 

Не нашли материал для своей работы?
Поможем написать уникальную работу
Без плагиата!