java socket报文通信(一) socket的建立
TCP是Transfer Control Protocol的 简称,是一种面向连接的保证可靠传输的协议。通过TCP协议传输,得到的是一个顺序的无差错的数据流。发送方和接收方的成对的两个socket之间必须建 立连接,以便在TCP协议的基础上进行通信,当一个socket(通常都是server socket)等待建立连接时,另一个socket可以要求进行连接,一旦这两个socket连接起来,它们就可以进行双向数据传输,双方都可以进行发送 或接收操作。
UDP是User Datagram Protocol的简称,是一种无连接的协议,每个数据报都是一个独立的信息,包括完整的源地址或目的地址,它在网络上以任何可能的路径传往目的地,因此能否到达目的地,到达目的地的时间以及内容的正确性都是不能被保证的。
(一)两者之间的比较
UDP:
- 每个数据报中都给出了完整的地址信息,因此无需要建立发送方和接收方的连接。
- UDP传输数据时有大小限制的,每个被传输的数据报必须限定在64KB之内。
- UDP是一个不可靠的协议,发送方所发送的数据报并不一定以相同的次序到达接收方。
TCP:
- 面向连接的协议,在socket之间进行数据传输之前必然要建立连接,所以在TCP中需要连接时间。
- TCP传输数据大小限制,一旦连接建立起来,双方的socket就可以按统一的格式传输大的 数据。
- TCP是一个可靠的协议,它确保接收方完全正确地获取发送方所发送的全部数据。
(二)应用
- TCP在网络通信上有极强的生命力,例如远程连接(Telnet)和文件传输(FTP)都需要不定长度的数据被可靠地传输。但是可靠的传输是要付出代价的,对数据内容正确性的检验必然占用计算机的处理时间和网络的带宽,因此TCP传输的效率不如UDP高。
- UDP操作简单,而且仅需要较少的监护,因此通常用于局域网高可靠性的分散系统中client/server应用程序。例如视频会议系统,并不要求音频视频数据绝对的正确,只要保证连贯性就可以了,这种情况下显然使用UDP会更合理一些。
注:以上内容是在网上找的,为了节省时间,我就不再自己写了。
下面我们来看看如何搭建socket环境:
socket通信分为客户端和服务器端。服务器端会不停的监听,当服务器端监听到有客户端向其发送通信请求的时候,双方建立连接。通信完毕后,双方关闭连接。
首先我们来看如何搭建客户端:
 public class SocketClient {
     public static void main(String[] args) throws IOException{
     try{
             Socket socket=new Socket("127.0.0.1",);
             System.out.println("client start ...");
             //向本机的52000端口发出客户请求
             BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
             //由系统标准输入设备构造BufferedReader对象
             PrintWriter write=new PrintWriter(socket.getOutputStream());
             //由Socket对象得到输出流,并构造PrintWriter对象
             BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));
             //由Socket对象得到输入流,并构造相应的BufferedReader对象
             String readline;
             readline=br.readLine(); //从系统标准输入读入一字符串
             while(!readline.equals("end")){
                 //若从标准输入读入的字符串为 "end"则停止循环
                 write.println(readline);
                 //将从系统标准输入读入的字符串输出到Server
                 write.flush();
                 //刷新输出流,使Server马上收到该字符串
                 System.out.println("Client:"+readline);
                 //在系统标准输出上打印读入的字符串
                 System.out.println("Server:"+in.readLine());
                 //从Server读入一字符串,并打印到标准输出上
                 readline=br.readLine(); //从系统标准输入读入一字符串
             } //继续循环
             write.close(); //关闭Socket输出流
             in.close(); //关闭Socket输入流
             socket.close(); //关闭Socket
         }catch(Exception e) {
             System.out.println("can not listen to:"+e);//出错,打印出错信息
         }
     }
 }
