Java網(wǎng)絡(luò)編程之入門篇
一、網(wǎng)絡(luò)基礎(chǔ)
二、網(wǎng)絡(luò)協(xié)議
實(shí)現(xiàn)TCP的網(wǎng)絡(luò)編程 例子1:客戶端發(fā)送信息給服務(wù)端,服務(wù)端將數(shù)據(jù)顯示在控制臺(tái)上 public class TCPTest1 { //客戶端 @Test public void client() { Socket socket = null; OutputStream os = null; try { //1.創(chuàng)建Socket對(duì)象,指明服務(wù)器端的ip和端口號(hào) InetAddress inet = InetAddress.getByName("127.0.0.1"); socket = new Socket(inet, 8899); //2.獲取一個(gè)輸出流,用于輸出數(shù)據(jù) os = socket.getOutputStream(); //3.寫出數(shù)據(jù)的操作 os.write("你好,我是客戶端mm".getBytes()); } catch (IOException e) { e.printStackTrace(); } finally { //4.資源的關(guān)閉 if(os != null){ try { os.close(); } catch (IOException e) { e.printStackTrace(); } } if(socket != null){ try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } } } //服務(wù)端 @Test public void server(){ ServerSocket ss = null; Socket socket = null; InputStream is = null; ByteArrayOutputStream baos = null; try { //1.創(chuàng)建服務(wù)器的ServerSocket,指明自己的端口號(hào) ss = new ServerSocket(8899); //2.調(diào)用accept()表示接收來(lái)自于客戶端的socket socket = ss.accept(); //3.獲取輸入流 is = socket.getInputStream(); //不建議這樣寫,可能會(huì)有亂碼 // byte[] buffer = new byte[1024]; // int len; // while((len = is.read(buffer)) != -1){ // String str = new String(buffer,0,len); // System.out.println(str); // } //4.讀取輸入流中的數(shù)據(jù) baos = new ByteArrayOutputStream(); byte[] buffer = new byte[5]; int len; while((len = is.read(buffer)) != -1){ baos.write(buffer,0,len); } System.out.println(baos.toString()); } catch (IOException e) { e.printStackTrace(); } finally { //5.關(guān)閉資源 if(baos != null){ try { baos.close(); } catch (IOException e) { e.printStackTrace(); } } if(is != null){ try { is.close(); } catch (IOException e) { e.printStackTrace(); } } if(socket != null){ try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } if(ss != null){ try { ss.close(); } catch (IOException e) { e.printStackTrace(); } } } } }
實(shí)現(xiàn)TCP的網(wǎng)絡(luò)編程 例題2:客戶端發(fā)送文件給服務(wù)端,服務(wù)端將文件保存在本地。 public class TCPTest2 { //這里異常處理的方式應(yīng)該使用try-catch-finally @Test public void client() throws IOException { Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9090); OutputStream os = socket.getOutputStream(); FileInputStream fis = new FileInputStream(new File("beauty.jpg")); byte[] buffer = new byte[1024]; int len; while((len = fis.read(buffer)) != -1){ os.write(buffer,0,len); } fis.close(); os.close(); socket.close(); } //這里異常處理的方式應(yīng)該使用try-catch-finally @Test public void server() throws IOException { ServerSocket ss = new ServerSocket(9090); Socket socket = ss.accept(); InputStream is = socket.getInputStream(); FileOutputStream fos = new FileOutputStream(new File("beauty1.jpg")); byte[] buffer = new byte[1024]; int len; while((len = is.read(buffer)) != -1){ fos.write(buffer,0,len); } fos.close(); is.close(); socket.close(); ss.close(); } }
實(shí)現(xiàn)TCP的網(wǎng)絡(luò)編程 例題3:從客戶端發(fā)送文件給服務(wù)端,服務(wù)端保存到本地,并返回"發(fā)送成功"給客戶端。并關(guān)閉相應(yīng)的連接 public class TCPTest3 { @Test public void client() throws IOException { Socket socket = new Socket(InetAddress.getByName("127.0.0.1"), 9090); OutputStream os = socket.getOutputStream(); FileInputStream fis = new FileInputStream(new File("beauty.jpg")); byte[] buffer = new byte[1024]; int len; while((len = fis.read(buffer)) != -1){ os.write(buffer,0,len); } //服務(wù)區(qū)端給予客戶端反饋 OutputStream os1 = socket.getOutputStream(); os.write("你好,美女,照片我以收到,非常漂亮!".getBytes()); fis.close(); os.close(); socket.close(); os1.close(); } //這里異常處理的方式應(yīng)該使用try-catch-finally @Test public void server() throws IOException { ServerSocket ss = new ServerSocket(9090); Socket socket = ss.accept(); InputStream is = socket.getInputStream(); FileOutputStream fos = new FileOutputStream(new File("beauty2.jpg")); byte[] buffer = new byte[1024]; int len; while((len = is.read(buffer)) != -1){ fos.write(buffer,0,len); } //接受來(lái)自于服務(wù)器端的數(shù)據(jù),并顯示到控制臺(tái)上 InputStream is1 = socket.getInputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream(); byte[] bufferr = new byte[20]; int len1; while((len1 = is1.read(buffer)) != -1){ baos.write(buffer,0,len1); } System.out.println(baos.toString()); fos.close(); is.close(); socket.close(); ss.close(); baos.close(); } }
UDP協(xié)議的網(wǎng)絡(luò)編程 public class UDPTest { @Test public void sender() throws IOException { DatagramSocket socket = new DatagramSocket(); String str = "我是UDP方式發(fā)送的導(dǎo)彈"; byte[] data = str.getBytes(); InetAddress inet = InetAddress.getLocalHost(); DatagramPacket packet = new DatagramPacket(data,0,data.length,inet,9090); socket.send(packet); socket.close(); } @Test public void receiver() throws IOException { DatagramSocket socket = new DatagramSocket(9090); byte[] buffer = new byte[100]; DatagramPacket packet = new DatagramPacket(buffer, 0, buffer.length); socket.receive(packet); System.out.println(new String(packet.getData(),0,packet.getLength())); }
URL類
URL網(wǎng)絡(luò)編程 1.URL:統(tǒng)一資源定位符,對(duì)應(yīng)著互聯(lián)網(wǎng)的某一資源地址 2.格式: http://localhost:8080/examples/beauty.jpg?username=Tom 協(xié)議 主機(jī)名 端口號(hào) 資源地址 參數(shù)列表 public class URLTest { public static void main(String[] args) { try { URL url = new URL("http://localhost:8080/examples/beauty.jpg?username=Tom"); // public String getProtocol() 獲取該URL的協(xié)議名 System.out.println(url.getProtocol());// http // public String getHost() 獲取該URL的主機(jī)名 System.out.println(url.getHost());//localhost // public String getPort() 獲取該URL的端口號(hào) System.out.println(url.getPort());// 8080 // public String getPath() 獲取該URL的文件路徑 System.out.println(url.getPath());//examples/beauty.jpg // public String getFile() 獲取該URL的文件名 System.out.println(url.getFile());//examples/beauty.jpg?username=Tom // public String getQuery() 獲取該URL的查詢名 System.out.println(url.getQuery());//username=Tom } catch (MalformedURLException e) { e.printStackTrace(); } } }
到此這篇關(guān)于Java網(wǎng)絡(luò)編程之入門篇的文章就介紹到這了,更多相關(guān)Java網(wǎng)絡(luò)編程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Boot如何排除自動(dòng)加載數(shù)據(jù)源
這篇文章主要介紹了Spring?Boot如何排除自動(dòng)加載數(shù)據(jù)源,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12利用Java實(shí)現(xiàn)更改Word中的頁(yè)面大小和頁(yè)面方向
這篇文章主要為大家詳細(xì)介紹了一種高效便捷的方法——通過(guò)Java應(yīng)用程序,以編程方式更改Word中的頁(yè)面大小和頁(yè)面方向,感興趣的可以了解一下2023-03-03Jmeter的接口測(cè)試詳細(xì)步驟并實(shí)現(xiàn)業(yè)務(wù)閉環(huán)
這篇文章主要介紹了Jmeter的接口測(cè)試詳細(xì)步驟并實(shí)現(xiàn)業(yè)務(wù)閉環(huán),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08Java用list儲(chǔ)存,遍歷,查詢指定信息過(guò)程詳解
這篇文章主要介紹了Java用list儲(chǔ)存,遍歷,查詢指定信息過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10通過(guò)實(shí)例解析Java class文件編譯加載過(guò)程
這篇文章主要介紹了通過(guò)實(shí)例解析Java class文件編譯加載過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07詳解Java中多線程異常捕獲Runnable的實(shí)現(xiàn)
這篇文章主要介紹了詳解Java中多線程異常捕獲Runnable的實(shí)現(xiàn)的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握這樣的知識(shí),需要的朋友可以參考下2017-10-10詳解高性能緩存Caffeine原理及實(shí)戰(zhàn)
Caffeine是基于Java 8開(kāi)發(fā)的,提供了近乎最佳命中率的高性能本地緩存組件,Spring5開(kāi)始不再支持Guava Cache,改為使用Caffeine。Caffeine提供的內(nèi)存緩存使用參考Google guava的API2021-06-06Java利用for循環(huán)輸出空心菱形的實(shí)例代碼
這篇文章主要介紹了Java利用for循環(huán)輸出空心菱形的實(shí)例代碼,需要的朋友可以參考下2014-02-02java中@JSONField和@JsonProperty注解的使用說(shuō)明及對(duì)比
@JSONField與@JsonProperty隸屬兩個(gè)不同的包,前者是阿里系的fastjson包,后者是spring?boot官方使用的jackson包,本文主要介紹了java中@JSONField和@JsonProperty注解的使用說(shuō)明及對(duì)比,感興趣的可以了解一下2023-11-11