И.Н. Блинов, В.С. Романчик - Основы программирования на языке Java (1160783), страница 12
Текст из файла (страница 12)
Номера портов от 1до 1024 используются, например, для запуска двух программ серверовна одном компьютере. Если порт явно не указан, браузер воспользуется значением по умолчанию: 20 – FTP-данные, 21 – FTP-управление,23 – TELNET, 53 – DNS, 80 – HTTP, 110 – POP3, 119 – NNTP.Адрес URL (Universal Resourse Lacator) состоит из двух частей –префикса протокола (http, ftp…) и URI (Universal Resource Identifier).URI содержит Internet-адрес, необязательный номер порта и путь к каталогу, содержащему файл, например: http://www.bsu.by:80/index.htm.URI не может содержать такие специальные символы, как пробелы,табуляции, возврат каретки. Их можно задавать через шестнадцатиричные коды. Например %20 обозначает пробел. Другие зарезервированные символы: / – разделитель каталогов, ? – следует за аргументами запросов, # – разделитель аргументов, + – специальный символ.Можно создать объект класса URL, указывающий на ресурсы вInternet.
В следующем примере объект URL используется для доступак HTML-файлу, на который он указывает и отображает его в окнебраузера с помошью метода showDocument().//пример #3 : вывод документа в браузер : MyShowDocument.javaimport java.applet.*;import java.net.*;import java.awt.*;public class MyShowDocument extends Applet {URL press = null;public void init() {try {press = new URL("http://www.pressball.by");}catch (MalformedURLException e){System.out.println("ошибка: " + e.getMessage());}}public boolean mouseDown(Event evt, int x, int y) {// при щелчке происходит переход к странице www.pressball.bygetAppletContext().showDocument(press, "_blank");75return true;}}Метод showDocument() может содержать параметры для отображения страницы различными способами: "_self" – выводит документ втекущем окне, "_blank" – документ в новое окно, "_top" – вверху окна, "_parent" – документ в родственном окне, "строка" – документ вокне с данным именем.В следующем примере методы getDocumentBase() и getCodeBase()используются для получения URL страницы апплета и URL апплета.//пример #4 : получение URL-ов : MyDocumentBase.javaimport java.applet.*;import java.net.*;import java.awt.*;public class MyDocumentBase extends Applet {public void init() {URL html = getDocumentBase();URL codebase = getCodeBase();System.out.println("URL страницы : " + html);System.out.println("URL апплета : " + codebase);}}В следующей программе читается содержимое HTML-файла с сервера и выводится в окно консоли.//пример #5 : чтение HTML-файла : MyURLTest.javaimport java.net.*;import java.io.*;public class MyURLTest {public static void main(String[] args) {try {URL homeBSU = new URL("http://www.bsu.by");InputStreamReader isr = newInputStreamReader(homeBSU.openStream());BufferedReader d = new BufferedReader(isr);String line = d.readLine();while (line != null) {System.out.println(line);line = d.readLine(); }}catch (IOException e) {76System.out.println("ошибка: " + e.getMessage());}}}Сокеты и сокетные соединенияСокеты − это сетевые разъемы, через которые осуществляютсядвунапрвленные поточные соединения между компьютерами.
Сокетопределяется номером порта и IP-адресом. При этом IP-адрес используется для идентификации компьютера, номер порта – для идентификации процесса, работающего на компьютере. Когда одно приложениезнает сокет другого, создается сокетное соединение. Клиент пытаетсясоедениться с сервером, инициализируя сокетное соединение. Серверждет, пока клиент не свяжется с ним. Первое сообщение, посылаемоеклиентом на сервер, содержит сокет клиента. Сервер в свою очередьсоздает сокет, который будет использоваться для связи с клиентом, ипосылает его клиенту с первым сообщением.
После этого устанавливается коммуникационное соединение.Сокетное соединение с сервером создается с помощью объектакласса Socket. При этом указывается IP-адрес сервера и номер порта(80 для HTTP). Если указано имя домена, то Java преобразует его спомощью DNS-сервера к IP-адресу:try { socket = new Socket("localhost",8080); }catch (IOException e){ System.out.println("ошибка: " + e); }Сервер ожидает сообщения клиента и должен быть запущен с указанием определенного порта.
Объект класса ServerSocket создается суказанием конструктору номера порта и ожидает сообщения клиента спомощью метода accept(), который возвращает сокет клиента:Socket socket = null;try { server = new ServerSocket(8080);socket = server.accept(); }catch (IOException e) { System.out.println("ошибка: " + e); }Клиент и сервер после установления сокетного соединения могутполучать данные из потока ввода и записывать данные в поток выводас помощью методов getInputStrеam() и getOutputStrеam() или кPrintStream для того, чтобы программа могла трактовать поток каквыходные файлы.В следующем примере для посылки клиенту строки "привет!" сервер вызывает метод getOutputStream() класса Socket.
Клиент получает данные от сервера с помощью метода getInputStream(). Для разъединения клиента и сервера после завершения работы сокет закрывает77ся с помощью метода close() класса Socket. В данном примере серверпосылает клиенту строку "привет!" после чего разрывает связь.//пример #6 : передача клиенту строки : MyServerSocket.javaimport java.io.*;import java.net.*;public class MyServerSocket{public static void main(String[] args) throws Exception{Socket s = null;try {//посылка строки клиентуServerSocket server = new ServerSocket(8030);s = server.accept();PrintStream ps = new PrintStream(s.getOutputStream());ps.println("привет!");ps.flush();s.close(); // разрыв соединения}catch (IOException e){System.out.println("ошибка: " + e); }}}//пример #7 : получение клиентом строки : MyClientSocket.javaimport java.io.*;import java.net.*;public class MyClientSocket {public static void main(String[] args) {Socket socket = null;try {//получение строки клиентомsocket = new Socket("www.bsu.by", 8080);BufferedReader dis = new BufferedReader(newInputStreamReader(socket.getInputStream()));String msg = dis.readLine();System.out.println(msg);} catch (IOException e) {System.out.println("ошибка: " + e); }}}Аналогично клиент может послать данные серверу через поток вывода с помощью метода getOutputStream(), а сервер может получатьданные с помощью метода getInputStream().Если необходимо протестировать подобный пример на одном компьютере, можно соединится самому с собой, используя статическиеметоды getLocalHost() класса InetAddress для получения динамического IP-адреса компьютера, который выделяется при входе в Internet.78МногопоточностьСервер должен поддерживать многопоточность, иначе он будет нев состоянии обрабатывать несколько соединений одновременно.
Сервер содержит цикл, ожидающий нового клиентского соединения. Каждый раз, когда клиент просит соединения, сервер создает новый поток. В следующем примере создается класс NetServerThread, расширяющий класс Thread./*пример #8 : сервер для множества клиентов :NetServerThread.java*/import java.net.*;import java.io.*;public class NetServerThread extends Thread {Socket socket;int i;PrintStream ps;public NetServerThread(Socket s) {socket = s;try {ps = new PrintStream(s.getOutputStream()); }catch (IOException e) { System.out.println("ошибка: " + e); }}public static void main(String[] args) {Socket s = null;try{ServerSocket server = new ServerSocket(8030);s = server.accept();NetServerThread nst = new NetServerThread(s);nst.start();}catch(Exception e){ System.out.println("ошибка: " + e); }}public void run() {while (true) {String line = "сообщение: "+i++;if (line == null) return; // клиент ушелsend(line);}}public void send(String msg) {ps.println(msg);System.out.println(msg+"<передача>");ps.flush();79}}Сервер передает сообщение, посылаемое клиенту.
Для клиентскихприложений поддержка многопоточности также необходима. Например, один поток ожидает выполнения операции ввода/вывода, а другие потоки выполняют свои функции./* пример #9 : получение сообшения клиентом в потоке :NetClientThread.java */import java.net.*;import java.io.*;public class NetClientThread extends Thread {BufferedReader br = null;Socket s = null;public NetClientThread() {try {//соединение с кольцевым адресомs = new Socket("127.0.0.1", 8030);InputStreamReader isr = newInputStreamReader(s.getInputStream());br = new BufferedReader(isr);} catch (IOException e) {System.out.println("ошибка: " + e); }}public static void main(String[] args) {NetClientThread nct = new NetClientThread();nct.start(); }public void run() {while (true) {try { String msg = br.readLine();if (msg == null) break;else System.out.println(msg);}catch (IOException e) { System.out.println("ошибка: " + e); }}}}Сервер должен быть готов до того, как клиент попытается осуществить сокетное соединение.
При этом может быть использован IPадрес локального компьютера.Упражнения1. import java.io.*;import java.net.*;public class NetClient {80public static void main(String args[]) { try {Socket skt = new Socket("host",88);Каким способом будет подключен объект skt?а)никаким ; б)POP3; в)FTP; г)HTTP2. Организовать соединение между клиентом и сервером используя визуальные компоненты?3.
Как получить содержание страницы используя его URL?а)Socket content = new Socket(new URL(url)).collect();б)Object content = new URL(url).getContent();в)String content = new URLHttp(url).getString();г)Object content = new URLConnection(url).getContent();д)String content = new URLConnection(url).collect();Вот и все, что мы смогли изложить на отведенных нам 80-тистраницах. Имейте в виду, что это только основа. Теперь применитеполученные знания при изучении и использовании сервлетов, JSP,JDBC, EJB, RMI и прочих API.81Литература1.