Python 开发Web静态服务器 - 返回固定值:胖子老板,来包槟榔

时间:2022-06-22
本文章向大家介绍Python 开发Web静态服务器 - 返回固定值:胖子老板,来包槟榔,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

仅供学习,转载请注明出处

使用网络调试器模拟http服务器

上一个章节讲述了关于http的基本内容。那么下面使用NetAssist来模拟http访问的以及数据返回。

首先NetAssist开启TCP端口服务:

使用浏览器访问TCP服务:

从上面的操作过程来看,基本上可以理解了web服务器其实只要简单使用TCP进行对应数据的返回,就可以完成功能。

使用TCP服务,开发Web静态服务器-返回:fat boss,give me binlang!

首先编写服务的第一步功能,就是接受浏览器的请求数据并打印出来

[root@server01 web]# vim server.py 

#coding=utf-8
from socket import *

def handle_client(client_socket):
    """为一个客户端服务"""
    # 接收对方发送的数据
    recv_data = client_socket.recv(1024).decode("utf-8") #  1024表示本次接收的最大字节数
    # 打印从客户端发送过来的数据内容
    print("client_recv:",recv_data)

def main():
   # 创建套接字
   server_socket = socket(AF_INET, SOCK_STREAM)
   # 设置当服务器先close 即服务器端4次挥手之后资源能够立即释放,这样就保证了,下次运行程序时 可以立即绑定7788端口
   server_socket.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
   # 设置服务端提供服务的端口号
   server_socket.bind(('', 7788))
   # 使用socket创建的套接字默认的属性是主动的,使用listen将其改为被动,用来监听连接
   server_socket.listen(128) #最多可以监听128个连接
   # 开启while循环处理访问过来的请求 
   while True:
      # 如果有新的客户端来链接服务端,那么就产生一个新的套接字专门为这个客户端服务
      # client_socket用来为这个客户端服务
      # server_socket就可以省下来专门等待其他新的客户端连接while True:
      client_socket, clientAddr = server_socket.accept()
      handle_client(client_socket)

if __name__ == "__main__":
   main()

运行执行如下:

好了,从上面的结果来看,服务端已经收到了浏览器发出的GET请求。那么只要服务端返回相应HTTP数据,就可以让浏览器显示数据了。

哟,好像很厉害

编写服务端返回http数据,类似前面的网络调试器返回的数据即可

[root@server01 web]# cat server.py 
#coding=utf-8
from socket import *

def handle_client(client_socket):
    """为一个客户端服务"""
    # 接收对方发送的数据
    recv_data = client_socket.recv(1024).decode("utf-8") #  1024表示本次接收的最大字节数
    # 打印从客户端发送过来的数据内容
    #print("client_recv:",recv_data)
    request_header_lines = recv_data.splitlines()
    for line in request_header_lines:
    print(line)
     
    # 返回浏览器数据
    # 设置返回的头信息 header
    response_headers = "HTTP/1.1 200 OKrn" # 200 表示找到这个资源
    response_headers += "rn" # 空一行与body隔开
    # 设置内容body
    response_body = "<h1>fat boss<h1>rn" 
    response_body += "<h2>come on<h2>rn" 
    response_body += "<h3>binlang!!!<h3>rn" 

    # 合并返回的response数据
    response = response_headers + response_body
    
    # 返回数据给浏览器
    client_socket.send(response.encode("utf-8"))   #转码utf-8并send数据到浏览器
    client_socket.close()

def main():
   # 创建套接字
   server_socket = socket(AF_INET, SOCK_STREAM)
   # 设置当服务器先close 即服务器端4次挥手之后资源能够立即释放,这样就保证了,下次运行程序时 可以立即绑定7788端口
   server_socket.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
   # 设置服务端提供服务的端口号
   server_socket.bind(('', 7788))
   # 使用socket创建的套接字默认的属性是主动的,使用listen将其改为被动,用来监听连接
   server_socket.listen(128) #最多可以监听128个连接
   # 开启while循环处理访问过来的请求 
   while True:
      # 如果有新的客户端来链接服务端,那么就产生一个新的套接字专门为这个客户端服务
      # client_socket用来为这个客户端服务
      # server_socket就可以省下来专门等待其他新的客户端连接while True:
      client_socket, clientAddr = server_socket.accept()
      handle_client(client_socket)

if __name__ == "__main__":
   main()
[root@server01 web]# 

运行如下: