1. Scoket概念:

    socket本质上就是在2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递。 我们知道网络 通信 都 是基于 ip+port 方能定位到目标的具体机器上的具体服务,操作系统有0-65535个端口,每个端口都可以独立对外提供服务,如果 把一个公司比做一台电脑 ,那公司的总机号码就相当于ip地址, 每个员工的分机号就相当于端口, 你想找公司某个人,必须 先打电话到总机,然后再转分机 。 建立一个socket必须至少有2端, 一个服务端,一个客户端, 服务端被动等待并接收请求,客户端主动发起请求, 连接建立之后,双方可以互发数据。(利用IP和端口实现两个设备的通信)。

  2. Socket核心方法:

    接收端:
    import socket
    socket.TCP/IP
    listen(ip,port)
    waiting()#等待数据
    recv()#接收数据
    send()#再发送数据
    发送端:
    import socket
    socket.TCP/IP
    connect(a.ip,a.port)#接受端主机的IP,端口(port:端口号)
    socket.send(hello)#发送的数据sendall()名义上是一次性发送所有的数据,但是由于系统原因还是有限制的
    socket.recv()#接收数据
    socket.close()#关闭
  3. 实例列举:

    服务器端:
    import socket
    server=socket.socket()#设置连接
    server.bind((“localhost”,8888))#绑定连接(参数是一个元组)
    server.listen(5)#监听
    conn,addr=server.accept()#等待
    data=conn.recv(1024)#接收(是byte类型的,需要转换(一般编为utf-8))
    conn.sendall(data)#一次性发送所有数据(由于系统原因,是发送不了所有的数据的)
    server.close()
    客户端:
    import socket
    client=socket.socket()
    client=connect((“localhost”,8888))#建立连接,参数是一个元组
    data=input().strip()#手工输入的是unicode类型,但是再传输的时候是要编码的
    client.send(data.encode(“utf-8”))#发送数据
    data=client.recv(1024)#收到的数据是utf-8编码的,所以直接输出是乱码
    client.close()
  4. 粘包:

    当你连续的调用send()时,由于接收时recv()有大小限制,会发生发送的数据量大于接收的数据量,导致接收的数据不是你期待的数据,这个时候就发生了粘包(两次发送的数据被同一次接收) 为了避免这种错误,我们通常会设计反馈,即你发送一次数据,我们会吧发送的数据反馈给发送给你。这样两次发送中间夹杂着一次接收,避免了数据在缓冲中导致粘包。

  5. 一些注意的地方:

  • 发送与接收的类型:

我们在Python3中,默认是Unicode,而在发送数据(send)时,函数send()的参数类型是:Byte,所以我们要进行数据的转换:

str==>bytes bytes==>str

a=”qweqwe”  =>a的类型为str

str==>bytes

b=a.encode(“utf-8”)

b=b”hello word”  =>b为bytes类型

bytes==>str

s=b.decode(“utf-8”)

  • 数据的校验:

字符串类型的,我们可以利用hashlib包中的md5算法来检验

文件类型的,我们可以对比两个文件的区别:

diff file1 file2

观察两个文件是否一致(文件检测)

SocketServer:

这个比较方便,它集成了一些东西,很方便的,只是server端改变了一下书写方式,客户端不用改变

代码如下:

#this is server
import socketserver
class MyTCPHandler(socketserver.BaseRequestHandler):#类名随意,但是继承的不能改变
def handle(self):#系统会自动调用这个函数,我们只需要在这个函数中写我们要实现的方法就可以了
while True:
try:
self.data=self.request.recv(1024).strip()
print("{} wrote".format(self.client_address))
print(self.data)
self.request.send(self.data.upper())
except ConnectionResetError as e:
print("error: ",e)
break
if __name__ =="__main__":
HOST,PORT="localhost",9999#声明IP与端口
server=socketserver.ThreadingTCPServer((HOST,PORT),MyTCPHandler)#设置连接
server.serve_forever()#建立连接,然后系统在连接成功以后会自动调用函数handle()
#this is client
import socket
client=socket.socket()
client.connect(("localhost",9999))
while True:
cmd=input(">>").strip()
if cmd =="":
continue
client.send(cmd.encode())
data=client.recv(1024)
print(data)

附:

socket一个最简单的通信:

#服务器端:
import socket
server=socket.socket()
server.bind(("localhost",8888))
server.listen()
conn,addr=server.accept()
count=10
while count:
data=conn.recv(1024)
print(data.decode("utf-8"))
conn.send(data)
count-=1
server.close()
#客户端
import socket
client=socket.socket()
client.connect(("localhost",8888))
while True:
chioce=input(">>").strip()
client.sendall(chioce.encode("utf-8"))
data=client.recv(1024)
if not data:
break
print(data.decode("utf-8"))
client.close()

