首先抛开语言层面,简单介绍一下socket通信过程:

  1、服务器端开启监听端口,阻塞进程  等待客户端连接

  2、客户端连接,这时就产生了一个socket

      socket就相当于一个传递消息的通道,一般都是成对出现的;客户端一个socket   服务器端一个socket,并且是由对应关系的;

      Java中,socket有两个属性比较重要:getInputStream与getOutputStream   分别用于读取对方传来的消息和发送消息

  OK,下面结合代码,介绍socket如何实现通信的

  先看服务器端代码:

package test;
import java.io.*;
import java.net.*;
public class helloWorld {
public static void main(String[] args)
{
System.out.println("Hello Server!!"); try{
ServerSocket server=null;
try
{
server=new ServerSocket(4700);
//创建一个ServerSocket在端口4700监听客户请求
}
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 is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
//由Socket对象得到输入流,并构造相应的BufferedReader对象
PrintWriter os=new PrintWriter(socket.getOutputStream());
//由Socket对象得到输出流,并构造PrintWriter对象
BufferedReader sin=new BufferedReader(new InputStreamReader(System.in));
//由系统标准输入设备构造BufferedReader对象
System.out.println("Client:"+is.readLine());
//在标准输出上打印从客户端读入的字符串
line=sin.readLine();
//从标准输入读入一字符串
while(!line.equals("bye")){
//如果该字符串为 "bye",则停止循环
os.println(line);
//向客户端输出该字符串
os.flush();
//刷新输出流,使Client马上收到该字符串
System.out.println("Server:"+line);
//在系统标准输出上打印读入的字符串
System.out.println("Client:"+is.readLine());
//从Client读入一字符串,并打印到标准输出上
line=sin.readLine();
//从系统标准输入读入一字符串
} //继续循环
os.close(); //关闭Socket输出流
is.close(); //关闭Socket输入流
socket.close(); //关闭Socket
server.close(); //关闭ServerSocket
}
catch(Exception e)
{
System.out.println("Error." + e);
//出错,打印出错信息
}
} }

服务器端代码

  关键流程介绍:

  开启主机监听端口

ServerSocket server=null;
try
{
server=new ServerSocket(4700);
//创建一个ServerSocket在端口4700监听客户请求
}
catch(Exception e)
{
System.out.println("can not listen to:"+e);
//出错,打印出错信息
}

  阻塞线程,等待客户端连接,如果客户端连接,则会在服务器端产生一个socket 对象,通信会用到;

Socket socket=null;
try
{
socket=server.accept();
//使用accept()阻塞等待客户请求,有客户
//请求到来则产生一个Socket对象,并继续执行
}catch(Exception e)
{
System.out.println("Error." + e);
//出错,打印出错信息
}

  好,到此为止已经建立起通信通道,下面就说怎么发送与接收消息

  之前提到过socket有两个重要的属性getInputStream()  与getOutputStream(),本质上就是通过调用这两个属性的方法,来收发消息的;但是为了提高效率 需要将getInputStream()交给BufferedReader类处理  至于PrintWriter,向指定地方写入数据,暂时就是这么理解的。;不过,这样做有时候会出现一些问题,曾经做过一个接口,向服务器端发送消息,如果直接调用 InputStream 与 OutputStream方法,不会有任何问题,但是如果交由这些类去处理,就会有问题。原因大概是与服务器不匹配吧。

BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream())); //将socket.getInputStream() 交给BufferedReader处理
is.readLine()  // 这句话会从socket对象的输入流(即外部发送来的数据)读取数据,会阻塞线程

  下面这三句话句话,是用来向输出流中写入数据的

PrintWriter os=new PrintWriter(socket.getOutputStream());
os.println(readline);  //将数据写入缓冲区
os.flush(); //强制将缓冲区中的数据输出(一般的话都是缓冲区满了之后 才输出)

  执行完这三句话后,就像对方发送数据了。

  OK,就先写到这儿了!

  下面将客户端代码贴上

  