下面是服务器端得搭建:
 public class SocketService {
     public static void main(String[] args) throws IOException{
         SocketService socketService = new SocketService();
         socketService.oneServer();
     }
     public  void oneServer(){
         try{
             ServerSocket server=null;
             try{
                 server=new ServerSocket();
                 System.out.println("server start is ok...");
                 //创建一个ServerSocket在端口5200监听客户请求
             }catch(Exception e) {
                     System.out.println("can not listen to:"+e);
                     //出错,打印出错信息
             }
             Socket socket=null;
             try{
                 socket=server.accept();
                 //使用accept()阻塞等待客户请求,有客户
                 //请求到来则产生一个Socket对象,并继续执行
             }catch(Exception e) {
                 System.out.println("Error."+e);
                 //出错,打印出错信息
             }
             String line;
             BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));
             //由Socket对象得到输入流,并构造相应的BufferedReader对象
             PrintWriter writer=new PrintWriter(socket.getOutputStream());
             //由Socket对象得到输出流,并构造PrintWriter对象
             BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
             //由系统标准输入设备构造BufferedReader对象
             System.out.println("Client:"+in.readLine());
             //在标准输出上打印从客户端读入的字符串
             line=br.readLine();
             //从标准输入读入一字符串
             while(!line.equals("end")){
             //如果该字符串为 "bye",则停止循环
                 writer.println(line);
                 //向客户端输出该字符串
                 writer.flush();
                 //刷新输出流,使Client马上收到该字符串
                 System.out.println("Server:"+line);
                 //在系统标准输出上打印读入的字符串
                 System.out.println("Client:"+in.readLine());
                 //从Client读入一字符串,并打印到标准输出上
                 line=br.readLine();
                 //从系统标准输入读入一字符串
             } //继续循环
             writer.close(); //关闭Socket输出流
             in.close(); //关闭Socket输入流
             socket.close(); //关闭Socket
             server.close(); //关闭ServerSocket
         }catch(Exception e) {//出错,打印出错信息
             System.out.println("Error."+e);
         }
     }
 }
这是我们先启动服务器端,再启动客户端(顺序不能乱),当我在客户端输入abc时,如下:

我们再打开服务器端得控制台,会看到客户端发送的消息:

然后我们再输入123:

我们再打开客户端得控制台:

这里显示了服务端回传的信息,证明我们的通信是没有问题的了。
以上的服务端只能监听一个客户端,要想是想监听多个客户端,我们对服务端做一下修改:
 public  void manyServer() throws IOException{
      boolean flag = true;
       ServerSocket serverSocket = null;
       serverSocket = new ServerSocket();
       int clientNum = ;
       while(flag){
           new SocketServerTherd(serverSocket.accept(), clientNum).start();
           clientNum++;
       }
       serverSocket.close();
     }
 public class SocketServerTherd extends Thread{
     Socket socket = null;
     int clientNum = ;
      public SocketServerTherd(Socket socket,int num){
          this.socket = socket;
          this.clientNum = num+;
      }
      public void run(){
          try{
              String line;
              BufferedReader in=new BufferedReader(new InputStreamReader(socket.getInputStream()));
              //由Socket对象得到输入流,并构造相应的BufferedReader对象
              PrintWriter writer=new PrintWriter(socket.getOutputStream());
              //由Socket对象得到输出流,并构造PrintWriter对象
              BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
              //由系统标准输入设备构造BufferedReader对象
              System.out.println("Client:"+in.readLine());
              //在标准输出上打印从客户端读入的字符串
              line=br.readLine();
              //从标准输入读入一字符串
              while(!line.equals("end")){
              //如果该字符串为 "bye",则停止循环
                  writer.println(line);
                  //向客户端输出该字符串
                  writer.flush();
                  //刷新输出流,使Client马上收到该字符串
                  System.out.println("Server:"+line);
                  //在系统标准输出上打印读入的字符串
                  System.out.println("Client:"+in.readLine());
                  //从Client读入一字符串,并打印到标准输出上
                  line=br.readLine();
                  //从系统标准输入读入一字符串
              } //继续循环
              writer.close(); //关闭Socket输出流
              in.close(); //关闭Socket输入流
              socket.close(); //关闭Socket
          }catch(Exception e) {//出错,打印出错信息
              System.out.println("Error."+e);
          }
      }
 }
java socket报文通信(一) socket的建立的更多相关文章
- java socket报文通信(一)socket的建立
		java socket报文通信(一) socket的建立 今天来和大家分享一下java中如何使用socket进行通信.先来啰嗦两句,看看Tcp/ip和udp: TCP是Transfer Contro ... 
- java socket报文通信(三)java对象和xml格式文件的相互转换
		前两节讲了socket服务端,客户端的建立以及报文的封装.今天就来讲一下java对象和xml格式文件的相互转换. 上一节中我们列举了一个报文格式,其实我们可以理解为其实就是一个字符串.但是我们不可能每 ... 
