Python实现简易版的Web服务器(推荐)

下面给大家介绍python实现简易版的web服务器,具体内容详情大家通过本文学习吧!

1、请自行了解HTTP协议

http://www.jb51.net/article/133883.htm(点击跳转)

2、创建Socket服务,监听指定IP和端口

3、以阻塞方式等待客户端连接

4、读取客户端请求数据并进行解析

5、准备服务器运行上下文

6、处理客户端请求数据

7、根据用户请求路径读取文件

8、返回响应结果给客户端

9、程序入口

10、目录结构

11、运行

python wsgiserver.py app:run

12、源码

a.wsgiserver.py文件

#encoding:utf-8
import socket
import StringIO
import sys
import logging
from datetime import datetime
logger = logging.getLogger(__name__)
class WSGIServer(object):
 address_family = socket.AF_INET
 socket_type = socket.SOCK_STREAM
 request_queue_size = 30
 recv_size = 1024
 def __init__(self, server_address):
  self._listen_socket = _listen_socket = socket.socket(self.address_family,
               self.socket_type)  _listen_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,1)  _listen_socket.bind(server_address)
  _listen_socket.listen(self.request_queue_size)
  _host, _port = _listen_socket.getsockname()
  self._server_name = socket.getfqdn(_host)
  self._server_port = _port
  self._headers_set = []
  self._application = None
  self._client = None
  self._request_data = None
  self._request_method = None
  self._path = None
  self._request_version = None
  self._start_response = None
 def set_application(self, application):
  self._application = application
 def server_forever(self):
  _listen_socket = self._listen_socket
  logger.info('listen on %s:%s', self._server_name, self._server_port)  while 1:
   try:
    self._client, _addr = _listen_socket.accept()
    self._handle_request(_addr)
   except KeyboardInterrupt as e:
    logger.info('interrupt')
    break
   except BaseException as e:
    logger.error(e)
 def _handle_request(self, client_addr):
  self._request_data = _request_data = self._client.recv(self.recv_size)
  self._parse_request_data(_request_data)
  _env = self._get_environment(client_addr)
  _result = self._application(_env, self.start_response)
  self._finish_response(_result)
 def _parse_request_data(self, request_data):
  _request_line = str(request_data.splitlines()[0]).rstrip('\r\n')
  (self._request_method, self._path, self._request_version) = _request_line.split()
 def _get_environment(self, client_addr):
  _env = {}
  _env['wsgi.version'] = (1, 0)
  _env['wsgi.url_scheme'] = 'http'
  _env['wsgi.input'] = StringIO.StringIO(self._request_data)    _env['wsgi.errors'] = sys.stderr
  _env['wsgi.multithread'] = False
  _env['wsgi.multiprocess'] = False
  _env['wsgi.run_once'] = False
  _env['REQUEST_METHOD'] = self._request_method.upper()
  _env['PATH_INFO'] = self._path
  _env['SERVER_NAME'] = self._server_name
  _env['SERVER_PORT'] = self._server_port
  _env['HTTP_CLIENT_IP'] = client_addr[0]
  logger.info('%s %s %s %s', _env['HTTP_CLIENT_IP'], datetime.now().strftime('%Y-%m-%d %H:%M:%S'), _env['REQUEST_METHOD'], _env['PATH_INFO'])
  return _env
 def start_response(self, status, response_headers, exc_info=None):   _server_headers = [
   ('Date', 'Sun, 7 Jun 2015 23:07:04 GMT'),
   ('Server', 'WSGIServer 0.1')
   ]
  self._headers_set = [status, response_headers + _server_headers]
 def _finish_response(self, result):
  _status, _response_headers = self._headers_set
  _response = 'HTTP/1.1 {status}\r\n'.format(status=_status)    for _header in _response_headers:
  _response += '{0}:{1}\r\n'.format(*_header)
  _response += '\r\n'
  for _data in result:
   _response += _data
  self._client.sendall(_response)
  self._client.close()
def make_server(server_address, application):
 server = WSGIServer(server_address)
 server.set_application(application)
 return server
if __name__ == '__main__':
 logging.basicConfig(level=logging.DEBUG)
 server_addr= ('0.0.0.0', 43002)
 app_path = sys.argv[1]
 module, application = app_path.split(':')
 module = __import__(module)
 application = getattr(module, application)
 httpd = make_server(server_addr, application)
 httpd.server_forever()

b.app.py文件

#encoding:utf-8
import os
class PageNotFoundException(BaseException):
 pass