package testSocketClient;
import java.net.*;
import java.io.*;
public class client
{
public static void main(String[] args)
{
System.out.println("Hello Client!!"); try
{
Socket socket=new Socket("127.0.0.1",4700);
BufferedReader sin = new BufferedReader(new InputStreamReader(System.in));
PrintWriter os=new PrintWriter(socket.getOutputStream());
BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
String readline;
readline=sin.readLine(); //从系统标准输入读入一字符串
readline = "nihao,good bye";
while(!readline.equals("bye"))
{
os.println(readline);
os.flush();
System.out.println("Client:"+readline);
System.out.println("Server:"+is.readLine());
readline=sin.readLine();
}
os.close(); //关闭Socket输出流
is.close(); //关闭Socket输入流
socket.close(); //关闭Socket
}
catch(Exception e)
{
System.out.println("错误信息:" + e);
}
} }

Java socket通信的更多相关文章

  1. java socket通信-传输文件图片--传输图片

    ClientTcpSend.java   client发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io ...

  2. java Socket通信使用BufferedReader和BufferedWriter的注意事项

    注意事项:readLine()要求有换行标识,write()要输出换行标识,要调用flush()刷新缓冲区. 以下是取自java socket通信中的一小段代码. BufferedReader rea ...

  3. Java Socket通信读取相关信息代码

    转自:http://developer.51cto.com/art/201003/190206.htm Java Socket通信读取有不少需要我们注意的知识点.当我们在使用的时候有很多的问题摆在我们 ...

  4. Java Socket通信以及可能出现的问题解决

    Java中基于TCP协议实现网络通信的两个类:客户端的Socket和服务器端的ServerSocket. Socket通信模型如图所示: 不管Socket通信的功能有多复杂,任何socket通信过程的 ...

  5. Java Socket通信实现私聊、群聊

    前言 闲言少叙,上代码! 代码编写 server服务端 /** * 服务端 */ public class Server { private static ServerSocket server = ...

  6. Java Socket 通信实例 - 转载

    基于Tcp协议的简单Socket通信实例(JAVA)   好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些 ...

  7. Java Socket通信实例

    一.简单的客户端与服务器一对一连接: Socket通信的步骤: 1.创建ServerSocket和Socket 2.打开连接到Scket的输入/输出流 3.按照协议对Socket进行读/写操作 4.关 ...

  8. 【Java】Java Socket 通信演示样例

    用socket(套接字)实现client与服务端的通信. 这里举两个样例: 第一种是每次client发送一个数据,服务端就做一个应答. (也就是要轮流发) 另外一种是client能够连续的向服务端发数 ...

  9. java Socket通信,客户端与服务端相互发消息

    1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...

随机推荐

  1. hibernate在配置文件中配置对象关系映射文件即hbm文件路径的写法

    hbm文件如果在src下,则<mapping resource="*.hbm.xml"/> 如果在实体类包中,则<mapping resource="c ...

  2. Hibernate中自带ID的generator的含义

    increment:代理主键,适合于所有数据库,由hibernate维护主键自增,和底层数据库无关,但是不适合于2个或以上hibernate进程. identity:代理主键,适合于Mysql或ms ...

  3. POJ 2418 Hardwood Species (哈希,%f 和 %lf)

    我的错因: 本来改用%f输出,我用了%lf,结果编译器直接判定为错误(一部分编译器认为lf是没有错的).当时我还以为是hash出错了.. 方法不止一种: 方法 时间   空间 Hash 891ms 5 ...

  4. VMware+Windbg双机调试

    虚拟机使用XP系统:

  5. 常用的css

    产品鼠标经过加边框效果 .productsCol:hover { box-shadow: 0 0 0 3px #333333 inset; transition: all 0.2s ease 0s; ...

  6. Chapter 1 First Sight——28

    "Which one is the boy with the reddish brown hair?" 那个红褐色头发的男孩是谁? I asked. I peeked at him ...

  7. C++ 中 const和define的区别

    来源网址:http://wujiangping.blog.163.com/blog/static/195182011201255115125205/ 请区别用#define命令定义的符号常量和用con ...

  8. Entity Framework教程

    随着Code First一起出现的DbContext和DbSet类绝对可以称得上EF的功能核心,其取代了之前的ObjectContext和ObjectSet类,提供了与数据库通信,管理内存中实体的重要 ...

  9. LeetCode OJ 202. Happy Number

    Write an algorithm to determine if a number is "happy". A happy number is a number defined ...

  10. python--lambda和def函数

    1.Python lambda和Python def区别分析 Python支持一种有趣的语法,它允许你快速定义单行的最小函数.这些叫做lambda的函数,是从Lisp借用来的,可以用在任何需要函数的地 ...