zoukankan      html  css  js  c++  java
  • 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()
    

      

  • 相关阅读:
    应用Solaris11放置光盘修复solaris引导妨碍
    HP 3803TX 装置debian4 Linux
    释放linux细碎的内存
    linux批量查找文件内容
    Oracle 10g R2 for Solaris x86在Solaris 11上的装配
    Linux 零碎进修之shell剧本进修
    华硕易PC台式机版7月环球上市 或运转Linux
    Linux文件琐细 一分钱一分货
    linux下平安管理
    预装Windows或Ubuntu,戴尔出Mini Inspiron 8.9寸笔记本
  • 原文地址:https://www.cnblogs.com/nerdlerss/p/6742778.html
Copyright © 2011-2022 走看看