Socket

一.网络编程

网络模型:

OSI参考模型:应用层、表示层、会话层、传输层、网络层、链路层、物理层

TCP/IP参考模型:

应用层:FTPHTTP

传输层:UDP协议和TCP协议

网际层:

主机至网络层

 

二.网络通讯要素

a)     IP地址:网络设备标识

类:InetAddress

 

InetAddress I = InetAdress.getLocalHost();

//结果是主机名和IP地址

System.out.println(i.toString);

//结果是IP地址

System.out.println(“address:”+i.getHostAddress());

//结果是主机名

System.out.println(“name:”+i.getHostName());

 

InetAddress ia = InetAddress.getByName(“www.baidu.com”);

System.out.println(“address:”+ia.getHostAddress());

System.out.println(“name:”+ia.getHostName());

 

 

b)     端口号:有效端口:0~65535,其中0~1024系统使用或保留端口

c)     传输协议:

通讯的规则

常见协议:TCPUDP

UDP     将数据及源和目的封闭成数据包中,不需要建立连接

              每个数据报的大小在限制在64k

              因无连接,是不可靠协议

              不需要建立连接,速度快

1.面向无连接,2. 数据会被封包,有限制64k内,3.不可靠。4. 速度快

 

TCP      建立连接,形成传输数据的通道。

              在连接中进行大数据量传输

              通过三次握手完成连接,是可靠协议

              必须建立连接,效率会稍低

             

.   Socket

       为网络服务提供的一种机制,通信的两端都有Socket,网络通信其实就是Socket间的通信。数据在两个Socket间通过IO传输。

       UDP传输

       DatagramSocket (此类表示用来发送和接收数据报包的套接字)

       receive(DatagramPacketp):接收

       send(DatagramPacketp):发送

       DatagramPacket(此类表示数据报包)

      

       实例:

需求:通过UDP传输方式,将一段文字数据发送出去

1.    建立udpscoket服务。

2.    提供数据,并将数据封闭到DatagramPacket

3.    通过socket服务的发送功能,将数据包发出支。

4.    关于资源

 

DatagramSocketds = new DatagramSocket();

byte[]buf = “udp ge men lai le”.getBytes();

DatagramPacketdp = new DatagramPacket(buf,buf.length,InetAddress.getByName(“127.0.0.1”),10000);

ds.send(dp);

ds.close();

      

       需求:用于接收udp传输的数据并处理

1.    定义udpsocket服务。通常会监听一个端口,其实就是给这个接收网络应用程序定义数据标识,如果没有定义,系统会自动分配一个。方便于明确哪些数据过来该应用程序可以处理。

2.    定义一个空的数据包,因为要存储接收到的字节数据,因为数据包对象中有更多功能可以提取字节数据中不同数据信息。

3.    通过socket服务的receive方法将收到的数据存入已定义好的数组中。

4.    通过数据包对象的特有功能,将这些不同的数据取出,打印出来。

5.    关闭资源

 

DatagramSocket  ds =  new  DatagramSocket(10000);

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());

int  port = dp.getPort();

System.out.println(ip+”::”+data+”::”+port);

ds.close();

 

发送端如果要一直处于等待状态的话。加while语句

BindException:端口已经被使用,绑定异常。

1024*64,数据包最大值

 

需求:编写一个聊天程序。

有收数据和发数据的部分,这两部分需要同时执行,那就需要用到多线程技术。一个线程控制收,另一个线程控制发

因为收和发动作是不一致的。所以要定义两个run方法,而且这两个方法要封闭到不同的类中。

      

 

       TCP传输

       SocketServerSocket     建立客户端和服务器端

      

       实例:

       客户端:  通过查阅socket对象,发现在该对象建立时,就可以去连接指定主机。因为tcp是面向连接的,所以在建立socket服务时,就要有服务端存在,并连接成功。形成通路后,在该通道进行数据的传输。

       需求:给服务端发送一个文本数据。

       步骤:

1.    创建socket服务,并指定要连接的主机和端口。

Socket s= new Socket(“192.168.1.254”,10003);

2.    为了发送数据,应该获取socket流中的输出流。

OutputStreamou t = s.getOutputStream();

out.write(“sfdasfsaddsaf”.getBytes());

3.    关闭服务

s.close();

      

       服务端:

       需求:定义端点接收数据并打印在控制台上。

1.    建立服务器端 的socket服务。ServerSocket();并监听一个端口。

