使用浏览器访问python写的服务器程序
代码如下所示:
import socket import re import multiprocessing def service_client(client_socket): data = client_socket.recv(1024) recv_data=data.decode("utf-8") print(recv_data) #GET /index.html HTTP/1.1 ret=re.match(r"[^/]+ /([\S]+\s|\s)",recv_data) file_n="index.html" if ret: if ret.group(1)!=" ": print(ret.group(1)) file_n=ret.group(1) else: print("代码有误!") try: with open(file_n,"rb") as f: content=f.read() f.close() except Exception as r: print(r) content = "<h1>file not found<\h1>".encode("utf-8") header="HTTP/1.1 200 OK\r\n" empty="\r\n" response=(header+empty).encode('utf-8') client_socket.send(response) client_socket.send(content) client_socket.close() print("client_socket.close()已调用") def main(): tcp_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM) tcp_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) local_addr=("127.0.0.1",7788) tcp_socket.bind(local_addr) tcp_socket.listen(128) while True: client_socket, client_addr = tcp_socket.accept() p=multiprocessing.Process(target=service_client,args=(client_socket,)) p.start() # p.join() tcp_socket.close() if __name__ == "__main__": main()
注意:
1.开始的时候file_n没有先定义,结果就报错:local variable ‘file_n' referenced before assignment
2.正则表达式一定要先验证筛取的内容是否正确。
3.要获取程序同级文件夹中文件夹的文件,相对路基为“文件夹名/文件名”
4.tcp_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) 要加不然容易出现“address already in use"之类的故障
总结
以上所述是小编给大家介绍的使用浏览器访问python写的服务器程序,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
相关文章
使用Python的Flask框架构建大型Web应用程序的结构示例
虽说Flask是一个以轻量级著称的框架,但也为大型Web应用提供了诸如单元测试与数据库迁移等许多便利的功能,这里我们来看一下使用Python的Flask框架构建大型Web应用程序的结构示例:2016-06-06Python Pandas 对列/行进行选择,增加,删除操作
这篇文章主要介绍了Python Pandas 对列/行进行选择,增加,删除操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-05-05Python argparse模块实现解析命令行参数方法详解
argparse 是 python 自带的命令行参数解析包,可以用来方便的服务命令行参数。本文将通过示例和大家详细讲讲argparse的使用,需要的可以参考一下2022-09-09
最新评论