Java Socket通信(一)之客戶端程序 發(fā)送和接收數(shù)據(jù)
網(wǎng)絡(luò)應用分為客戶端和服務端兩部分,而Socket類是負責處理客戶端通信的Java類。通過這個類可以連接到指定IP或域名的服務器上,并且可以和服務器互相發(fā)送和接受數(shù)據(jù)。
對于Socket通信簡述,服務端往Socket的輸出流里面寫東西,客戶端就可以通過Socket的輸入流讀取對應的內(nèi)容。Socket與Socket之間是雙向連通的,所以客戶端也可以往對應的Socket輸出流里面寫東西,然后服務端對應的Socket的輸入流就可以讀出對應的內(nèi)容。
例1:客戶端的簡略寫法(一)。
Socket client = null;
try{
client = new Socket(Ip,Port);
String msg="發(fā)送的數(shù)據(jù)內(nèi)容!";
//得到socket讀寫流,向服務端程序發(fā)送數(shù)據(jù)
client.getOutputStream().write(msg.getBytes());
byte[] datas = new byte[2048];
//從服務端程序接收數(shù)據(jù)
client.getInputStream().read(datas);
System.out.println(new String(datas));
}catch(Exception e){
e.printStackTrace();
}finally {
if (client != null) {
try {
client.close();
} catch (IOException e) {
System.out.println("systemerr:" +e);
}
}
}
例2:客戶端簡略寫法(二)。
try{
client = new Socket();
SocketAddress socketAddress = new InetSocketAddress(Ip,Port);
client.connect(socketAddress, 3000);
String msg="訪問的服務器返回內(nèi)容!";
//得到socket讀寫流,向服務端程序發(fā)送數(shù)據(jù)
client.getOutputStream().write(msg.getBytes());
byte[] datas = new byte[2048];
//從服務端程序接收數(shù)據(jù)
client.getInputStream().read(datas);
System.out.println(new String(datas));
}catch(Exception e){
e.printStackTrace();
}finally {
if (client != null) {
try {
client.close();
} catch (IOException e) {
System.out.println("systemerr:" +e);
}
}
}
例3:客戶端的完整寫法。
try {
//1.建立客戶端socket連接,指定服務器位置及端口
Socket socket =new Socket(Ip,Port);
//2.得到socket讀寫流
OutputStream os=socket.getOutputStream();
PrintWriter pw=new PrintWriter(os);
//輸入流
InputStream is=socket.getInputStream();
BufferedReader br=new BufferedReader(new InputStreamReader(is));
//3.利用流按照一定的操作,對socket進行讀寫操作
String sendInfo="向服務器發(fā)送的數(shù)據(jù)信息!";
pw.write(sendInfo);
pw.flush();
socket.shutdownOutput();
//接收服務器的相應
String replyInfo=null;
while(!((replyInfo=br.readLine())==null)){
System.out.println("接收服務器的數(shù)據(jù)信息:"+replyInfo);
}
//4.關(guān)閉資源
br.close();
is.close();
pw.close();
os.close();
socket.close();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
關(guān)于Java Socket通信(一)之客戶端程序 發(fā)送和接收數(shù)據(jù)的相關(guān)知識,小編就給大家介紹到這里,更多信息請登陸腳本之家網(wǎng)站了解更多內(nèi)容!
相關(guān)文章
Springboot+Redis實現(xiàn)API接口防刷限流的項目實踐
本文主要介紹了Springboot+Redis實現(xiàn)API接口防刷限流的項目實踐,通過限流可以讓系統(tǒng)維持在一個相對穩(wěn)定的狀態(tài),為更多的客戶提供服務,具有一定的參考價值,感興趣的可以了解一下2024-07-07
JAVA通過HttpURLConnection 上傳和下載文件的方法
這篇文章主要介紹了JAVA通過HttpURLConnection 上傳和下載文件的方法,非常具有實用價值,需要的朋友可以參考下2017-09-09
Spring框架應用的權(quán)限控制系統(tǒng)詳解
在本篇文章里小編給大家整理的是關(guān)于基于Spring框架應用的權(quán)限控制系統(tǒng)的研究和實現(xiàn),需要的朋友們可以學習下。2019-08-08
Springboot基于enable模塊驅(qū)動的實現(xiàn)
這篇文章主要介紹了Springboot基于enable模塊驅(qū)動的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08

