zoukankan      html  css  js  c++  java
  • python学习笔记 day30 网络编程

    1. TCP协议的三次握手和四次挥手

    https://github.com/jawil/blog/issues/14 这篇文章讲的很好 Mark~

    2.互联网协议 & OSI模型

     3. 代码实现

    1. 简单版本----同一主机两个不同进程之间的通信:

    # server.py
    import socket
    sk=socket.socket()
    sk.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)  # 为了防止重启服务时出现错误
    sk.bind(('127.0.0.1',8080))  # sk.bind()方法必须接收一个元组,绑定IP地址和端口,由于是一台主机上的两个不同的进程,所以IP地址直接使用127.0.0.1 端口一般都是使用8000之后的
    sk.listen()  # 服务端要时刻保持监听状态,等待客户端的请求
    
    conn,addr=sk.accept()
    ret=conn.recv(1024).decode('utf-8')  # 客户端给服务端发送数据,服务端指定接收1024个字节,decode='utf-8'是考虑了中文
    print(ret)  # 服务端打印客户端发来的请求
    conn.send(bytes("你好,客户端,我可以听到,你能听到我说话吗".encode('utf-8')))  # 服务端接收到客户端的请求后,给客户端发送信息
    ret=conn.recv(1024).decode('utf-8')
    print(ret)
    conn.close() # 连接中断
    sk.close()
    # client.py
    import socket
    sk=socket.socket()
    sk.connect(('127.0.0.1',8080))  # 客户端指定服务端的IP地址和端口号
    sk.send(bytes("你好,服务器,我是客户端,你听的到吗?".encode('utf-8')))
    ret=sk.recv(1024).decode('utf-8')
    print(ret)
    sk.send("我也可以听得到,我们可以愉快的通话了~".encode('utf-8'))
    
    sk.close()  # 中断连接

    运行结果:

     2. 版本二---可以实现服务器和客户端的实时聊天

    # server.py
    import socket
    sk=socket.socket()
    sk.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)
    sk.bind(('127.0.0.1',8080))
    sk.listen()
    
    conn,addr=sk.accept()
    while True:
        ret=conn.recv(1024).decode('utf-8')
        if ret=='bye':  # 接收到客户端发来的bye就会终止循环
            break
        print(ret)
        info=input(">>>")
        conn.send(bytes(info.encode('utf-8')))
    conn.close()
    sk.close()
    # client.py
    import socket
    sk=socket.socket()
    sk.connect(('127.0.0.1',8080))
    
    while True:
        info=input(">>>")
        sk.send(bytes(info.encode('utf-8')))  # 因为服务端是先接收,所以客户端得先发一个
        ret=sk.recv(1024).decode('utf-8')
        print(ret)
        if ret=='bye':
            sk.send(bytes("bye".encode('utf-8'))) # 如果bye是服务端发送的,则客户端接收到之后需要在自身停止循环之前先把结束的信息再传给服务端(因为总是客户端先停止,再来断开服务端)
            break
    sk.close()

    运行结果:

    3. 作业---客户端每隔十秒给服务端发送时间戳,服务端需要转化为格式化的时间:

    # server.py
    import time
    import pickle
    import socket
    sk=socket.socket()
    sk.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)
    sk.bind(('127.0.0.1',8080))
    sk.listen()
    
    conn,addr=sk.accept()
    count=0
    while True:
        ret_str=conn.recv(1024)
        ret=pickle.loads(ret_str)
        ret_struct_time=time.asctime(time.localtime(ret))
        print(ret_struct_time)
        count+=1
        if count==10:  # 统计十次时间 就不再连接了
            break
    conn.close()
    sk.close()
    # client.py
    import time
    import pickle
    import socket
    sk=socket.socket()
    sk.connect(('127.0.0.1',8080))
    count=0
    while True:
        time.sleep(10)
        time_float=time.time()
        time_str=pickle.dumps(time_float)  # 将时间戳(float类型)通过pickle序列化转为字符串
        sk.send(bytes(time_str))
        count+=1
        print("第%s次发送时间" % count)
        if count==10:
            break
    
    sk.close()

    运行结果:

     

    talk is cheap,show me the code
  • 相关阅读:
    QT中使用CoInitializeEx
    Linux 声音采集的时候内容全都是0
    linux类似系统中编译依赖库出现error trying to exec cc1plus
    C语言练习题2
    进程和任务计划管理
    解决火车头7.6版本无法采集部分https网站处理方法
    PHP输出13位时间戳函数
    destoon取消公司名称怎重复注册的限制
    destoon取消公司名称怎重复注册的限制
    destoon伪静态地址空值优化
  • 原文地址:https://www.cnblogs.com/xuanxuanlove/p/9737767.html
Copyright © 2011-2022 走看看