返回固定数据

  import socket

  def request_handler(new_client_socket):

  """ 响应客户端请求的核心函数 """

  request_data = new_client_socket.recv(1024)

  # 判断客户端是否已经断开链接

  if not request_data:

  print("客户端已经断开连接!")

  # 关闭当前连接

  new_client_socket.close()

  # 退出,代码不再向后执行

  return

  # 开始拼接响应数据

  response_line = "HTTP/1.1 200 OK\r\n"

  response_header = "Server:Python-Web1.0\r\n"

  response_blank = "\r\n"

  response_content = "HelloWorld!"

  # 拼接响应头

  response_data = response_line + response_header + response_blank + response_content

  # 发送数据

  new_client_socket.send(response_data.encode())

  # 关闭socket

  new_client_socket.close()

  def main():

  # 创建套接字

  tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  # 绑定IP 和端口

  tcp_server_socket.bind(("", 8080))

  # 设置套接字为被动套接字,主要接收客户端链接

  tcp_server_socket.listen(128)

  while True:

  # 接受客户端链接

  new_client_socket, ip_port = tcp_server_socket.accept()

  print("[新客户端上线]", ip_port)

  # 相应客户端请求,发送数据给客户端

  request_handler(new_client_socket)

  if __name__ == '__main__':

  main()

  返回固定页面

  import socket

  def request_handler(new_client_socket):

  """ 响应客户端请求的核心函数 """

  request_data = new_client_socket.recv(1024)

  # 判断客户端是否已经断开链接

  if not request_data:

  print("客户端已经断开连接!")

  # 关闭当前连接

  new_client_socket.close()

  # 退出,代码不再向后执行

  return

  # 开始拼接响应数据

  response_line = "HTTP/1.1 200 OK\r\n"

  response_header = "Server:Python-Web1.0\r\n"

  response_blank = "\r\n"

  # response_content = "HelloWorld!"

  # 读取指定路径文件,并且返回

  with open("static/index.html", "rb") as file:

  # 读取文件的二进制数据

  response_content = file.read()

  # 拼接响应头

  response_data = (response_line + response_header + response_blank).encode() + response_content

  # 发送数据

  new_client_socket.send(response_data)

  # 关闭socket

  new_client_socket.close()

  def main():

  # 创建套接字

  tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  # 设置地址重用

  tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)

  # 绑定IP 和端口

  tcp_server_socket.bind(("", 8080))

  # 设置套接字为被动套接字,主要接收客户端链接

  tcp_server_socket.listen(128)

  while True:

  # 接受客户端链接

  new_client_socket, ip_port = tcp_server_socket.accept()

  print("[新客户端上线]", ip_port)

  # 相应客户端请求,发送数据给客户端

  request_handler(new_client_socket)

  if __name__ == '__main__':

  main()

  协程实现多任务服务器

  # 导入猴子补丁

  from gevent import monkey

  import socket

  import re

  import gevent

  # 让gevent 识别普通的耗时操作,并适时切换进程

  monkey.patch_all()

  def request_handler(new_client_socket):

  """ 响应客户端请求的核心函数 """

  request_data = new_client_socket.recv(1024)

  # 判断客户端是否已经断开链接

  if not request_data:

  print("客户端已经断开连接!")

  # 关闭当前连接

  new_client_socket.close()

  # 退出,代码不再向后执行

  return

  # 目的:得到 客户端 请求行

  # 对客户端请求的数据进行分析

  request_data_str = request_data.decode()

  # 根据”\r\n“ 分割请求头,得到存储每行请求数据的列表

  request_list = request_data_str.split("\r\n")

  # print(request_list)

  # 使用正则 取出 请求头中的 路径部分

  ret = re.search(r"\s(.*)\s", request_list[0])

  if not ret:

  print("用户请求报文格式错误!")

  new_client_socket.close()

  return

  # 得到路径

  path_info = ret.group(1)

  print("接收到用户请求:", path_info)

  # 设置默认请求页面为 index.html

  if path_info == "/":

  path_info = "/index.html"

  response_header = "Server:Python-Web1.0\r\n"

  response_blank = "\r\n"

  try:

  # 读取指定路径文件,并且返回

  with open("static"+path_info, "rb") as file:

  # 读取文件的二进制数据

  response_content = file.read()

  except Exception as e:

  # 开始拼接响应数据

  response_line = "HTTP/1.1 404 Not Found\r\n"

  response_content = "Error !!! %s" % str(e)

  response_content = response_content.encode()

  else:

  # 开始拼接响应数据

  response_line = "HTTP/1.1 200 OK\r\n"

  # 拼接响应头

  response_data = (response_line + response_header + response_blank).encode() + response_content

  # 发送数据

  new_client_socket.send(response_data)

  # 关闭socket

  new_client_socket.close()

  def main():

  # 创建套接字

  tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  # 设置地址重用

  tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)

  # 绑定IP 和端口

  tcp_server_socket.bind(("", 8080))

  # 设置套接字为被动套接字,主要接收客户端链接

  tcp_server_socket.listen(128)

  while True:

  # 接受客户端链接

  new_client_socket, ip_port = tcp_server_socket.accept()

  print("[新客户端上线]", ip_port)

  # 相应客户端请求,发送数据给客户端

  # request_handler(new_client_socket)

  # 使用gevent协程处理客户端请求

  g1 = gevent.spawn(request_handler, new_client_socket)

  # 因为服务器一直在while True 不会退出,所以此处不用join一次

  # g1.join()无锡人流哪家好 http://www.wxbhffk.com/

  if __name__ == '__main__':

  main()

  面向对象封装

  # 导入模块

  import socket

  import re

  import gevent

  from gevent import monkey

  # recv() accept() time.sleep()

  monkey.patch_all()

  class HttpServer(object):

  def __init__(self):

  # 构建Tcp服务器

  # 1、创建tcp的socket

  tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  # 设置地址重用

  tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)

  # 2、绑定ip和端口

  tcp_server_socket.bind(("", 8080))

  # 3、把套接字由主动设置为被动,套接字只能用于建立连接

  tcp_server_socket.listen(128)

  self.tcp_server_socket = tcp_server_socket

  def start(self):

  # 改成 while True 的目的是,让服务器端一直接收客户端请求

  while True:

  # 4、等待接受客户端连接

  new_client_socket, ip_port = self.tcp_server_socket.accept()

  print("[新客户端来了]", ip_port)

  # 5、开始进行通信,响应客户端的请求

  # request_handler(new_client_socket)

  # 使用gevent 实现多任务

  g1 = gevent.spawn(self.request_handler, new_client_socket)

  @staticmethod

  def request_handler(new_client_socket):

  """完成对客户端的响应"""

  # 1、接受客户端发送的数据

  request_data = new_client_socket.recv(1024)

  # 2、判断数据是否为空,如果为空给出提示,程序退出

  if not request_data:

  print("客户端已断开连接!")

  new_client_socket.close()

  return

  # 返回指定页面

  # 1)、获取请求报文

  request_data_str = request_data.decode()

  # 2)、获取请求行

  # 把请求报文用 \r\n 分割,得到一个列表,列表的每一项保存的是报文的每个协议项

  request_list = request_data_str.split("\r\n")

  # 3)、解析请求行中的路径部分

  ret = re.search(r"\s(.*)\s", request_list[0])

  if not ret:

  print("用户请求报文格式错误,请重试!")

  new_client_socket.close()

  return

  # 获取请求报文路径

  path_info = ret.group(1)

  # 设置默认的首页为 index.html

  if path_info == "/":

  path_info = "/index.html"

  print("正在请求:", path_info)

  # 3、拼接响应数据

  # 3.1 响应行

  response_line = "HTTP/1.1 200 OK\r\n"

  # 3.2 响应头

  response_header = "Server:PythonWeb v1.0\r\n"

  # 3.3 空行

  response_blank = "\r\n"

  # 3.4 响应的内容

  # response_content = "HelloWorld!"

  # 客户端发请求,服务器段返回 指定的页面 static/index.html

  # 1) 打开文件 以读的方式打开

  try:

  with open("./static"+path_info, "rb") as file:

  # 2) 读取文件内容

  response_content = file.read()

  except Exception as e:

  # 请求页面不存在,需要做两件事情:1)服务器要捕获这个异常,否则服务器端就挂了 2)给客户单响应 没有找到请求页面

  response_line = "HTTP/1.1 404 Not Found\r\n"

  # 如果出错,设置响应的内容为 Error 信息

  response_content = "Error!!!~ %s " % str(e)

  # 编码

  response_content = response_content.encode()

  # 4、拼接响应数据,并且发送给客户端

  response_data = (response_line + response_header + response_blank).encode() + response_content

  new_client_socket.send(response_data)

  # 5、关闭套接字

  new_client_socket.close()

  def main():

  # 实例化对象

  httpserver = HttpServer()

  # 调用对象方法

  httpserver.start()

  # 定义程序主入口

  if __name__ == '__main__':

  main()

