一、TCP:用字符流传输信息

------------------------------------------------------------------------------

[用字符流的要点提示]

1:

将套接字关闭之后,字符流自然也就关闭了,所以只需要socket.shutdownOutput();/socket.shutdownInput();

应为套接字开启的字节流封装在字符流Buffered里面,若果先关闭字符流bw.close(),将会关闭套接字。 抛出java.net.SocketException: Socket is closed异常,说明已经将套接字关闭。

2:必须要写入换行符bw.newLine();(或者在内容末尾加\n),这样在用BufferedReader的readerLine() 接收数据包的时候才能读取到一个换行信息,否则会出现读取错误。

------------------------------------------------------------------------------

public class Tcpc { // 客户端

 

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

//1.创建套接字指定主机和端口

Socket socket = new Socket(InetAddress.getLocalHost(),8808);

//2打开输入输出流

InputStream is = socket.getInputStream();

OutputStream os = socket.getOutputStream();

//准备要撒送的数据

String send = "我是客户端,请求登录!";

BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(os));

bw.write(send);

bw.newLine();

bw.flush();

socket.shutdownOutput();

 

//4.准备接受返回的信息,并用行读取

BufferedReader br = new BufferedReader(new InputStreamReader(is));

String lin =br.readLine();

System.out.println("客户端开始接受信息!");

while(lin!=null){

System.out.println(lin);

lin=br.readLine();

}

//5关闭资源

socket.shutdownInput();

 

}

}

-------------------------------------------------------------------------

public class Tcps { // 服务端

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

//1创建套接字,到指定的端口接受信息

ServerSocket serversocket = new ServerSocket(8808);

//2监听客户端的消息

Socket socket = serversocket.accept();

//3.打开输入输出的流

InputStream is = socket.getInputStream();

OutputStream os = socket.getOutputStream();

//4封装一个行读取的流

BufferedReader br = new BufferedReader(new InputStreamReader(is));

String lin = br.readLine();

while(lin!=null){

System.out.println(lin);

lin = br.readLine();

}

socket.shutdownInput();

//5给客户端一反馈

String replay="我是服务端,允许登录!";

BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(os));

bw.write(replay);

bw.newLine();

bw.flush();

 

//6关闭资源

 

socket.shutdownOutput();

 

}

}

------------------------------------------------------------------------------

 

 

二、TCP字节流传输信息

 

TCP:字节流传输信息

-------------------------------------------------------------------------------------

public class Tcpc { //客户端

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

//1.创建套接字指定主机和端口

Socket socket = new Socket(InetAddress.getLocalHost(),8808);

//2打开输入输出流

InputStream is = socket.getInputStream();

OutputStream os = socket.getOutputStream();

//准备要撒送的数据

String send = "我是客户端,请求登录!";

os.write(send.getBytes());

socket.shutdownOutput();

 

//4.准备接受返回的信息,并用行读取

System.out.println("客户端接受完毕!");

byte[] by = new byte[1024];

is.read(by);

System.out.println(new String(by,0,by.length));

//5关闭资源

socket.shutdownInput();

 

}

}

 

-------------------------------------------------------------------------------------

public class Tcps { //服务端

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

//1创建套接字,到指定的端口接受信息

ServerSocket serversocket = new ServerSocket(8808);

//2监听客户端的消息

Socket socket = serversocket.accept();

//3.打开输入输出的流

InputStream is = socket.getInputStream();

OutputStream os = socket.getOutputStream();

//4封装一个行读取的流

 

System.out.println("服务端接收完毕!");

byte[] by = new byte[1024];

is.read(by);

System.out.println(new String(by,0,by.length));

socket.shutdownInput();

//5给客户端一反馈

String replay="我是服务端,允许登录!";

 

System.out.println("服务端反馈完毕!");

os.write(replay.getBytes());

//6关闭资源

 

socket.shutdownOutput();

 

}

}

 

