web静态,动态服务器

web静态服务器

服务端:


1.1.1显示固定的页面

参考代码:

import socket

from multiprocessing import Process

def handleClient(clientSocket):

'用一个新的进程,为一个客户端进行服务'

recvData = clientSocket.recv(2014)

requestHeaderLines = recvData.splitlines()

for line in requestHeaderLines:

print(line.decode('utf-8'))

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

responseHeaderLines += "Server:laowang\r\n"

responseHeaderLines += "\r\n"

responseBody = "hello world"

response = responseHeaderLines + responseBody

clientSocket.send(bytes(response,'gbk'))

clientSocket.close()

def main():

'作为程序的主控制入口'

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

serverSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

serverSocket.bind(("", 8000))

serverSocket.listen(10)

while True:

clientSocket,clientAddr = serverSocket.accept()

clientP = Process(target = handleClient, args = (clientSocket,))

clientP.start()

clientSocket.close()

if __name__ == '__main__':

main()

客户端浏览器:


1.1.1显示需要的页面

参考代码:

import socket

import re

from multiprocessing import Process

#设置静态文件根目录

HTML_ROOT_DIR = "./html"

def handle_client(client_socket):

"""处理客户端请求"""

#获取客户端请求数据

request_data = client_socket.recv(1024)

print("request data:", request_data)

request_lines = request_data.splitlines()

for line in request_lines:

print(line)

#解析请求报文

# 'GET / HTTP/1.1'

request_start_line = request_lines[0].decode('utf-8')

#提取用户请求的文件名

file_name = re.match(r"\w+ +(/[^ ]*) ", request_start_line).group(1)

if "/" == file_name:

file_name = "/index.html"

#打开文件,读取内容

try:

file = None

file = open(HTML_ROOT_DIR + file_name, "rb")

file_data = file.read()

#构造响应数据

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

response_headers = "Server: My server\r\n"

response_body = file_data.decode("utf-8")

except FileNotFoundError:

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

response_headers = "Server: My server\r\n"

response_body = "The file is not found!"

finally:

if file and (not file.closed):

file.close()

response = response_start_line + response_headers + "\r\n" + response_body

print("response data:", response)

#向客户端返回响应数据

client_socket.send(bytes(response, "utf-8"))

#关闭客户端连接

client_socket.close()

def main():

'作为程序的主控制入口'

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

server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

server_socket.bind(("", 8000))

server_socket.listen(128)

while True:

client_socket, client_address = server_socket.accept()

# print("[%s, %s]用户连接上了" % (client_address[0],client_address[1]))

print("[%s, %s]用户连接上了" % client_address)

handle_client_process = Process(target=handle_client, args=(client_socket,))

handle_client_process.start()

client_socket.close()

if __name__ == "__main__":

main()

1.1.1使用类

import socket

import re

from multiprocessing import Process

#设置静态文件根目录

HTML_ROOT_DIR = "./html"

class HTTPServer(object):

""""""

def __init__(self):

self.server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

self.server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

def start(self):

self.server_socket.listen(128)

while True:

client_socket, client_address = self.server_socket.accept()

# print("[%s, %s]用户连接上了" % (client_address[0],client_address[1]))

print("[%s, %s]用户连接上了" % client_address)

handle_client_process = Process(target=self.handle_client, args=(client_socket,))

handle_client_process.start()

client_socket.close()

def handle_client(self, client_socket):

"""处理客户端请求"""

#获取客户端请求数据

request_data = client_socket.recv(1024)

print("request data:", request_data)

request_lines = request_data.splitlines()

for line in request_lines:

print(line)

#解析请求报文

# 'GET / HTTP/1.1'

request_start_line = request_lines[0]

#提取用户请求的文件名

print("*" * 10)

print(request_start_line.decode("utf-8"))

file_name = re.match(r"\w+ +(/[^ ]*) ", request_start_line.decode("utf-8")).group(1)

if "/" == file_name:

file_name = "/index.html"

#打开文件,读取内容

try:

file = None

file = open(HTML_ROOT_DIR + file_name, "rb")

