本文实例为大家分享了Android socket的实现原理,供大家参考,具体内容如下
Socket套接字
是网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字。
socket实现的原理机制:
1、通信的两端都有Socket
2、网络通信其实就是Socket间的通信
3、数据在两个Socket间通过IO传输
建立Socket(客户端)和ServerSocket(服务器端)
建立连接后,通过Socket中的IO流进行数据的传输
关闭socket
同样,客户端与服务器端是两个独立的应用程序。
服务器端思路
1、建立服务器端的socket服务,需要一个端口
2、服务端没有直接的操作,而是通过accept方法获取客户端对象,在通过获取到的客户端对象的流和客户端进行通信
3、通过客户端获取流对象的方法,读取数据或者写入数据
4、如果服务完成,需要关闭客户端,然后关闭服务器,但是,一般会关闭客户端,不会关闭服务器,因为服务端是一直提供服务的
服务端实现代码
// 创建服务器端 ServerSocket server = new ServerSocket(5555); while(true){ // 等待连接 Socket accept = server.accept(); OutputStream outputStream = accept.getOutputStream(); outputStream.write("你好,我是服务器!\r\n".getBytes()); outputStream.flush(); // 读取数据 InputStream inputStream = accept.getInputStream(); BufferedReader reader = new BufferedReader(new InputStreamReader( inputStream)); System.out.println("服务器:" + reader.readLine()); outputStream.close(); inputStream.close(); }
客户端思路
1、建立客户端的Socket服务,并明确要连接的服务器。
2、如果连接建立成功,就表明,已经建立了数据传输的通道.就可以在该通道通过IO进行数据的读取和写入.该通道称为Socket流,Socket流中既有读取流,也有写入流.
3、通过Socket对象的方法,可以获取这两个流
4、通过流的对象可以对数据进行传输
5、如果传输数据完毕,关闭资源
客户端实现代码
//创建套接字 确定要连接的服务器ip与端口口 Socket socket=new Socket("172.17.23.77",5555); InputStream inputStream = socket.getInputStream(); BufferedReader br=new BufferedReader(new InputStreamReader(inputStream)); String readLine = br.readLine(); System.out.println("客户端:"+readLine); //向服务器发送消息 OutputStream outputStream = socket.getOutputStream(); outputStream.write("你好\r\n".getBytes()); outputStream.flush(); outputStream.close(); inputStream.close();
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍python Socket之客户端和服务端握手详解,包括了python Socket之客户端和服务端握手详解的使用技巧和注意事项,需要的朋友参考一下 简单的学习下利用socket来建立客户端和服务端之间的连接并且发送数据 1. 客户端socketClient.py代码 2. 服务端serverSocket.py代码 3.操作过程 开两个控制台窗口,先运行服务端 python3 ser
本文向大家介绍详解如何用python实现一个简单下载器的服务端和客户端,包括了详解如何用python实现一个简单下载器的服务端和客户端的使用技巧和注意事项,需要的朋友参考一下 话不多说,先看代码: 客户端: 服务器: 前几天有写一个基于UDP的简单程序,今天学习了TCP,TCP与UDP 的区别与联系其实已经写得很清楚了,这里不再多说。今天使用的TCP,在文件下载方面应用更加广泛(可靠)。客户端分析
我想在一些计算机之间建立点对点连接,这样用户就可以在没有外部服务器的情况下聊天和交换文件。我最初的想法如下: 我在服务器上制作了一个中央服务器插座,所有应用程序都可以连接到该插座。此ServerSocket跟踪已连接的套接字(客户端),并将新连接的客户端的IP和端口提供给所有其他客户端。每个客户端都会创建一个新的ServerSocket,所有客户端都可以连接到它。 换句话说:每个客户端都有一个Se
本文向大家介绍.Net整合Json实现REST服务客户端的方法详解,包括了.Net整合Json实现REST服务客户端的方法详解的使用技巧和注意事项,需要的朋友参考一下 前言 本文主要给大家介绍了关于.Net整合Json实现REST服务客户端的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 一. 准备工作 1. 点击官网 或 本地 下载支持.Net4.0 的Json插
我有一个运行在j2ee服务器(jboss 4.0.4)上的axis2 web服务客户端,该服务器一直在使用tomcat上托管的web服务。最近tomcat管理员打开了TLS,现在我的axis2客户端无法工作。如何为axis2客户端打开TLS? 谢谢你的帮助!
服务发现是基于微服务架构的关键原则之一。尝试配置每个客户端或某种形式的约定可能非常困难,可以非常脆弱。Netflix服务发现服务器和客户端是Eureka。可以将服务器配置和部署为高可用性,每个服务器将注册服务的状态复制到其他服务器。 如何包含Eureka客户端 要在您的项目中包含Eureka客户端,请使用组org.springframework.cloud和工件ID spring-cloud-st