网络编程—代码—TCP网络传输的更多相关文章

  1. 【Linux网络编程】TCP网络编程中connect()、listen()和accept()三者之间的关系

    [Linux网络编程]TCP网络编程中connect().listen()和accept()三者之间的关系 基于 TCP 的网络编程开发分为服务器端和客户端两部分,常见的核心步骤和流程如下: conn ...

  2. UNIX网络编程——解决TCP网络传输“粘包”问题

    当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socket应用开发编程接口(API).TCP/IP传输层有两个并列的协议:TCP和UDP.其中TCP(transport contro ...

  3. 【Linux 网络编程】TCP网络编程中connect()、listen()和accept()三者之间的关系

    基于 TCP 的网络编程开发分为服务器端和客户端两部分,常见的核心步骤和流程如下: connect()函数:对于客户端的 connect() 函数,该函数的功能为客户端主动连接服务器,建立连接是通过三 ...

  4. 【网络编程】TCP网络编程

    TCP网络程序设计 一.模型函数化 图片:TCP编程模型 1.1 创建套接字Socket #include <sys/types.h> /* See NOTES */ #include & ...

  5. java网络编程基础——TCP网络编程一

    基于TCP协议的网络编程 TCP/IP协议是一种可靠的网络协议,它的通信的两端各自建立一个Socket,从而在通信的两端之间形成网络虚拟链路. Java使用Socket对象来代表两端的通信端口,并通过 ...

  6. 网络编程—代码—UDP数据报传输

    UDP:数据报传输 1.接收端 public class Udps { //接收端 public static void main(String[] args) throws IOException ...

  7. java网络编程基础——TCP网络编程二

    1.半关闭的Socket 前面的服务器和客户端通信时总是以行为最小数据单位,但是在某些协议里,通信的数据单位可能是多行的,当出现多行数据时就 出现一个问题:Socket输出流如何表示输出数据已经结束. ...

  8. java网络编程基础——TCP网络编程三

    AIO实现非阻塞通信 java7 NIO2 提供了异步Channel支持,这种异步Channel可以提供更高效的IO,这种基于异步Channel的IO被称为异步IO(Asynchronous IO) ...

  9. C#网络编程之---TCP协议的同步通信(二)

    上一篇学习日记C#网络编程之--TCP协议(一)中以服务端接受客户端的请求连接结尾既然服务端已经与客户端建立了连接,那么沟通通道已经打通,载满数据的小火车就可以彼此传送和接收了.现在让我们来看看数据的 ...

随机推荐

  1. [转]F5负载均衡名词LTM和GTM

    LTM就是本地流量管理,也就是通常所说的服务器负载均衡.可以将多个提供相同服务的设备(pool)虚拟成一个逻辑设备,供用户访问.也就是说,对于用 户来讲,看到的只有一个设备,而实际上用户是服务请求是在 ...

  2. mint下截图工具shutter的安装和使用设置

    [原创作品,技术交流.允许转载,转载时请务必以超链接形式标明文章原始出处 .作者信息.如有错误,请指正] /** author: lihaibo date: 1/25/2016 */ 今天安装了双系统 ...

  3. iOS 循环引用 委托 (实例说明)

    如何避免循环引用造成的内存泄漏呢: 以delegate模式为例(viewcontroller和view之间就是代理模式,viewcontroller有view的使用权,viewcontroller同时 ...

  4. Edge Animate使用SPRITESHEET创建动画(三)

    在Flash动画制作中,使用SpriteSheet制作动画元素是一个常见和普遍的方法.在Edge Animate中,我们也可以利用SpriteSheet来制作HTML5动画.本文将从一个示例出发,介绍 ...

  5. HTML表格的运用

    表格是用<table>标签定义的,表格被划分为行(使用<标签>),html 难度比C语言,JAVA,Oracle容易,但是要会灵活运用并把命令记住,不断测试一些结果 ,编程还是 ...

  6. poj3417Network【LCA】【树形DP】

    Yixght is a manager of the company called SzqNetwork(SN). Now she's very worried because she has jus ...

  7. Numpy基础学习与总结

    Numpy类型学习 1.数组的表示 import numpy as np In [2]: #numpy核心是高维数组,库中的ndarray支持多维数组,同时提供了数值运算,可对向量矩阵进行运算 In ...

  8. HDU 4352 - XHXJ's LIS - [数位DP][LIS问题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4352 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...

  9. 插入排序之python

    插入排序( Insert sort) 通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入: 由于不需要全部都比较完,所以排序速度优于冒泡和选择排序. #插入排序就像是斗地 ...

  10. Redis used_cpu_sys used_cpu_user meaning (redis info中cpu信息的含义)

    Redis 中 used_cpu_sys 和 used_cpu_user含义. 在Redis的info命令输出结果中有如下四个指标,redis官网给出了下面一段解释,但是还是不明白什么意思. used ...