def render(filename, dirname='html'):
 _path = os.path.join(dirname, filename)
 if os.path.exists(_path):
  with open(_path, 'rb') as handler:
   return handler.read()
 raise PageNotFoundException('file not found:%s' % _path)
def run(env, start_response):
 _path = env.get('PATH_INFO')
 response = ''
 try:
  _path = 'index.html' if _path == '/' else _path[1:]
  if _path.endswith('.css'):
   start_response('200 OK', [('Content-Type', 'text/css')])
  elif _path.endswith('.js'):
   start_response('200 OK', [('Content-Type', 'text/javascript')]
  elif _path.endswith('.html'):
   start_response('200 OK', [('Content-Type', 'text/html')])
  else:
   start_response('200 OK', [('Content-Type', 'text/plain'), ('Content-Disposition', 'attachment; filename=%s' % os.path.basename(_path))])
  response = render(_path)
 except PageNotFoundException as e:
  response = render('404.html')
 return [response, '\r\n']

总结

以上所述是小编给大家介绍的Python实现简易版的Web服务器,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

您可能感兴趣的文章:

  • Python编程实现的简单Web服务器示例
  • Python命令启动Web服务器实例详解
  • python制作websocket服务器实例分享
  • python创建一个最简单http webserver服务器的方法
  • python快速建立超简单的web服务器的实现方法
(0)

相关推荐

  • python快速建立超简单的web服务器的实现方法

    作为临时测试用python命令来搭建web测试是最好不过的选择了: CD切换到当前目录只需要一句python命令就迅速搭建好了简单的web服务器,python linux自带又无需额外配置安装感觉还是很好用的: python开启web服务器命令 python -m SimpleHTTPServer 8080 端口号可以任意指定一个没有被占用的端口,但必须能通过防火墙: 执行完上面命令后,直接输入IP地址加端口号就行了 http://:端口号/路径  如:http://192.168.0.12/8

  • python制作websocket服务器实例分享

    一.开始的话 使用python简单的实现websocket服务器,可以在浏览器上实时显示远程服务器的日志信息. 之前做了一个web版的发布系统,但没实现在线看日志,每次发布版本后,都需要登录到服务器上查看日志,非常麻烦,为了偷懒,能在页面点几下按钮完成工作,这几天查找了这方面的资料,实现了这个功能,瞬间觉的看日志什么的,太方便了,以后也可以给开发们查日志,再也不用麻烦运维了,废话少说,先看效果吧. 二.代码 需求:在web上弹出iframe层来实时显示远程服务器的日志,点击stop按钮,停止日志

  • Python编程实现的简单Web服务器示例

    本文实例讲述了Python编程实现的简单Web服务器.分享给大家供大家参考,具体如下: 最近有个需求,就是要创建一个简到要多简单就有多简单的web服务器,目的就是需要一个后台进程用来接收请求然后处理并返回结果,因此就想到了使用Python来实现. 首先创建一个myapp.py文件,其中定义了一个方法,所有的请求都会经过此方法,可以在此方法里处理传递的url和参数,并返回结果. def myapp(environ, start_response): status = '200 OK' header

  • Python命令启动Web服务器实例详解

    Python命令启动Web服务器实例详解 利用Python自带的包可以建立简单的web服务器.在DOS里cd到准备做服务器根目录的路径下,输入命令: python -m Web服务器模块 [端口号,默认8000] 例如: python -m SimpleHTTPServer 8080 然后就可以在浏览器中输入 http://localhost:端口号/路径 来访问服务器资源. 例如: http://localhost:8080/index.htm(当然index.htm文件得自己创建) 其他机器

  • python创建一个最简单http webserver服务器的方法

    本文实例讲述了python创建一个最简单http webserver服务器的方法.分享给大家供大家参考.具体实现方法如下: import sys import BaseHTTPServer from SimpleHTTPServer import SimpleHTTPRequestHandler Handler = SimpleHTTPRequestHandler Server = BaseHTTPServer.HTTPServer Protocol = "HTTP/1.0" if s

  • Python实现简易版的Web服务器(推荐)

    下面给大家介绍python实现简易版的web服务器,具体内容详情大家通过本文学习吧! 1.请自行了解HTTP协议 http://www.jb51.net/article/133883.htm(点击跳转) 2.创建Socket服务,监听指定IP和端口 3.以阻塞方式等待客户端连接 4.读取客户端请求数据并进行解析 5.准备服务器运行上下文 6.处理客户端请求数据 7.根据用户请求路径读取文件 8.返回响应结果给客户端 9.程序入口 10.目录结构 11.运行 python wsgiserver.p

  • Python制作简易版2048小游戏

    目录 目标效果 设计开始 步骤一 步骤二 步骤三 步骤四 步骤五 今天我们来动手实现一款2048小游戏.这款游戏的精髓就玩家能够在于通过滑动屏幕合并相同数字,直到不能再合并为止.玩法可以说是非常的简单,但挑战性也是十足的.话不多说,让我们从0开始实现! 目标效果 大致要实现的效果如下: 设计开始 首先简单分析一下游戏的逻辑: 输入移动方向,游戏内所有方块都朝指定方向移动 同方向移动的方块,数字相同则合并,然后生成一个合并的方块 合并后生成新的方块,无法生成新方块时游戏结束 用一系列的颜色来区分不

  • python探索之BaseHTTPServer-实现Web服务器介绍

    在Python探索之SocketServer详解中我们介绍了Python标准库中的SocketServer模块,了解了要实现网络通信服务,就要构建一个服务器类和请求处理类.同时,该模块还为我们创建了不同的服务器类和请求处理类. 1.服务器类 BaseServer TCPServer(BaseServer) UDPServer(TCPServer) UnixStreamServer UnixDatagramServer 2.请求处理类 BaseRequestHandler StreamReques

  • 利用python实现简易版的贪吃蛇游戏(面向python小白)

    引言 作为python 小白,总是觉得自己要做好百分之二百的准备,才能开始写程序.以至于常常整天在那看各种语法教程,学了几个月还是只会print('hello world'). 这样做效率太低,正确的做法,是到身边找问题,然后编程实现.比如说,我学了高等数学,我是不是应该考虑下如何去用编程实现求导或者积分操作,如果想不出怎么办,是不是应该 baidu 一下,别人是如何实现数值积分或是符号积分的.我们每天买东西都要用到加减甚至乘除,那么我是否能编写个简单的计算器,如果命令行太丑的话,我是否能够快速

  • Python制作简易版小工具之计算天数的实现思路

    需求 给定一个日期,格式如 "2020-2-12",计算出这个日期是 2020 年的第几天? 实现思路 使用 tkinter 和 tkinter.ttk 对界面进行布置: 使用 calendar 计算天数: 规范输入日期的格式: 对月份,天数进行逻辑判断: 输入错误抛出异常提示. 代码实现 # -*- coding: utf-8 -*- ''' @File: calc_day_v2.py @Time: 2020/02/12 20:33:22 @Author: 大梦三千秋 @Contac

  • Python 实现一个简单的web服务器

    import re import socket def service_cilent(new_socket): request = new_socket.recv(1024).decode("utf-8") # Python splitlines() 按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符. request_lines = request.splitlin

  • Python模拟简易版淘宝客服机器人的示例代码

    对于用Python制作一个简易版的淘宝客服机器人,大概思路是:首先从数据库中用sql语句获取相关数据信息并将其封装成函数,然后定义机器问答的主体函数,对于问题的识别可以利用正则表达式来进行分析,结合现实情况选择答案,最后在执行时可以设置循环语句,并且在每次回答间隔1s方便进一步做并发处理作为未来优化方向.从以下几个方面分别实现: 1.货物信息储存到MySQL数据库中 在现实情景中,购物信息的数据一般会储存到数据库中,方便在进行问答时才访问数据库获取相关信息,可以用Python中的sqlalche

  • 基于python制作简易版学生信息管理系统

    一.前言 本篇博客对于文件操作.字典.列表.匿名函数以及sort()等内置函数进行了系统的整理操作,以设计一个学生信息管理系统的形式展示,具体概念方法等会在代码后进行分析讲述,请读者仔细分析每一处解析,对于基础巩固将会有很大的帮助,其中还有每一块代码的设计思路图,逻辑分析会有一定的提升. 二.需求分析 本程序需要用到os模板首先导入,并命名要存储信息的文件 import os File_Object_Name = 'Student_Inforation.txt' 三.主函数 def Main()

  • 教你用Python实现简易版学生信息管理系统(含源码)

    一.项目分析 1.首先定义一个存放基础学生信息列表 格式:list = [{学号:姓名,年龄:num,成绩:num },{--}] student1 = [\ {1:"jam",'age':17,'socer':99}, {2:'kol','age':18,'socer':89}, {3:'avlir','age':19,'socer':100}] 2.先搭建框架(主函数main()) if __name__ == '__main__': while True: menu() key

随机推荐