python高级编程之 web静态服务器的更多相关文章

  1. Python Flask高级编程之从0到1开发《鱼书》精品项目 ☝☝☝

    Python Flask高级编程之从0到1开发<鱼书>精品项目 ☝☝☝ 一 .安装环境我们使用 flask web框架,并用 sqlalchemy来做数据库映射,并使用 migrate做数 ...

  2. Python Flask高级编程之从0到1开发《鱼书》精品项目 ✍✍✍

    Python Flask高级编程之从0到1开发<鱼书>精品项目  一 .安装环境我们使用 flask web框架,并用 sqlalchemy来做数据库映射,并使用 migrate做数据迁移 ...

  3. Python Flask高级编程之RESTFul API前后端分离精讲 (网盘免费分享)

    Python Flask高级编程之RESTFul API前后端分离精讲 (免费分享)  点击链接或搜索QQ号直接加群获取其它资料: 链接:https://pan.baidu.com/s/12eKrJK ...

  4. Python Flask高级编程之从0到1开发《鱼书》精品项目

    Python Flask高级编程之从0到1开发<鱼书>精品项目     整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感 ...

  5. python并发编程之multiprocessing进程(二)

    python的multiprocessing模块是用来创建多进程的,下面对multiprocessing总结一下使用记录. 系列文章 python并发编程之threading线程(一) python并 ...

  6. Web静态服务器

    Web静态服务器 编程微刊 Web静态服务器-1-显示固定的页面 #coding=utf-8 import socket def handle_client(client_socket): " ...

  7. Python网络编程之TCP套接字简单用法示例

    Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...

  8. Nodejs实现web静态服务器对多媒体文件的支持

    前几天,一个同事说他写的web静态服务器不支持音视频的播放,现简单实现一下. 原理:实现http1.1协议的range部分. 其实这一点都不神秘,我们常用的下载工具,如迅雷,下载很快,还支持断点续传, ...

  9. Python 多进程编程之multiprocessing--Pool

    Python 多进程编程之multiprocessing--Pool ----当需要创建的子进程数量不多的时候,可以直接利用multiprocessing 中的Process 动态生成多个进程, -- ...

