Java实现UDP之Echo客户端和服务端

代码内容

  • 采用UDP协议编写服务器端代码(端口任意)
  • 编写客户机的代码访问该端口
  • 客户机按行输入
  • 服务器将收到的字符流和接收到的时间输出在服务器console
  • 原样返回给客户机在客户机console显示出来

代码实现

/* UDPEchoClient.java */
import java.io.*;
import java.net.*; public class UDPEchoClient {
public final static String serverIP = "localhost";
public final static int serverPort = 13;
public static String userName = null; @SuppressWarnings("resource")
public static void main(String[] args) {
DatagramSocket client = null;
try {
/* 获取服务器地址 */
InetAddress server = InetAddress.getByName(serverIP);
/* 创建客户端DatagramSocket */
client = new DatagramSocket();
/* 从用户键盘读取输入 */
BufferedReader sin = new BufferedReader(new InputStreamReader(System.in));
/* 登陆 */
System.out.print("Please Login: ");
userName = sin.readLine();
/* 获取用户输入的一行,exit则退出 */
String line;
System.out.print("> ");
line = sin.readLine();
while (!line.equals("exit")) {
line = "[" + userName + "]: " + line;
/* 从用户输入转化为byte */
byte[] data = line.getBytes("utf-8");
/* 将byte内容转化为UDP数据包 */
DatagramPacket sendPacket = new DatagramPacket(data, data.length, server, serverPort);
/* UPD发送数据包 */
client.send(sendPacket);
/* 定义接收byte空间 */
byte[] buffer = new byte[8192];
/* 将UDP数据包内容保存在byte中 */
DatagramPacket receivePacket = new DatagramPacket(buffer, buffer.length);
/* UDP接收数据包 */
client.receive(receivePacket);
/* 输出服务器返回的内容 */
System.out.println(new String(receivePacket.getData(), receivePacket.getOffset(),
receivePacket.getLength(), "utf-8"));
/* 读取用户下一行输入 */
System.out.print("> ");
line = sin.readLine();
}
} catch (SocketException e) {
e.printStackTrace();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
/* 安全关闭Socket */
try {
if (client != null) {
client.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
/* UDPEchoServer.java */
import java.io.*;
import java.net.*;
import java.util.Date; public class UDPEchoServer {
public final static int serverPort = 13; @SuppressWarnings({ "resource", "static-access", "unused" })
public static void main(String[] args) {
DatagramSocket server = null;
try {
/* 创建服务端DatagramSocket */
server = new DatagramSocket(serverPort);
System.out.println("Server start running...");
while (true) {
/* 定义接收byte空间 */
byte[] buffer = new byte[8192];
/* 将UDP数据包内容保存在byte中 */
DatagramPacket receivePacket = new DatagramPacket(buffer, buffer.length);
/* UDP接收数据包 */
server.receive(receivePacket);
/* 获取当前系统时间 */
Date currentTime = new Date();
/* 处理客户端的输入 */
String echo = new String(receivePacket.getData(), receivePacket.getOffset(),
receivePacket.getLength(), "utf-8");
echo = currentTime.toString().split(" ")[3] + " " + echo;
/* 打印系统日志记录用户输入 */
System.out.println(echo);
/* 从客户端输入转化为byte */
byte[] data = echo.getBytes("utf-8");
/* 将byte内容转化为UDP数据包 */
DatagramPacket sendPacket = new DatagramPacket(data, data.length,
receivePacket.getAddress(), receivePacket.getPort());
/* UPD发送数据包 */
server.send(sendPacket);
}
} catch (SocketException e) {
e.printStackTrace();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
/* 安全关闭Socket */
try {
if (server != null) {
server.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
/* Makefile */
target:
javac -encoding utf-8 UDPEchoClient.java
javac -encoding utf-8 UDPEchoServer.java run-UDPEchoClient:
java UDPEchoClient run-UDPEchoServer:
java UDPEchoServer clean:
rm *.class

运行截图

问题解决方案

  1. 中文编码问题:在代码使用UTF-8编码并且编译选项添加UTF8参数的话,不需要在代码中声明为UTF8编码,使用了反而会出错,亲测。
  2. 面向连接的传输TCP:由于需要面向连接,因此一个服务端需要和多个客户端进行通信,这就需要在服务端使用多线程技术,一个客户端分配一个线程,分别处理不同客户端的通信。
  3. 面向无连接的传输UDP:由于不需要连接,也不在意可靠传输,因此当客户端发送了一个数据包之后,若一定时间内没有返回内容,可以认为传输失败,让用户接着输入下一个内容。
  4. 关于TCP的聊天室:在客户端中无法体现出一个聊天室的完成功能,但是服务端是体现出来了,如果需要在客户端也有这个体现,需要做线程之间的通信,想想还是太麻烦我就没做了。
  5. 还有一点是面向连接的程序,不应该每发送一次就连接一次再断开连接,这样子的通信效率太低,而是应该等到客户端退出后再断开连接,这点已实现。

样例代码下载

传送门:下载

Java实现UDP之Echo客户端和服务端的更多相关文章

  1. Java实现TCP之Echo客户端和服务端

    Java实现TCP之Echo客户端和服务端 代码内容 采用TCP协议编写服务器端代码(端口任意) 编写客户机的代码访问该端口 客户机按行输入 服务器将收到的字符流和接收到的时间输出在服务器consol ...

  2. 在Java中使用Socket模拟客户端和服务端(多线程)

    1:Socket与ServerSocket的交互 2.Socket和ServerSocket介绍 Socket 构造函数 Socket() Socket(InetAddress address, in ...

  3. [Java]Hessian客户端和服务端代码例子

    简要说明:这是一个比较简单的hessian客户端和服务端,主要实现从客户端发送指定的数据量到服务端,然后服务端在将接收到的数据原封不动返回到客户端.设计该hessian客户端和服务端的初衷是为了做一个 ...

  4. Java基础---Java---网络编程---TCP的传输、客户端和服务端的互访、建立一个文本转换器、编写一个聊天程序

    演示TCP的传输的客户端和服务端的互访 需求:客户端给服务端发送数据,服务端收到后,给客户端反馈信息. 客户端: 1.建立Socket服务,指定要连接方朵和端口 2.获取Socket流中的输出流,将数 ...

  5. java客户端与服务端交互通用处理 框架解析

    一.综述 java 客户端与服务端交互过程中,采用NIO通讯是异步的,客户端基本采用同一处理范式,来进行同异步的调用处理. 处理模型有以下几个要素: 1. NIO发送消息后返回的Future 2. 每 ...

  6. c++ 网络编程(一)TCP/UDP windows/linux 下入门级socket通信 客户端与服务端交互代码

    原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9601511.html c++ 网络编程(一)TCP/UDP  入门级客户端与服务端交互代码 网 ...

  7. java网络编程客户端与服务端原理以及用URL解析HTTP协议

    常见客户端与服务端 客户端: 浏览器:IE 服务端: 服务器:web服务器(Tomcat),存储服务器,数据库服务器. (注:会用到Tomact服务器,在webapps下有一个自己创建的目录myweb ...

  8. java在线聊天项目1.1版 ——开启多个客户端,分别实现注册和登录功能,使用客户端与服务端信息request机制,重构线程,将单独的登录和注册线程合并

    实现效果图: eclipse项目中初步整合之前的各个客户端和服务端的窗口与工具类,效果如下图: 已将注册服务器线程RegServer功能放到LoginServer中,使用客户端与服务端的request ...

  9. 网络编程 UDP协议 TCP局域网客户端与服务端上传下载电影示例

    UDP协议 (了解) 称之为数据包协议,又称不可靠协议. 特点: 1) 不需要建立链接. 2) 不需要知道对方是否收到. 3) 数据不安全 4) 传输速度快 5)能支持并发 6) 不会粘包 7) 无需 ...

随机推荐

  1. seafile修改

    ---恢复内容开始--- [root@seafile yunpan]# vim /yunpan/installed/seahub/seahub/templates/footer.html ---恢复内 ...

  2. Redis+php-resque实现消息队列

      服务器硬件配置 Dell PowerEdge R310英特尔单路机架式服务器 Intel Xeon Processor X3430 2.4GHz, 8MB Cache 8GB内存(2 x 4GB) ...

  3. 解决error C2011: 'fd_set' : 'struct' type redefinition的方法

    http://www.cnblogs.com/ark-zhang/archive/2013/06/19/3144383.html   首先说明这个问题由于重复定义引起的编译错误. 先说明解决方法,然后 ...

  4. (笔记)angular选中变色

  5. Linux之档案管理

    1:档案类型[1] d :目录 -:档案 l:链接档 b:装置文件中可存储接口设备 c:装置文件中串行设备,例如:键盘,鼠标 2:RWX: R:read (可读),W:write(可写),X:excu ...

  6. new_things

    'NapCat' in AppStore for reading codes from github. and the ----minibufexpl                |  + nerd ...

  7. Spring框架搭建遇到的问题汇总

    1.The resource is not on the build path of a Java project 然后把相应的依赖加入构建路径 2.Type mismatch: cannot con ...

  8. [原]hdu2602 Bone Collector (01背包)

    本文出自:http://blog.csdn.net/svitter 题意:典型到不能再典型的01背包.给了我一遍AC的快感. //=================================== ...

  9. oracle 数组类型

    create or replace function my_test(p_str varchar2) return number as --普通变量 v_var ); --固定长度数组 type v_ ...

  10. zabbix基本功能操作

    上一篇我已经把zabbix server 和zabbix agent 安装在了同一台主机上,现在如何配置zabbix server监控自己. vim /etc/zabbix/zabbix_agentd ...