• python-网络编程-02


    [1] server端

    首先我们看下一个最简单http服务端

    import socket
    def handle_request(client):
        buf = client.recv(1024)
        client.send("HTTP/1.1 200 OK
    
    ")
        client.send('test')
    client.close() def main(): sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)#创建socket对象 sock.bind(('localhost',8000))#监听 sock.listen(5) while True: connection ,clent_addr = sock.accept() handle_request(connection) if __name__ == '__main__': main()

    当我们监听端口之后 我们执行 sock.accept() 这行代码的时候,代码会堵塞等待客户端请求 也就是如果用户不访问这个端口,就不执行下面的代码

    那么  connection ,clent_addr 分别代表就是接收到客户端对象和客户端ip地址

    然后在代码中我们调用客户端socket的recv方法设定了缓存区大小。并且通过send函数发送了内容。本质上http协议是tcp的上层协议,又由于http的特性

    只要send中有字符串信息,浏览器就能显示。当然你也可以整个网页的内容都返回,那么显示就是整个网页了。我们通过答应buf就能获得客户端的请求头部的,当然我们这里不讨论http协议。

    那么说白了 客户端跟服务端的的关系就是发送和接收数据的关系

    [2]clent端 

    server 代码

    import socket
    def handle_request(client):
        buf = client.recv(1024)
        client.send('hi')
        client.close()
    
    def main():
        sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        sock.bind(('localhost',8000))
        sock.listen(5)
        while True:
            connection ,clent_addr = sock.accept()
            print connection,clent_addr
            handle_request(connection)
    if __name__ == '__main__':
        main()
    

    client 代码

    import  socket
    sock = socket.socket()
    sock.connect(('localhost',8000))
    data= raw_input('input:')
    sock.send(data)
    res = sock.recv(1024)
    print res
    sock.close()
    

      

  • 相关阅读:
    七月随想
    曾经的诗
    Foundry feats. MultiverseStudio
    "BLAME" is out.
    去除partner页面消息 自动添加关注者的功能
    Odoo小数精度及货币精度详解
    CentOs 6.x 升级 Python 版本【转】
    django template if return false
    Odoo “坑” 系列之 XML中的布尔类型
    Qweb报表中的Reload from Attachment参数
  • 原文地址:https://www.cnblogs.com/nerdlerss/p/6742778.html
Copyright © 2020-2023  润新知