• 第61天python学习scoket流程


    套接字流程图:

    socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求。

    socket起源于Unix,而Unix/Linux基本哲学之一就是“一切皆文件”,对于文件用【打开】【读写】【关闭】模式来操作。socket就是该模式的一个实现,socket即是一种特殊的文件,一些socket函数就是对其进行的操作(读/写IO、打开、关闭)

    socket和file的区别:

    file模块是针对某个指定文件进行【打开】【读写】【关闭】

    socket模块是针对 服务器端 和 客户端Socket 进行【打开】【读写】【关闭】

     实现代码:

    TCP服务端:

    import  scoket

    1、买手机:phone=scoket.scoket(conket.AF_INET,scoet.sock_STREM)

    2、绑定个手机:phone.bind("127.0.0.1",8080)

    3、开机phone.listen(5)

    4、等电话,拿到一个电弧(电话链接,对方的手机号)conn,data=phone.accept()   

    5、发消息:adata=conn.recv(1024)

    6、收消息:conn.send(data)

    7、断开电话链接:conn.close()

    8、关机:phone.close

    TCP客户端:

    1、买手机:phone=scoket.scoket(conket.AF_INET,scoet.sock_STREM)

    2、拨通电话:phone.connet("127.0.0.1",8080) 

    3、发消息:phone.send(data)

    4、收消息:phone.recv()

    5、断开电话链接:phone.close()

     TCP服务端:

    import socket
    from socket import *#tcp_server=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
    ip_port=("127.0.0.1",8080)
    back_log=5
    buffer_size=1024
    tcp_server=socket(AF_INET,SOCK_STREAM)
    tcp_server.bind(ip_port)#绑定端口
    tcp_server.listen(back_log)#监听

    conn,addr=tcp_server.accept()
    print("双向链接是",conn)
    print("客户端地址",addr)

    data=conn.recv(buffer_size)
    print("客户端发来的消息是",data.decode("utf-8"))
    conn.send(data.upper())
    conn.close()
    tcp_server.close()

     TCP客户端:

    import socket
    from socket import *#tcp_server=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
    ip_port=("127.0.0.1",8080)
    back_log=5
    buffer_size=1024
    tcp_client=socket(AF_INET,SOCK_STREAM)
    tcp_client.connect(ip_port)
    tcp_client.send("hello".encode("utf-8"))
    print("客户端已经发送消息")
    data=tcp_client.recv(buffer_size)
    print("收到服务器发来的消息",data.decode("utf-8"))

    tcp_client.close()
  • 相关阅读:
    python爬虫循环导入MySql数据库
    以洛谷P2661信息传递为例总结找环的常见的几种方法
    CF1339E-Perfect Triples (打表找规律)
    CF1339D-Edge Weight Assignment (dfs)
    CF1335E2-Three Blocks Palindrome (hard version) (二分+双指针)
    CF1327D-Infinite Path (循环置换)
    洛谷P3178 [HAOI2015]树上操作 (树链剖分)
    洛谷P2590 [ZJOI2008]树的统计 (树链剖分)
    洛谷P3833 [SHOI2012]魔法树 (树链剖分)
    树链剖分板子
  • 原文地址:https://www.cnblogs.com/jianchixuexu/p/11815879.html
Copyright © 2020-2023  润新知