java socketServer socket

本文展示了Java客户端如何通过Socket与服务器端进行数据交换,包括对象序列化与反序列化过程,以及服务器端如何接收、处理并返回数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<div class="iteye-blog-content-contain" style="font-size: 14px"></div>
客户端代码
package serialver.client;

import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInput;
import java.io.ObjectInputStream;
import java.io.ObjectOutput;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;

/**
* @ version 创建时间:2014-3-21 下午03:19:58
*
* @ author leicl
*
* 类说明:
*
*/
public class Client {

public static void main(String[] args) throws UnknownHostException, IOException, ClassNotFoundException {
Socket s = new Socket(InetAddress.getLocalHost(), 2323);
int[] a = {2,3,4,5};
int[] b = {1,1,1,1};
InputStream is = s.getInputStream();
ObjectInput ois = new ObjectInputStream(is);
OutputStream os = s.getOutputStream();
ObjectOutput oos = new ObjectOutputStream(os);

oos.writeObject(a);
oos.writeObject(b);
int[] result = (int[]) ois.readObject();
System.out.println("result got from MathServer:");
for (int i = 0; i < result.length; i++) {
System.out.print(result[i]+"\t");
}
ois.close();
oos.close();
}

}
服务器端代码:
package serialver.server;

import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInput;
import java.io.ObjectInputStream;
import java.io.ObjectOutput;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;

/**
* @ version 创建时间:2014-3-21 下午03:06:52
*
* @ author leicl
*
* 类说明:
*
*/
public class MathServer extends Thread{

public static void main(String[] args) throws IOException {

final ServerSocket ser = new ServerSocket(2323);

new Thread(new Runnable() {
public void run() {
while(true){
try {
final Socket accept = ser.accept();
int[] a = new int[10];
int[] b = new int[10];
int[] result = new int[10];
try {
//此处注意,应该先new ObjectOutput,否则会出现卡死问题
//而且系统捕获不到任何异常
OutputStream os = accept.getOutputStream();
ObjectOutput oos = new ObjectOutputStream(os);
InputStream in = accept.getInputStream();
ObjectInput ois = new ObjectInputStream(in);
a = (int[]) ois.readObject();
b = (int[]) ois.readObject();

for (int i = 0; i < a.length; i++) {
System.out.println("a["+i+"]=" +a[i]);
}
for (int i = 0; i < b.length; i++) {
System.out.println("b["+i+"]=" +b[i]);
}
for (int i = 0; i < b.length; i++) {
result[i] = a[i] + b[i];
}
for (int i = 0; i < result.length; i++) {
System.out.println("result["+i+"]=" +result[i]);
}
oos.writeObject(result);
oos.flush();

ois.close();
oos.close();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}).start();
}

}
### 创建Java SocketServerJava中,`ServerSocket`类用于创建服务器套接字,该对象可以监听来自客户端的连接请求。当有新的连接到达时,会返回一个新的`Socket`实例来处理这个特定的客户机连接[^2]。 下面展示了一个简单的Java `ServerSocket`示例: ```java import java.io.*; import java.net.*; public class SimpleServer { public static void main(String[] args) throws IOException { int port = 8080; try (ServerSocket serverSocket = new ServerSocket(port)) { // 创建ServerSocket并绑定到指定端口 System.out.println("Server started, listening on port " + port); while (true) { // 循环等待接受新连接 Socket clientSocket = serverSocket.accept(); // 接受一个新连接 // 处理客户端连接... BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream())); PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true); String inputLine; StringBuilder sb = new StringBuilder(); while ((inputLine = in.readLine()) != null && !inputLine.isEmpty()) { sb.append(inputLine).append("\n"); } System.out.println("Received message from client: " + sb.toString()); // 打印收到的消息[^4] out.println("Echo: " + sb.toString()); clientSocket.close(); // 关闭当前连接 } } catch (IOException e) { System.err.println("Exception caught when trying to listen on port " + port + " or listening for a connection"); System.err.println(e.getMessage()); } } } ``` 此代码片段展示了如何设置一个基本的服务端程序,它可以接收来自客户端的信息并将这些信息回显给发送者。这里使用了`BufferedReader`读取输入流中的数据,并通过`PrintWriter`向输出流写入响应消息[^1]。 对于更复杂的应用场景,可能还需要考虑多线程支持以便能够同时服务于多个并发连接;错误处理机制以应对可能出现的各种异常情况;以及安全性措施如SSL/TLS加密通信等[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值