设为首页 收藏本站
查看: 1373|回复: 0

[经验分享] Python简单实现Web服务器

[复制链接]

尚未签到

发表于 2018-8-6 13:02:58 | 显示全部楼层 |阅读模式
import socket  import re
  import gevent
  from gevent import monkey
  import sys
  monkey.patch_all()# 识别等待时间,让协程切换
  class HTTPServer(object):
  def __init__(self, port):
  """完成实例对象的初始化操作"""
  # 创建套接字,指定IP和数据报类型
  server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  # 设置端口复用
  server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
  # 设置绑定,监听,接收链接
  server_socket.bind(("", 4433))
  server_socket.listen(128)
  # 套接字对象的引用
  self.server_socket = server_socket
  # 套接字的链接等待
  def start(self):
  # 服务器是面向多客户,循环接收客户端请求链接
  while True:
  client_socket, client_address = self.server_socket.accept()
  print("服务端接收到来自%s的链接请求" % str(client_address))
  # 处理链接请求
  # client_handler(client_socket)
  # 创建协程实现多任务
  g1 = gevent.spawn(self.client_handler, client_socket)
  # 保持主进程存活(阻塞主进程,等待协程g1执行完再退出)
  #g1.join()
  def client_handler(self, client_socket):
  '''接收客户端链接请求,响应对应的的数据'''
  # 接收数据
  request_data = client_socket.recv(4096)
  # 判断是否接收到数据
  if not request_data:
  print("客户端已经断开链接")
  client_socket.close()
  return
  # 对接收到的客户端请求数据进行解码
  request_str_data = request_data.decode()
  #对请求的报文进行分割,分割出一个请求各行数列表
  data_list = request_str_data.split("\r\n")
  # 拿到请求行数据,请求行数据是列表第0个元素
  request_line = data_list[0]
  # 通过正则匹配到我们请求的文件路径
  result = re.match(r"\w+\s+(\S+)", request_line)
  # 判断匹配的请求文件路径是否存在
  if not result:
  print("请求路径不存在")
  client_socket.close()
  return
  path_info = result.group(1)
  print("用户请求信息%s" % str(path_info))
  # 设置请求域名默认跳转首页
  if path_info == "/":
  # 指定首页地址
  path_info = "/index.html"
  # 响应头
  response_header = "Server: PWS1.0\r\n"
  try:
  # 响应体,打开客户端请求的数据
  with open("./html" + path_info, "rb") as file:
  file_data = file.read()
  except Exception as e:
  # 构造请求错误响应报文
  response_line = "HTTP/1.1 404 NOT FOUND\r\n"
  response_body = "EROOR!!! %s".center(800) %(e)
  # 拼接响应报文
  response_data = response_line + response_header + "\r\n" + response_body
  # 给客户端发送响应报文
  client_socket.send(response_data.encode())
  else:
  # 构造请求成功响应报文
  response_line = "HTTP/1.1 200 OK\r\n"
  response_body = file_data
  response_data = (response_line + response_header + "\r\n").encode() + response_body
  # 发送响应报文
  client_socket.send(response_data)
  finally:
  # 关闭套接字
  client_socket.close()
  # 创建主函数,定义套接字,设置命令行自定义端口运行
  def main():
  # 判断输入命令参数是否符合要求
  if len(sys.argv) != 2:
  print("正确打开方式: python3 运行程序.py 端口号")
  return
  if not sys.argv[1].isdigit():
  print("正确打开方式: python3 运行程序.py 端口号")
  return
  port = int(sys.argv[1])
  http_server = HTTPServer(port)
  http_server.start()
  # 程序入口
  if __name__ == '__main__':
  main()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-547674-1-1.html 上篇帖子: Python3的各进制间的转换 下篇帖子: Python 常用模块续
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表