java網(wǎng)絡(luò)編程學(xué)習(xí)java聊天程序代碼分享
package com.neusoft.edu.socket;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
/**
* 服務(wù)器端代碼
* 獲取客戶端發(fā)送的信息,顯示并且返回對(duì)應(yīng)的回復(fù)
* 1、創(chuàng)建ServerSocket對(duì)象
* 2、調(diào)用accept方法獲取客戶端連接
* 3、使用輸入流讀取客戶端發(fā)送的數(shù)據(jù)
* 4、使用輸出流向客戶端寫(xiě)入數(shù)據(jù)
* 5、關(guān)閉對(duì)應(yīng)的對(duì)象
* @author L
*
*/
public class ChatServer {
/**
* @param args
*/
public static void main(String[] args) {
try {
//1、創(chuàng)建ServerSocket對(duì)象,8875為自定義端口號(hào)
ServerSocket server = new ServerSocket(8857);
//簡(jiǎn)單提示
System.out.println("等待客戶端連接……");
//2、獲取客戶端連接
Socket client = server.accept();
//獲取客戶端的相關(guān)信息
System.out.println(client.getInetAddress().getHostAddress() + "連接上來(lái)了……");
//3.1、定義輸入流和輸出流對(duì)象
BufferedReader in = new BufferedReader(
new InputStreamReader(
client.getInputStream()));
//用來(lái)獲取從控制臺(tái)輸入的數(shù)據(jù),將該數(shù)據(jù)發(fā)送給客戶端
BufferedReader inByServer = new BufferedReader(
new InputStreamReader(System.in));
PrintWriter out = new PrintWriter(client.getOutputStream(), true);
//讀取到的數(shù)據(jù)
String data = null;
String answer = null;
//循環(huán)和客戶端進(jìn)行通信
do
{
//3.2、讀取客戶端發(fā)送的數(shù)據(jù)
data = in.readLine();
//在服務(wù)器端顯示讀取到的數(shù)據(jù)
System.out.println("客戶端發(fā)送信息:" + data);
//獲取服務(wù)器端要發(fā)送給客戶端的信息
System.out.print("服務(wù)器端回復(fù)客戶端:");
answer = inByServer.readLine();
//3.3、將數(shù)據(jù)寫(xiě)入到客戶端
out.println(answer);
out.flush();
}while(!"bye".equals(data));
//4、關(guān)閉相關(guān)資源
out.flush();
in.close();
inByServer.close();
out.close();
//關(guān)閉Socket對(duì)象
client.close();
server.close();
System.out.println("服務(wù)器端關(guān)閉……");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
package com.neusoft.edu.socket;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException;
/**
* 聊天客戶端
* 1、創(chuàng)建Socket對(duì)象
* 2、寫(xiě)入數(shù)據(jù)
* 3、讀取從服務(wù)器端發(fā)來(lái)的數(shù)據(jù)
* 4、關(guān)閉
* @author L
*
*/
public class ChatClient {
/**
* @param args
*/
public static void main(String[] args) {
try {
//1、創(chuàng)建Socket對(duì)象,("192.168.1.107", 8857)分別為主機(jī)IP和端口號(hào),兩個(gè)類端口號(hào)要一致
Socket client = new Socket("192.168.1.107", 8857);
//2.1、創(chuàng)建輸入流和輸出流對(duì)象
BufferedReader in = new BufferedReader(
new InputStreamReader(
client.getInputStream()));
PrintWriter out = new PrintWriter(client.getOutputStream(), true);
BufferedReader inByClient = new BufferedReader(
new InputStreamReader(System.in));
//服務(wù)器端發(fā)送的數(shù)據(jù)
String data = null;
//客戶端向服務(wù)器端寫(xiě)入的數(shù)據(jù)
String answer = null;
do
{
//2.2、客戶端的讀寫(xiě)操作
System.out.print("你說(shuō):");
//獲取要發(fā)送給服務(wù)器端的數(shù)據(jù)
answer = inByClient.readLine();
//向服務(wù)器端寫(xiě)入數(shù)據(jù)
out.println(answer);
out.flush();
//獲取服務(wù)器端發(fā)送的數(shù)據(jù)
data = in.readLine();
//輸出從服務(wù)器端獲取的數(shù)據(jù)
System.out.println("服務(wù)器端返回信息是:" + data);
}while(!"bye".equals(data));
//3、關(guān)閉
in.close();
out.close();
inByClient.close();
client.close();
System.out.println("客戶端關(guān)閉……");
} catch (UnknownHostException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
- java中UDP簡(jiǎn)單聊天程序?qū)嵗a
- 詳解基于java的Socket聊天程序——客戶端(附demo)
- java基于TCP協(xié)議實(shí)現(xiàn)聊天程序
- java基于C/S模式實(shí)現(xiàn)聊天程序(客戶端)
- 詳解基于java的Socket聊天程序——服務(wù)端(附demo)
- java實(shí)現(xiàn)基于Tcp的socket聊天程序
- 詳解基于java的Socket聊天程序——初始設(shè)計(jì)(附demo)
- java實(shí)現(xiàn)簡(jiǎn)單TCP聊天程序
- 基于Java的Socket多客戶端Client-Server聊天程序的實(shí)現(xiàn)
- 用Java實(shí)現(xiàn)聊天程序
相關(guān)文章
easyexcel讀取excel合并單元格數(shù)據(jù)的操作代碼
這篇文章主要介紹了easyexcel讀取excel合并單元格數(shù)據(jù)的操作代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
MySQL數(shù)據(jù)庫(kù)之Purge死鎖問(wèn)題解析
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)之Purge死鎖問(wèn)題解析的相關(guān)資料,需要的朋友可以參考下2017-11-11
Springboot+Flowable?快速實(shí)現(xiàn)工作流的開(kāi)發(fā)流程
這篇文章主要介紹了Springboot+Flowable?快速實(shí)現(xiàn)工作流的開(kāi)發(fā)流程,本文通過(guò)實(shí)例代碼圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
OKHttp3(支持Retrofit)的網(wǎng)絡(luò)數(shù)據(jù)緩存Interceptor攔截器的實(shí)現(xiàn)
本篇文章主要介紹了OKHttp3(支持Retrofit)的網(wǎng)絡(luò)數(shù)據(jù)緩存Interceptor攔截器的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
利用SpringBoot解決多個(gè)定時(shí)任務(wù)阻塞的問(wèn)題
當(dāng)我們?cè)赟pring Boot應(yīng)用中使用多個(gè)定時(shí)任務(wù)時(shí),任務(wù)之間的阻塞可能是一個(gè)常見(jiàn)的問(wèn)題,這可能會(huì)因任務(wù)之間的依賴、執(zhí)行時(shí)間過(guò)長(zhǎng)或資源爭(zhēng)用等原因而發(fā)生,本文讓我們深入探討如何利用Spring Boot來(lái)解決多個(gè)定時(shí)任務(wù)阻塞的問(wèn)題,感興趣的小伙伴跟著小編一起來(lái)看看吧2024-01-01
詳解Java并發(fā)工具類之CountDownLatch和CyclicBarrier
在JDK的并發(fā)包中,有幾個(gè)非常有用的并發(fā)工具類,它們分別是:CountDownLatch、CyclicBarrier、Semaphore和Exchanger,本文主要來(lái)講講其中CountDownLatch和CyclicBarrier的使用,感興趣的可以了解一下2023-06-06

