使用socket实现局域网聊天,写这个主要是为了深入理解socket与信息流在网络中的传送过程加深理解。
代码很简单分为两个类,一个服务器类,一个客户端,运行时分别启动两个线程一个负责接受另一个负责发送。
整体流程是 两台机器分别启动程序,一个选择主动连接 另一个选择被动接受,即可实现类似qq的聊天效果两个人可以同时发送消息。
注意的事,不要在同一台电脑上同时启动两个,这样会服务端和客户端的ip都是相同很有可能造成自己发送的消息自己接受到了,可以两台电脑或者虚拟机里面进行。
服务端:
package com.server;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;
import com.client.RunClient;
public class RunServer {
public static Socket socket=null;
/**
* 建立服务器被动连接
* @throws IOException
*/
public void startServer() throws IOException {
//服务器接收数据
ServerSocket serverSocekt=new ServerSocket(8888);
System.out.println("服务器启动,等待连接...");
//创建客户端线程
RunClient rc=new RunClient();
Thread rct=new Thread(rc);
rct.start();
//阻塞线程 监听端口建立socket会话
RunServer.socket=serverSocekt.accept();
//获取输入留
InputStream is=socket.getInputStream();
//将字节输入流转换成字符输入流
InputStreamReader isr=new InputStreamReader(is);
//将字符输入流装入带缓冲的输入流中
BufferedReader br=new BufferedReader(isr);
String str=null;
while((str=br.readLine())!=null){
System.out.print("输出信息:"+str);
}
socket.shutdownInput();
serverSocekt.close();
}
}客户端:
package com.client;
import java.io.BufferedWriter;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Scanner;
import com.server.RunServer;
public class RunClient implements Runnable {
@Override
public void run() {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
System.out.println("1、主动连接\n2、被动等待");
String sign=input.next();
switch (sign) {
case "1":
try {
System.out.println("输入服务器IP:");
startClient(input.next());
} catch (Exception e) {
e.printStackTrace();
}
break;
case "2":
try {
startClient();
} catch (Exception e) {
e.printStackTrace();
}
break;
default:
break;
}
}
/**
* 由已经建立的socket 进行连接反向连
* @throws Exception
* @throws UnknownHostException
*/
public void startClient() throws Exception{
while(true){
try {
if(RunServer.socket!=null){
break;
}
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
// 与服务器建立连接
Socket socket=new Socket(RunServer.socket.getInetAddress().getHostAddress(), 8888);
System.out.println("连接建立成功...");
//向服务器写入流
OutputStream os=socket.getOutputStream();
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(os));
Scanner input=new Scanner(System.in);
while(true){
System.out.println("输入信息:");
bw.write(input.next());
bw.newLine();
bw.flush();
}
}
/**
* 通过IP与服务器建立连接
* @throws Exception
* @throws UnknownHostException
*/
public void startClient(String ip) throws Exception{
// 与服务器建立连接
Socket socket=new Socket(ip, 8888);
System.out.println("连接建立成功...");
//向服务器写入流
OutputStream os=socket.getOutputStream();
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(os));
Scanner input=new Scanner(System.in);
while(true){
bw.write(input.next());
bw.newLine();
bw.flush();
}
}
}main:
package com.start;
import com.server.RunServer;
public class Go {
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
RunServer rs=new RunServer();
rs.startServer();
}
}效果:我是用虚拟机加本机

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持html5模板网。
Java数据结构之堆(优先队列)的实现堆(优先队列)是一种典型的数据结构,其形状是一棵完全二叉树,一般用于求解topk问题。本文将利用Java语言实现堆
详解Java中Dijkstra(迪杰斯特拉)算法的图解与实现Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径。本文将详解该算
Java中ThreadLocal 导致内存 OOM 的原因分析这篇文章主要介绍了Java中ThreadLocal导致内存OOM的原因分析,文章基于Java的相关内容展开ThreadLocal导致内存OOM的原因分
Java中CyclicBarrier 循环屏障这篇文章主要介绍了Java中CyclicBarrier 循环屏障,可以实现让一组线程等待至某个状态屏障点之后再全部同时执行,下
利用Java代码写一个并行调用模板这篇文章主要介绍了利用Java代码写一个并行调用模板,文章基于Java的相关内容展开写一个并行调用模板的详细介绍,
Java高版本Api在Android中的使用方法详解API(Application Programming Interface)应用程序编程接口,java API是一本程序员字典,是JDK提供给我们使用的类的说明文档,下面