2.    获取连接过来的客户端对象。通过ServerSocketaccept()方法获取Socket对象。没有连接就会等,这个方法是阻塞式的。

3.    客户端如果发过来数据,那么服务端要使用对应的客户端对象,并获取到该客户端对象的读取流来读取发过来的数据。

4.    关闭服务端。(可选,一般不关闭)

 

ServerSocketss = new ServerSocket(10003);

Socket s= ss.accept();

String ip= s.getInetAddress().getHostAddress();

System.out.println(ip+“connected…”);

InputStreamin = s.getInputStream();

byte[]buf = new byte[1024];

int len =in.read(buf);

 

System.out.println(newString(buf,0,len));

s.close();

ss.close();

 

演示tcp的传输的客户端和服务端的互访。

需求:客户端给服务端发送数据,服务端收到后,给客户端反馈信息。

 

客户端:

1.    建立socket服务,指定要连接主机和端口。

2.    获取socket流中的输出流,将数据写到该流中,通过网络发送给服务端。

3.    获取socket流中的输入流,将服务端反馈的数据获取到并打印。

4.    关闭客户端资源。

 

Socket s= new Socket(“192.168.1.254”,10004);

OutputStreamout = s.getOutputStream();

out.write(“服务端,您好”.getBytes());

InputStreamin = s.getInputStream();

byte[]buf = new byte[1024];

int len =in.read(buf);

System.out.println(newString(buf,0,len));

s.close();

 

 

服务端

ServerSocketss = new ServerSocket(10004);

Socket s= ss.accept();

System.out.println(s.getInetAddress().getHostAddress()+”…..connected”);

InputStreamin = s.getInputStream();

byte[]buf = new byt[1024];

int len =in.read[buf];

system.out.println(newString(buf,0,len));

 

OutputStreamout = s.getOutputStream();

out.write(“你也好”.getBytes());

ss.close();

 

       实例:上传图片

       客户端:

1,服务端点

       2,读取客户端已有的图片数据

       3,通过Socket输出流将数据发给服务端

       4,读取服务端反馈信息

       5,关闭

      

       服务端:

       这个服务端有个局限性,当客户端连接上以后,被服务端获取到。服务端执行具体流程,这时B客户端连接只有等待A执行完。因为服务端还没处理完A客户端的请求,还没有循环回来执行下次的accept方法,所以暂时获取不到B客户坚象。那么为了可以让多个客户端同时并发访问服务端,那么服务端最好就是将每个客户端封装到一个单独的线程中。这样,就可以同时处理多个客户端的请求。

       如何定义线程呢?

       只要明确了每一个客户端要在服务端执行的代码即可。将该代码存入run方法中。

 

       客户端并发登录

 

       浏览器客户端-自定义服务端

      

       浏览器客户端-Tomcat服务器

       HTTP

       可以利用HTTP头自定义客户端向Tomcat服务器发送请求信息

      

       http://192.168.1.254:11000/myweb/demo.html

 

GET/myweb/demo.html HTTP/1.1

Accept:application/x-shockwave-flash, image/gif, image/x-xbitmap, image/jpeg, i

mage/pjpeg,application/vnd.ms-excel, application/vnd.ms-powerpoint, application

/msword,application/QVOD, application/QVOD,

Accept-Language:zh-cn

Accept-Encoding:gzip, deflate

User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0

.50727)

Host:192.168.1.254:11000

Connection:Keep-Alive

//回车

//发送的内容

 

 

URL

URIURL范围大,包括条形码

包括很多获取服务器信息的方法

getFile()文件名

getHost()主机名

getPath()路径部分

getPort();端口号

getProtocol();协义名称

getQuery();    获取此URL的查询部

 

 

URLConnection

URLConnection urlc  =  url.openConnection();

 

URL  url =  new  URL(“http://localhost:8080/web/aa.html”);

URLConnection  urlc =  url.openConnection();

InputStream  is =  urlc.getInputStream();

...........

 

//不需要用Socket了。因为现在走的是应用层, 当服务器返回时,http响应信息会在传输层过滤掉!

 

 

Socket()一个无参数的构造函数

.connect(SocketAddress  endpoint) 连接服务器

 

ServerSocket(int  port , int  backlog)backlog:同时在线的客户端连接数

 

域名解析:

www.baidu.com

首先会访问一个DNS域名解析服务器,在DNS域名解析服务器中查找baiduIP地址

 

本机的映射关系在于host文件中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值