file_data = file.read()

#构造响应数据

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

response_headers = "Server: My server\r\n"

response_body = file_data.decode("utf-8")

except FileNotFoundError:

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

response_headers = "Server: My server\r\n"

response_body = "The file is not found!"

finally:

if file and (not file.closed):

file.close()

response = response_start_line + response_headers + "\r\n" + response_body

print("response data:", response)

#向客户端返回响应数据

client_socket.send(bytes(response, "utf-8"))

#关闭客户端连接

client_socket.close()

def bind(self, port):

self.server_socket.bind(("", port))

def main():

http_server = HTTPServer()

# http_server.set_port

http_server.bind(8000)

http_server.start()

if __name__ == "__main__":

main()

1.1Web服务器动态资源请求

1.1.1浏览器请求动态页面过程

1.1.1WSGI

怎么在你刚建立的Web服务器上运行一个Django应用和Flask应用,如何不做任何改变而适应不同的web架构呢?

在以前,选择Python web架构会受制于可用的web服务器,反之亦然。如果架构和服务器可以协同工作,那就好了:

但有可能面对(或者曾有过)下面的问题,当要把一个服务器和一个架构结合起来时,却发现他们不是被设计成协同工作的:

那么,怎么可以不修改服务器和架构代码而确保可以在多个架构下运行web服务器呢?答案就是Python Web Server Gateway Interface (或简称WSGI,读作“wizgy”)。

WSGI允许开发者将选择web框架和web服务器分开。可以混合匹配web服务器和web框架,选择一个适合的配对。比如,可以在Gunicorn或者Nginx/uWSGI或者Waitress上运行Django, Flask,或Pyramid。真正的混合匹配,得益于WSGI同时支持服务器和架构:

web服务器必须具备WSGI接口,所有的现代Python Web框架都已具备WSGI接口,它让你不对代码作修改就能使服务器和特点的web框架协同工作。

WSGI由web服务器支持,而web框架允许你选择适合自己的配对,但它同样对于服务器和框架开发者提供便利使他们可以专注于自己偏爱的领域和专长而不至于相互牵制。其他语言也有类似接口:java有Servlet API,Ruby有Rack。

1.1.1定义WSGI接口

WSGI接口定义非常简单,它只要求Web开发者实现一个函数,就可以响应HTTP请求。我们来看一个最简单的Web版本的“Hello World!”:

defapplication(environ, start_response):

start_response('200 OK', [('Content-Type','text/html')])

return'Hello World!'

上面的application()函数就是符合WSGI标准的一个HTTP处理函数,它接收两个参数:

·environ:一个包含所有HTTP请求信息的dict对象;

·start_response:一个发送HTTP响应的函数。

整个application()函数本身没有涉及到任何解析HTTP的部分,也就是说,把底层web服务器解析部分和应用程序逻辑部分进行了分离,这样开发者就可以专心做一个领域了

不过,等等,这个application()函数怎么调用?如果我们自己调用,两个参数environ和start_response我们没法提供,返回的str也没法发给浏览器。

所以application()函数必须由WSGI服务器来调用。有很多符合WSGI规范的服务器。而我们此时的web服务器项目的目的就是做一个极可能解析静态网页还可以解析动态网页的服务器

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,475评论 4 372
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,744评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,101评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,732评论 0 221
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,141评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,049评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,188评论 2 320
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,965评论 0 213
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,716评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,867评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,341评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,663评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,376评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,200评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,990评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,179评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,979评论 2 279

推荐阅读更多精彩内容

  • 1.使用类 import socket import re from multiprocessing import...
    TENG书阅读 370评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,111评论 18 139
  • 1.1 回顾网络编程 1.2 http协议介绍 HTTP是Hyper Text Transfer Protocol...
    TENG书阅读 491评论 0 0
  • =========================================================...
    lavor阅读 3,455评论 0 5
  • 工人是社会中很重要的群体,他们用自己的智慧与汗水生产着老百姓各种生活必需品。小到牙膏牙刷,大到飞机火箭,都是工人辛...
    耕耘生活阅读 551评论 2 9