Java 网络编程之 Socket
========================UDP=============================
UDP---用户数据报协议,是一个简单的面向数据报的运输层协议。
UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去,但是并不能保证它们能到达目的地。
由于UDP在传输数据报前不用在客户和服务器之间建立一个连接,且没有超时重发等机制,故而传输速度很快。
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; public class UDPServer {
public static void main(String[] args) {
try {
System.out.println("**服务器已经启动**"); // 指定服务端口号、数据包大小
int serverPort = 8800;
byte[] data = new byte[1024];
// 创建服务端DatagramSocket,并指定端口号
DatagramSocket socket = new DatagramSocket(serverPort); /* UDP数据传输 */
while (true) { /* 处理客户端的请求 */
// 创建数据报DatagramPacket,用于接收客户端发送的数据
DatagramPacket packet = new DatagramPacket(data, data.length);
// 等待客户端的连接请求
socket.receive(packet);
// 获取客户端发送的数据
String content = new String(data, 0, packet.getLength()); /* 服务器处理任务 */
System.out.println("处理需要转置的字符串:" + content);
StringBuffer temp = new StringBuffer().append(content);
// 倒置字符串
content = new String(temp.reverse()); /* 发送服务端响应 */
// 定义客户端的地址、端口号、数据
InetAddress address = packet.getAddress();
int clientPort = packet.getPort();
byte[] reply = content.getBytes();
// 创建数据报,含响应的数据信息
DatagramPacket packet2 = new DatagramPacket(reply, reply.length, address, clientPort);
// 响应客户端
socket.send(packet2);
}
// 关闭资源
// socket.close(); } catch (Exception e) {
e.printStackTrace();
}
}
}
UDPServer.java
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.util.Scanner; public class UDPClient {
public static void main(String[] args) {
try { /* 获取用户需要处理的字符串 */
Scanner scanner = new Scanner(System.in);
System.out.print("输入需要倒转的字符串:");
String content = scanner.nextLine(); /* 向服务器发送数据 */
// 定义服务器的地址、端口号、数据
InetAddress address = InetAddress.getByName("localhost");
int clientPort = 8800;
// 将字符串转换为字节数组
byte[] data = content.getBytes();
// 创建数据报,包含发送的数据
DatagramPacket packet = new DatagramPacket(data, data.length, address, clientPort);
// 创建DatagramSocket对象
DatagramSocket socket = new DatagramSocket();
// 向服务器发送数据报
socket.send(packet); /* 从服务器获得数据 */
// 创建数据报,用于接收服务器端响应的数据
byte[] reply = new byte[1024];
DatagramPacket packet2 = new DatagramPacket(reply, reply.length);
// 接收服务器相应的数据
socket.receive(packet2);
// 读取字节数组中的数据
content = new String(reply, 0, packet2.getLength());
System.out.println("转置后的结果为:" + content); /* 关闭资源 */
socket.close();
scanner.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
UDPClient.java
服务端输出:
**服务器已经启动**
处理需要转置的字符串:JavaScript 客户端输出:
输入需要倒转的字符串:JavaScript
转置后的结果为:tpircSavaJ
========================TCP==============================
TCP---传输控制协议,提供的是面向连接、可靠的字节流服务。
当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据。
TCP提供超时重发,丢弃重复数据,检验数据,流量控制等功能,保证数据能从一端传到另一端。
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket; public class TCPServer {
public static void main(String[] args) {
try {
System.out.println("**服务器已经启动**"); // 创建服务器Socket,并填写端口号
ServerSocket serverSocket = new ServerSocket(8888); /* TCP数据传输 */
while (true) { /* 处理客户端的请求 */
// 调用accept()方法监听客户端连接
Socket socket = serverSocket.accept();
// 从客户端接收内容
InputStream is = socket.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader reader = new BufferedReader(isr);
// 将响应内容存入字符串中
String data = null;
StringBuffer content = new StringBuffer();
do {
if (data != null) {
content.append(data);
}
} while ((data = reader.readLine()) != null);
// 关闭输入流
socket.shutdownInput(); /* 服务器处理任务 */
System.out.println("处理需要转置的字符串:" + content);
// 倒置字符串
content = content.reverse(); /* 发送服务端响应 */
OutputStream os = socket.getOutputStream();
PrintWriter writer = new PrintWriter(os);
writer.write(new String(content));
writer.flush();
// 关闭输出流
socket.shutdownOutput(); /* 关闭资源 */
reader.close();
isr.close();
is.close();
writer.close();
os.close();
socket.close();
} /* 关闭Socket */
// serverSocket.close(); } catch (Exception e) {
e.printStackTrace();
}
}
}
TCPServer.java
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.util.Scanner; public class TCPClient {
public static void main(String[] args) {
try { // 创建客户端Socket,指定服务器地址和端口
Socket socket = new Socket("localhost", 8888); /* 获取用户需要处理的字符串 */
Scanner scanner = new Scanner(System.in);
System.out.print("输入需要倒转的字符串:");
String content = scanner.nextLine(); /* 向服务器发送数据 */
// 将数据以输出流形式发送
OutputStream os = socket.getOutputStream();
PrintWriter writer = new PrintWriter(os);
writer.write(content); // 写入数据
writer.flush(); // 刷新缓存
// 关闭输出流
socket.shutdownOutput(); /* 从服务器获得数据 */
// 将数据以输入流形式获取
InputStream is = socket.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader reader = new BufferedReader(isr);
/* 将响应内容存入字符串中 */
String data = null;
StringBuffer buffer = new StringBuffer();
do {
if (data != null) {
buffer.append(data);
}
} while ((data = reader.readLine()) != null);
// 关闭输入流
socket.shutdownInput();
System.out.println("转置后的结果为:" + buffer); /* 关闭资源 */
writer.close();
os.close();
socket.close();
reader.close();
isr.close();
is.close();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
TCPClient.java
服务端输出:
**服务器已经启动**
处理需要转置的字符串:Android 客户端输出:
输入需要倒转的字符串:Android
转置后的结果为:diordnA
Java 网络编程之 Socket的更多相关文章
- java网络编程之Socket编程
概念 网络编程分为BIO(传统IO).NIO.AIO.Socket编程属于BIO这种传统IO. InetAddress java.net.InetAddress是JAVA中管理IP地址的类,常用 pu ...
- java网络编程之socket
网络编程是什么 网络编程的本质是两个设备之间的数据交换,当然,在计算机网络中,设备主要指计算机.数据传递本身没有多大的难度,不就是把一个设备中的数据发送给两外一个设备,然后接受另外一个设备反馈的数据. ...
- java网络编程之socket(1)
网络编程是什么 网络编程的本质是两个设备之间的数据交换,当然,在计算机网络中,设备主要指计算机.数据传递本身没有多大的难度,不就是把一个设备中的数据发送给两外一个设备,然后接受另外一个设备反馈的数据. ...
- java 网络编程之Socket编程
1.客户端代码 1 package com.gylhaut.socket; 2 3 import java.io.BufferedReader; 4 import java.io.IOExcept ...
- java网络编程之socket(2)
异步处理多客户端连接服务端 上篇讲到的是服务端接收一个客户端的请求之后就结束了,不能再接收其他客户端的请求了,实际情况上我们希望服务端能够处理来自不同用户的请求. 想到这里,或许我们可以用一个死循环, ...
- 网络编程之Socket & ServerSocket
网络编程之Socket & ServerSocket Socket:网络套接字,网络插座,建立网络通信连接至少要一对端口号(socket).socket本质是编程接口(API),对TCP/IP ...
- GO语言的进阶之路-网络编程之socket
GO语言的进阶之路-网络编程之socket 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是socket; 在说socket之前,我们要对两个概念要有所了解,就是IP和端口 ...
- Java网络编程之TCP、UDP
Java网络编程之TCP.UDP 2014-11-25 15:23 513人阅读 评论(0) 收藏 举报 分类: java基础及多线程(28) 版权声明:本文为博主原创文章,未经博主允许不得转载. ...
- Java网络编程之UDP
Java网络编程之UDP 一.C/S架构中UDP网络通信流程 ①创建DatagramSocket与DatagramPacket对象 ②建立发送端,接收端 ③建立数据包 ④调用Socket的发送.接收方 ...
随机推荐
- NOI2018准备Day12
上午学了1个小时左右的指针,学了个从句子中分离单词的方法,其他的感觉没学到啥. 中午看了一会儿网络流,懵逼...... A了8道题,4道钻石.3道黄金.1道白银,自己写出了codevs"解药 ...
- Java中的instanceof关键字
instanceof是Java的一个二元操作符,和==,>,<是同一类东东.由于它是由字母组成的,所以也是Java的保留关键字.它的作用是测试它左边的对象是否是它右边的类的实例,返回boo ...
- LeetCode:N-Queens I II(n皇后问题)
N-Queens The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no tw ...
- Caliburn.Micro学习笔记(一)----引导类和命名匹配规则
Caliburn.Micro学习笔记目录 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详 ...
- MarkdownPad2 Pro v2.4.2.29969 专业中文破解版完美支持table表格语法
在网上搞了半天,终于搞定了支持table简写语法的markdown软件. 下载地址:http://download.csdn.net/detail/wang_jun_hua/8180717 下载包内含 ...
- JAVA的垃圾回收机制
1. 垃圾回收的意义 在C++中,对象所占的内存在程序结束运行之前一直被占用,在明确释放之前不能分配给其它对象:而在Java中,当没有对象引用指向原先分配给某个对象的内存时,该内存便成为垃圾.JVM的 ...
- c#编码转换
/// <summary> /// URL编码 /// </summary> /// <param name="Source"></par ...
- Oracle数据库的创建以及远程连接(PL/SQL Developer远程连接数据库)
dbca: 创建数据库 netca: 创建监听程序 netmgr: 配置监听服务(将数据库服务注册到监听器上) netca 与 netmgr 两步可以直接在 ORACLE_HOME/network/a ...
- OC中的@property详解
简介: @property 生成了变量的get set 方法,同时指定了变量名称. 例如@property (nonatomic,strong) NSString *name;表示生成了_name私有 ...
- Couchbase的安装步骤
本指南将在几分钟内让你上手,探索关联APP,在命令行shell 中删除一些实例查询,并尝试查询工作台. 下载Couchbase Server 下载地址:http://www.couchbase.com ...