• 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
  • 相关阅读:
    linux虚拟机系统的复制或克隆后续问题解决!
    Linux命令大全
    Linux 介绍快速浏览
    Linux软件管理和安装
    Kali linux 2016.2(Rolling)安装之后的常用配置
    使用ttXactAdmin、ttSQLCmdCacheInfo、ttSQLCmdQueryPlan获取SQL相关具体信息[TimesTen运维]
    MongoDB--Getting Started with Java Driver
    OpenCV 通过 MFC 的 Picture Control 控件操作图像
    HTML学习笔记之中的一个(input文件选择框的封装)
    hdu 5282 Senior's String 两次dp
  • 原文地址:https://www.cnblogs.com/xuanxuanlove/p/9737767.html
Copyright © 2020-2023  润新知