python socket 如何接收tcp/ip byte 格式的数据?
问题描述
python socket 如何接收tcp/ip byte 格式的数据?下面的只能接收明文
import socketserver # 导入socketserver模块class MyServer(socketserver.BaseRequestHandler): # 创建一个类,继承自socketserver模块下的BaseRequestHandler类 def handle(self): # 要想实现并发效果必须重写父类中的handler方法,在此方法中实现服务端的逻辑代码(不用再写连接准备,包括bind()、listen()、accept()方法)while 1: conn = self.request addr = self.client_address # 上面两行代码,等于 conn,addr = socket.accept(),只不过在socketserver模块中已经替我们包装好了,还替我们包装了包括bind()、listen()、accept()方法 while 1:accept_data = conn.recv(1024)#accept_data = int(’0x4’,16)print(accept_data)if accept_data == 'byebye': breaksend_data = bytes(input('>>>>>'))conn.sendall(send_data) conn.close()if __name__ == ’__main__’: sever = socketserver.ThreadingTCPServer(('192.168.0.110', 10001), MyServer) # 传入 端口地址 和 我们新建的继承自socketserver模块下的BaseRequestHandler类 实例化对象 sever.serve_forever() # 通过调用对象的serve_forever()方法来激活服务端
问题解答
回答1:如果你的python3, conn.recv() 返回数据就是 bytes,decode一下就是str类型。或者使用bytes比较。
if accept_data == b'byebye': break
处理 accept_date数据的时候,decode即可,如果服务器返回的utf-8编码的,只需要accep_data.decode(’utf-8’)
相关文章:
1. javascript - 按钮链接到另一个网址 怎么通过百度统计计算按钮的点击数量2. java - jdbc如何返回自动定义的bean3. python - 请问这两个地方是为什么呢?4. 请教一个mysql去重取最新记录5. 大家都用什么工具管理mysql数据库?6. Python处理Dict生成json7. mysql的循环语句问题8. python - 为什么match匹配出来的结果是<_sre.SRE_Match object; span=(0, 54), match=’’>9. mysql优化 - mysql 一张表如果不能确保字段列长度一致,是不是就不需要用到char。10. mysql updtae追加数据sql语句