Socket简单实现ssh笔记的更多相关文章

  1. 运用socket实现简单的ssh功能

    在python socket知识点中已经对socket进行了初步的了解,那现在就使用这些知识来实现一个简单的ssh(Secure Shell)功能. 首先同样是建立两个端(服务器端和客户端) 需求是: ...

  2. Python3学习之路~8.2 socket简单实例 实现ssh 发送大量数据

    实例1: 利用socket模拟客户端和服务器端各自收发一次数据: #Author:Zheng Na # 客户端 import socket # 声明socket类型,同时生成socket连接对象 cl ...

  3. 网络编程基础【day09】:实现简单地ssh(四)

    本节内容 概述 简单ssh socket接收大数据的困惑 一.概述 我们用过linux的就知道什么是ssh,它是一种客户端和服务端交互返回的一个解决,输入一个命令,给我返回什么,接下来我们说一说,如何 ...

  4. FreeBSD简单配置SSH并用root远程登陆方法

    FreeBSD简单配置SSH并用root远程登陆方法 前言:最近下载了FreeBSD,在虚拟机上安装,第一步先要开启SSH服务,用终端putty软件可以实现在windows系统进行远程管理, 初级 = ...

  5. 简单脱壳教程笔记(2)---手脱UPX壳(1)

    本笔记是针对ximo早期发的脱壳基础视频教程,整理的笔记. ximo早期发的脱壳基础视频教程 下载地址如下: http://down.52pojie.cn/%E5%90%BE%E7%88%B1%E7% ...

  6. .NET 跨平台RPC框架DotNettyRPC Web后台快速开发框架(.NET Core) EasyWcf------无需配置,无需引用,动态绑定,轻松使用 C# .NET 0配置使用Wcf(半成品) C# .NET Socket 简单实用框架 C# .NET 0命令行安装Windows服务程序

    .NET 跨平台RPC框架DotNettyRPC   DotNettyRPC 1.简介 DotNettyRPC是一个基于DotNetty的跨平台RPC框架,支持.NET45以及.NET Standar ...

  7. ContOS网络连接及简单的ssh Xshell连接!

    这边简单的记录一下下ContOS网络连接及简单的ssh Xshell连接! 首先你得安装一个Contos Linux系统对吧! 1.找到设置--->网络-->有线连接-->IPv4 ...

  8. Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型

    Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes类型 目录 Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes ...

  9. C# .NET Socket 简单实用框架,socket组件封装

    参考资料 https://www.cnblogs.com/coldairarrow/p/7501645.html 根据.NET Socket 简单实用框架进行了改造,这个代码对socket通信封装还是 ...

随机推荐

  1. 基于JWT的Token登录认证

    1.JWT简介   JSON Web Token(缩写 JWT),是目前最流行的跨域认证解决方案. 2.JWT的原理        JWT的原理是,服务器认证以后,生成一个JSON格式的对象,发回给客 ...

  2. Ajax:实现后台验证js实现get方式的异步请求,判断用户名是否重复

    <%@ page contentType="text/html;charset=UTF-8" language="java" %><html& ...

  3. 利用jquery实现前端同步请求---判断姓名是否为空并设置事件

    <%@ page contentType="text/html;charset=UTF-8" language="java" %><html& ...

  4. 对于写Java的博文

    其实我是有过想要自己总结java相关的知识点给大家分享,但我的Java并不很好,大多数情况我只是拿Java当工具,写一些自己所需一些简单的东西,因此,大多数碰到我不懂的Java问题时,我也是上博客园, ...

  5. docker in docker 的启动方式

    --privileged  -v /var/run/docker.sock:/var/run/docker.sock  -v $(which docker):/bin/docker 启动容器时添加上面 ...

  6. RAC_多路径配置

    多路径配置 http://blog.itpub.net/31397003/viewspace-2143390/ 挂盘/配置好yum源 2.程序包的安装 device-mapper-1.02.95-2. ...

  7. MongoDB学习笔记(四、MongoDB安全管理)

    目录: mongoDB角色 mongoDB初始化账号 mongoDB安全认证 其它常用的命令 mongoDB角色: mongoDB初始化账号: 1.启动mongoDB ./mongod -f mong ...

  8. mock 模拟数据在框架中的简单使用

    首先在框架中需要安装mock模块 cnpm i mockjs -S 其次在src文件夹下新建mock文件夹,在mock文件夹中新建一个index.js文件 代码如下: const Mock = req ...

  9. pytorch基础-搭建网络

    搭建网络的步骤大致为以下: 1.准备数据 2. 定义网络结构model 3. 定义损失函数4. 定义优化算法 optimizer5. 训练 5.1 准备好tensor形式的输入数据和标签(可选) 5. ...

  10. 详解扩展欧几里得算法(扩展GCD)

    浅谈扩展欧几里得(扩展GCD)算法 本篇随笔讲解信息学奥林匹克竞赛中数论部分的扩展欧几里得算法.为了更好的阅读本篇随笔,读者最好拥有不低于初中二年级(这是经过慎重考虑所评定的等级)的数学素养.并且已经 ...