Java基础---Java---网络编程---TCP的传输、客户端和服务端的互访、建立一个文本转换器、编写一个聊天程序
演示TCP的传输的客户端和服务端的互访
需求:客户端给服务端发送数据,服务端收到后,给客户端反馈信息。
客户端:
1.建立Socket服务,指定要连接方朵和端口
2.获取Socket流中的输出流,将数据写到该流中,通过网络发送给服务端。
3.获取socket流中的输入流,将服务端反映的数据获取到,找打印。
4.关闭客户端。
客户端:
class TcpClient2{ public static void main(String[] args) throws Exception{ Socket a=new Socket("172.16.196.12",10004); OutputStream out=s.getOutputStream(); out.write("服务端你好".getBytes()); InputStream in=s.getInputStream(); byte[] buf=new byte[1024]; int len=in.read(buf);//只有等待服务端发送数据,才能进行开始读 System.out.println(new String(buf,0,len)); s.close(); } }
</pre><strong><span style="color:rgb(255,0,0); font-size:18px">服务端:</span></strong><pre code_snippet_id="272018" snippet_file_name="blog_20140403_2_3221842" name="code" class="html">class TcpServer2{ public static void main(String[] args){ //不要觉得代码差不多,是两个独立的程序 ServerSocket ss=new ServerSocket(10004);//监听10004端口 Socket s=ss.accept(); String ip=s.getInetAddress().getHostAddress();//拿到客户端的地址 System.out.println(ip+"...is connect"); InputStrean in=s.getInputStream(); byte [] buf=new byte[1024]; int len=in.read(buf); System.out.println(new String(buf,0,len)); OutputStream out=s.getOutputStream(); out.write("哥们收到".getBytes()); s.close(); ss.close(); } }
需求:建立一个文本转换器
客户端给服务端发送文本,服务端会将文本转成大写返回给客户端。
而且客户端可以不断的进行文本转换,当客户端输入over时,转换结束
既然是操作设备上的数据,那么就可以使用IO技术,并按照IO的操作规律来思考,
源:键盘录入
目的:网络设备,网络输出流。
而且操作的基本文档,可以选择字符流。
步骤:
1.建立服务。
2.获取键盘录入。
3.将数据发给服务端。
4.取服务端返回的大写数据。
5.结束,关闭资源。
都是文本数据,可以使用字符流进行操作,同时提高效率,加入缓冲
class TransClient{ public static void main(String [] args){ Socket s=new Socket("172.16.196.12",10005); //定义读取键盘数据的流对象 BufferedReader bufr=new BufferedReader(new InputStreamReader(System.in)); //定义目的:将数据写入到socket输出流,发给服务端。 BufferedWriter bufw=new BufferedWriter(new OutputStreamWriter(s.getOutputStream())); //这是用到转换流,OutputStreamWriter. //定义一个socket读取流。读取服务端返回的大写信息。 BufferedReader bufIn=new BufferedReader(new InputStreamReader(e.getInputStream())); String line=null; while((line=bufr.readLine())!null){ if("over".equals(line)) break; bufOut.write(line+"\r\n");//这个地方要加换行。不然服务端没法找到什么时候结束。 bufOut.flush(); String str=bufIn.readLine(); System.out.println("server"+str); } butr.close(); s.close(); } }
服务端:
源:Socket读取流
目的:socket输出流
都是文本
class TransServer{ public static void main(String[] args)throws Exception{ ServerSocket ss=new ServerSocket(10005); Socket s=ss.accept(); String ip=s.getInetAddress().getHostAddress(); System.out.println(ip+"....is connected"); //读取socket读取流中的数据 BufferedReader bufIn=new BufferedReader(new InputStreamReader(e.getInputStream())); //目的。socket输出流,将大写数据写入到socket输出流,并发送给客户端 BufferedWriter bufOut=new BufferedWriter(new OutputStreamWriter(s.getOutputStream()); String line=null; while((line=bufIn.readLine())!null){//判断的是回车标识 //当关闭服务端时,客户端也相应结束。 System.out.println(line); bufOut.write(line.toUpperCase()); bufOut.newLine(); bufOut.flush(); } s.close(); ss.close(); } }
//该例子出现的问题
现象:客户端和服务端都在莫名的等待。
为什么?以后就查阻塞式方式
因为客户端和服务端都有阻塞式方法。这些方法没有读到结束标识。那么就一直等待而导致两端。都在等待。
编写一个聊天程序。
有收数据的部分,和发数据的部分。
这两部分需要同时执行。
那就需要用到多线程技术。
一个线程控制收,一个线程控制发。
因为收和发动作是不一致的,所以要定义两个run方法。
而且这两个方法要封装到不同的类中。
发送:
import java.io.*; import java.net.*; class Send implements Runnable { private DatagramSocket ds; public Send(DatagramSocket ds) { this.ds = ds; } public void run() { try { BufferedReader bufr = new BufferedReader(new InputStreamReader(System.in)); String line = null; while((line=bufr.readLine())!=null) { byte[] buf = line.getBytes(); DatagramPacket dp = new DatagramPacket(buf,buf.length,InetAddress.getByName("172.16.196.12"),10002); ds.send(dp); if("886".equals(line)) break; } } catch (Exception e) { throw new RuntimeException("发送端失败"); } } }
接收:
class Rece implements Runnable { private DatagramSocket ds; public Rece(DatagramSocket ds) { this.ds = ds; } public void run() { try { while(true) { byte[] buf = new byte[1024]; DatagramPacket dp = new DatagramPacket(buf,buf.length); ds.receive(dp); String ip = dp.getAddress().getHostAddress(); String data = new String(dp.getData(),0,dp.getLength()); if("886".equals(data)) { System.out.println(ip+"....离开聊天室"); break; } System.out.println(ip+":"+data); } } catch (Exception e) { throw new RuntimeException("接收端失败"); } } }
主函数,是用来调用的
class ChatDemo { public static void main(String[] args) throws Exception { DatagramSocket sendSocket = new DatagramSocket(); DatagramSocket receSocket = new DatagramSocket(10002); new Thread(new Send(sendSocket)).start(); new Thread(new Rece(receSocket)).start(); } }
Java基础---Java---网络编程---TCP的传输、客户端和服务端的互访、建立一个文本转换器、编写一个聊天程序的更多相关文章
- java基础篇---网络编程(TCP程序设计)
TCP程序设计 在Java中使用Socket(即套接字)完成TCP程序的开发,使用此类可以方便的建立可靠地,双向的,持续的,点对点的通讯连接. 在Socket的程序开发中,服务器端使用serverSo ...
- 网络编程_TCP协议_客户端与服务端
客户端发数据到服务端 Tcp传输,客户端建立的过程. 1,创建tcp客户端socket服务.使用的是Socket对象.建议该对象一创建就明确目的地.要连接的主机. 2,如果连接建立成功,说明数据传输通 ...
- java基础:网络编程TCP,URL
获取域名的两种方法: package com.lanqiao.java.test; import java.net.InetAddress;import java.net.UnknownHostExc ...
- 黑马程序员:Java基础总结----网络编程
黑马程序员:Java基础总结 网络编程 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 网络编程 网络通讯要素 . IP地址 . 网络中设备的标识 . 不易记忆,可用 ...
- 黑马程序员——JAVA基础之网络编程
------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 网络编程 网络模型:OSI参考模型和TCP/IP参考模型 网络通讯三要素: IP地址:InetA ...
- Java实现TCP之Echo客户端和服务端
Java实现TCP之Echo客户端和服务端 代码内容 采用TCP协议编写服务器端代码(端口任意) 编写客户机的代码访问该端口 客户机按行输入 服务器将收到的字符流和接收到的时间输出在服务器consol ...
- java 从零开始手写 RPC (03) 如何实现客户端调用服务端?
说明 java 从零开始手写 RPC (01) 基于 socket 实现 java 从零开始手写 RPC (02)-netty4 实现客户端和服务端 写完了客户端和服务端,那么如何实现客户端和服务端的 ...
- Java基础---Java---网络编程---TCP、UDP、UDP-键盘录入方式数据、Socket、TCP复制文件、UDP-聊天
网络编程 网络模型 *OSI参考模型 *Tcp/IP参考模型 网络通读要素 *IP地址 *端口号 *传输协议 1.找到对方Ip 2.数据要发送到对方指定的的应用程序上,为了标识这些应用程序,所经给这些 ...
- 【Java基础】网络编程
网络编程 网络编程概述 网络编程的目的:直接或简洁地通过网络协议与其他计算机实现数据交换,进行通讯. 网络编程的两个主要问题: 如果准确地定位网络上一台或多台主机,并定位主机上的特定应用: 找到主机后 ...
随机推荐
- ●UVa 1589 Xiangqi(模拟)
●赘述题意 给出一个中国象棋残局,告诉各个棋子的位置,黑方只有1枚“将”,红方有至少2枚,至多7枚棋子,包含1枚“帅G”,和若干枚“车R”,“马H”,“炮C”.当前为黑方的回合,问黑方的“将”能否在移 ...
- ●BZOJ 3172 [Tjoi2013]单词
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3172 题解: 把单词逐个接起来,中间用互不相同的字符连接,并记录下每个单词的首字母在串中的位 ...
- hdu 5391 (数论)
Zball in Tina Town Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Oth ...
- SpringMVC 处理映射
一.Spring MVC控制器名称处理映射 以下示例展示如何利用Spring MVC 框架使用控制器名称处理程序映射. ControllerClassNameHandlerMapping类是基于约定的 ...
- 选取id不为sth的div元素
选取id不为sth的div元素$("div:not(#sth)")
- 值得珍藏的HTTP协议详解
转自:http://www.cnblogs.com/li0803/archive/2008/11/03/1324746.html 引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式 ...
- django模板语言中的extends,block和include
extends和block一起用 它们用于母版和子版的继承 在母版html中将一些需要替换的部分用{% block xxx %}...{% endblock %}括起来, 在子版html中,在第一行需 ...
- Connection Reset By Peer 解析
linux网络编程 Connection reset by peer错误服务器向客户端发送了数据,客户端没有接收就关闭了,服务器read就会发生Connection reset by peer错误.我 ...
- Swift Review总结:从 Swift Style 开始
每个语言都有自己的推荐风格.显然OC与Swift有着不同的风格.当我们开始写Swift,首先要注意的就是按照Swift的风格写,而不是沿用OC的风格. 省略句末的分号 swift推崇简洁的语法.如果一 ...
- 网络爬虫框架Scrapy简介
作者: 黄进(QQ:7149101) 一. 网络爬虫 网络爬虫(又被称为网页蜘蛛,网络机器人),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本:它是一个自动提取网页的程序,它为搜索引擎从万维 ...