python-day8socket、粘包、并发、多用户ftp

@以字符串名称形式引入外部模块:同级文件lib里面有个函数a打印66

1.解释器内部使用

m=__import__('lib')
print(m.a())

结果:

66

None

  1. 官方推荐用户使用

import importlib
m=importlib.import_module('lib')
print(m.a())

 

@

F()()#执行类下面的__call__方法

__metaclass__暂时用不到

@@上周提到?

Fligh.status

Status.setter

Status.delter

__call__方法(没用过)

__mataclass__(没用过,以后可能用)

断言

@assert m is int#AssertionError

@ socket复习

博客里的Day7

 

@socket

    tcp/ip  send, recv

    udp

 

    family address

        AF.INET  ipv4

        AF.INET6

        AF.UNIX  local

    socket protocol type

        sock.SOCK_STREAM  tcp/ip

        socket.SOCK_DGRAM   数据报式socket , for UDP

 

 

    服务端

    server = socket.socket(AF.INET,sock.SOCK_STREAM)

    server.bind(localhost,9999)

    server.listen()

    while True:

        conn,addr = server.accept() #阻塞?

        while True:

           print("new conn",addr)

           data = conn.recv(1024) #8192最多,1024的整数  #recv默认是阻塞的

 

           if not data:

                break #客户端已断开, conn.recv收到的就都是空数据,

           print(data)

           conn.send(data.upper())

@判断一条程序是否被执行了,前后都print一句话。

@@@socket实现简单的ssh客户端

博客园Day8

@b”xxx”xxx必须是ASCII码里面的内容才能转,中文转不了。

@send的时候如果服务器端允许接受的小于客户端发送量,剩余的进入缓冲区,第二次发的时候不发新的,而先发缓冲区里面的。系统默认最多buffer8k,缓冲区满了发、超时也发,send相当于强制超时。

@整数不能encode,需要先转成字符串。

@8-4中问题,直接看截图就行,主要是调试一下错误。

同样的代码在unixwindows里面不一样,问题原因:不应该直接判断文件长度(字符数),而应该先encode再判断多少byte

@socket判断信息长度版

  1. client

import socket
client=socket.socket()
client.connect(('localhost',9999))
while True:
    cmd=input('>>:').strip()
    if len(cmd)==0:continue
    client.send(cmd.encode('utf-8'))#必须是byte类型
    cmd_res_size=client.recv(1024)
    print("命令结果大小:",cmd_res_size)

client.send('准备好接受,可以发了'.encode('utf-8'))
    received_size=0
    received_data=b''
    while received_size<int(cmd_res_size.decode()):
        data=client.recv(1024)
        received_size+=len(data)#每次收到的有可能小于1024,用len判断
        received_data+=data
    else:
        print("cmd res receive done...",received_size)
        print(received_data.decode())

client.close()

 

ssh

import socket,os
server=socket.socket()#实例化,默认不填参数
server.bind(('localhost',9999))
server.listen()
while True:
    conn,addr=server.accept()#conn是新的套接字对象,用来接收和发送数据。addr是连接客户端的地址。接收TCP 客户的连接(阻塞式)等待连接的到来
    print('new conn:',addr)
    while True:
        print('等待新指令')
        data=conn.recv(1024)
        if not data:
            print('客户端已断开')
            break
        print('执行指令:',data)
        cmd_res=os.popen(data.decode()).read()#接收了字符串,执行结果也是
        print('before send',len(cmd_res))
        if len(cmd_res)==0:
            cmd_res='none is output'#字符串前面加b就不能encode
        conn.send(str(len(cmd_res.encode())).encode('utf-8'))

client_ack = conn.recv(1024)#客户端回复,防止粘包
    conn.send(cmd_res.encode('utf-8'))#发送数据不可为空
    print('send done')
server.close()

@男生着装:优衣库、zaraHMtiger鞋;

@socket 粘包,两块数据一起发,如两次send,系统会从缓冲区将两者并成一条发出去。

sleep(0.25)还是有可能粘住

@8-7-4-30’’

posted on 2018-09-04 17:15  Akmendo 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/AKmendo/p/9585669.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 中使用 socket 进行网络通信时,也可能会遇到粘包和分包的问题。下面是一些解决粘包和分包问题的常用方法: 1. 使用固定长度的数据包:发送方在发送数据时,将每个数据包的长度固定为一个固定值。接收方在接收数据时,根据固定长度来切分数据包。例如: ```python # 发送方 data = "Hello" length = len(data) length_bytes = length.to_bytes(4, byteorder='big') sock.sendall(length_bytes + data.encode()) # 接收方 length_bytes = sock.recv(4) length = int.from_bytes(length_bytes, byteorder='big') data = sock.recv(length) ``` 2. 使用特殊字符作为分隔符:发送方在每个数据包的末尾添加一个特殊字符作为分隔符,接收方根据分隔符来切分数据包。例如: ```python # 发送方 data = "Hello" sock.sendall(data.encode() + b'\n') # 接收方 data = b'' while True: chunk = sock.recv(1024) if b'\n' in chunk: parts = chunk.split(b'\n') data += parts[0] break data += chunk ``` 3. 使用消息边界:发送方和接收方之间约定一个消息边界,每个数据包都以边界标记结尾。例如,可以使用换行符 `\n` 或其他特殊字符作为边界。 ```python # 发送方 data = "Hello\n" sock.sendall(data.encode()) # 接收方 data = b'' while True: chunk = sock.recv(1024) data += chunk if b'\n' in chunk: break ``` 这些方法都是常用的解决粘包和分包问题的方式,你可以根据实际情况选择适合自己的方法来处理。注意在实际应用中,可能需要处理更复杂的情况,如粘包和分包同时出现或处理大量并发连接的情况,这时可能需要更加复杂的处理策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值