- java socket报文通信(二)报文的封装
		昨天我们谈了怎么建立socket通信的服务端和客户端,今天我们就来谈一谈怎么封装报文. 什么是报文这里我就不在阐述了,不清楚的朋友可以自己去查资料.我们今天要谈的报文主要友以下几个部分组成: 3位同步 ... 
- 使用Socket进行通信
		客户端通常可使用Socket的构造器来连接到指定服务器,Socket通常可使用如下两个构造器. Socket(lnetAddress/String remoteAddress , int port ... 
- Java Socket编程----通信是这样炼成的
		Java最初是作为网络编程语言出现的,其对网络提供了高度的支持,使得客户端和服务器的沟通变成了现实,而在网络编程中,使用最多的就是Socket.像大家熟悉的QQ.MSN都使用了Socket相关的技术. ... 
- Java Socket应用---通信是这样练成的
		网络基础简介 Java 中网络相关 API 的应用 Java 中的 InetAddress 的应用 Test01.java package com.imooc; import java.n ... 
- Java与C之间的socket通信
		最近正在开发一个基于指纹的音乐检索应用,算法部分已经完成,所以尝试做一个Android App.Android与服务器通信通常采用HTTP通信方式和Socket通信方式.由于对web服务器编程了解较少 ... 
- java 的底层通信--Socket
		以前一直不太重视java 基础的整理,感觉在实际开发中好像java 基础用处不大,感觉不理解一些底层的东西对开发工作影响也不大.不过,后来我发现,很多东西都是相互联系的,如果底层的东西你不理解,后面的 ... 
- java socket线程通信
		关于socket线程通信的一些知识整理 一般我们需要要让两台机子进行通信,需要创建一个Server 类,一个Client类,还需要创建一个线程类 server public class Server ... 
随机推荐
- java反射机制 struts2 获取 action、method、invocation、proxy
			ActionInvocation invocation = ActionContext.getContext().getActionInvocation(); Object action = invo ... 
- 各种乱码,编码问题设置方法整理(UTF-8)
			一.tomcat中文乱码问题 打开tomcat安装目录,在conf文件夹中找到server.xml文件 ,找到 <Connector port="8009" protoc ... 
- PL/SQL客户端安装配置说明
			一.电脑安装了多个Oracle客户端时,需要设定pl/sql 中的home 二.配置环境变量: (打开环境变量配置界面操作:我的电脑---属性---高级---环境变量,在系统变量部分新建或编辑即可.w ... 
- iOS9之后对于NSURL的编码转换方法变化说明
			在iOS9之后,官方推荐使用下面的方法对NSString进行转换 - (nullable NSString *)stringByAddingPercentEncodingWithAllowedChar ... 
- Knockoutjs官网翻译系列(二) Observable 数组
			承接前文,前文书说道了KO框架中如何使用observable的视图模型属性来与UI元素进行绑定并自动进行双向更新的事儿.observable属性除了服务基础数据类型之外,还定义了专门为服务数组类型的o ... 
- VS2010 C++ 优化配置
			个人感觉VC6.0太土了,而且有很多bug存在,且微软早就不对其更新.所以,在选择C++编程的时候.使用IDE,VC6.0一段时间以后,我毅然决然的放弃了,觉得还是使用VS2010比较有前途. 但是当 ... 
- Oracle数据库之数据类型
			Oracle数据库之数据类型 Oracle基本数据类型(亦叫内置数据类型,internal datatypes或built-in datatypes)可以按类型分为:字符串类型.数字类型.日期类型.L ... 
- 1.3.1 switch 语句中的 String
			switch语句是一种高效的多路语句,可以省掉很多繁杂的嵌套if判断: 在Java 6及之前,case语句中的常量只能是byte.char.short和int(也可以是对应的封装类)或枚举常量,在Ja ... 
- 《Javascript模式》之对象创建模式读书笔记
			引言: 在javascript中创建对象是很容易的,可以使用对象字面量或者构造函数或者object.creat.在接下来的介绍中,我们将越过这些方法去寻求一些其他的对象创建模式. 我们知道js是一种简 ... 
- Centos+nginx+uwsgi+Python多站点环境搭建
			前言 新公司的第一个项目,服务器端打算用python作为restful api.所以需要在Centos上搭建nginx+fastcgi+python的开发环境,但后面网上很多言论都说uwsgi比fas ... 