随机推荐

  1. JDOJ 1140: 完数

    JDOJ 1140: 完数 题目传送门 Description 一个数如果恰好等于它的因子之和,这个数就称为"完数". 例如,6的因子为1.2.3,而6=1+2+3,因此6是&qu ...

  2. serialize()和new FormData()的区别

    serialize()和FormData对象都可将表单数据序列化,后通过ajax异步提交 ,序列化表单就是将form表单中所有name属性序列化成KEY-VALUE的形式,提交到后台,后台以对象相应的 ...

  3. 1. vue 的安装

    兼容性 Vue 不支持 IE8 及以下版本,因为 Vue 使用了 IE8 无法模拟的 ECMAScript 5 特性.但它支持所有兼容 ECMAScript 5 的浏览器. 安装: 1.直接用 < ...

  4. Ant Design的Form

    Ant Design的Form 使用onFieldsChange时不要与 mapPropsToFields一起使用,将导致表单校验等失效

  5. java 8 学习二(Lambda表达式)

    粗略的概括:lambda表达式主要用来实现“函数接口”中“唯一”的抽象方法用的. 他的特殊版有 方法引用,构造函数引用,用对应的接口实例接收即可. 可以把Lambda表达式理解为简洁地表示可传递的匿名 ...

  6. Ubuntu下Thunderbird设置

    安装 apt-get install thunderbird(software) thunderbird-locale-zh-cn(汉化包) 添加最小化插件 附加组件里安装 MinimizeToTra ...

  7. 网络协议 17 - HTTPDNS

    全球统一的 DNS 是很权威,但是我们都知道“适合自己的,才是最好的”.很多时候,标准统一化的 DNS 并不能满足我们定制的需求,这个时候就需要 HTTPDNS 了.     上一节我们知道了 DNS ...

  8. 洛谷P1531 I Hate It题解

    题目背景 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感. 题目描述 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的 ...

  9. Java 集合系列之五:Map基本操作

    1. Java Map 1. Java Map 重要观点 Java Map接口是Java Collections Framework的成员.但是它不是Collection 将键映射到值的对象.一个映射 ...

  10. Apollo配置中心--安装使用-docker

    官网:https://github.com/ctripcorp/apollo Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推 ...