python實現靜態web服務器

這篇文章主要爲大家詳細介紹了python實現靜態web服務器,具有一定的參考價值,感興趣的小夥伴們可以參考一下

HTTP協議簡介

HTTP請求

1:瀏覽器首先向服務器發送HTTP請求,請求包括:

方法:GET還是POST,GET僅請求資源,POST會附帶用戶數據;
路徑:/full/url/path;
域名:由Host頭指定:Host: www.sina.com以及其他相關的Header;
如果是POST,那麼請求還包括一個Body,包含用戶數據

2:服務器向瀏覽器返回HTTP響應,響應包括:

響應代碼:200表示成功,3xx表示重定向,4xx表示客戶端發送的請求有錯誤,5xx表示服務器端處理時發生了錯誤;
響應類型:由Content-Type指定;
以及其他相關的Header;
通常服務器的HTTP響應會攜帶內容,也就是有一個Body,包含響應的內容,網頁的HTML源碼就在Body中。

3:如果瀏覽器還需要繼續向服務器請求其他資源,比如圖片,就再次發出HTTP請求,重複步驟1、2。

Web採用的HTTP協議採用了非常簡單的請求-響應模式,從而大大簡化了開發。當我們編寫一個頁面時,我們只需要在HTTP請求中把HTML發送出去,不需要考慮如何附帶圖片、視頻等,瀏覽器如果需要請求圖片和視頻,它會發送另一個HTTP請求,因此,一個HTTP請求只處理一個資源(此時就可以理解爲TCP協議中的短連接,每個鏈接只獲取一個資源,如需要多個就需要建立多個鏈接)

HTTP格式

每個HTTP請求和響應都遵循相同的格式,一個HTTP包含Header和Body兩部分,其中Body是可選的。
HTTP協議是一種文本協議,所以,它的格式也非常簡單。

1 HTTP GET請求的格式:

 

1

2

3

4

GET /path HTTP/1.1

 Header1: Value1

 Header2: Value2

 Header3: Value3

每個Header一行一個,換行符是\r\n。

2 HTTP POST請求的格式:

 

1

2

3

4

5

6

POST /path HTTP/1.1

 Header1: Value1

 Header2: Value2

 Header3: Value3

 

 body data goes here...

3 HTTP響應的格式:

 

1

2

3

4

5

6

200 OK

 Header1: Value1

 Header2: Value2

 Header3: Value3

 

 body data goes here...

HTTP響應如果包含body,也是通過\r\n\r\n來分隔的。
請再次注意,Body的數據類型由Content-Type頭來確定,如果是網頁,Body就是文本,如果是圖片,Body就是圖片的二進制數據。

嗨嘍:正在學習python的小夥伴或者打算學習的,可以加羣領學習資料哦:877562786

當存在Content-Encoding時,Body數據是被壓縮的,最常見的壓縮方式是gzip,所以,看到Content-Encoding: gzip時,需要將Body數據先解壓縮,才能得到真正的數據。壓縮的目的在於減少Body的大小,加快網絡傳輸。

demo:靜態web服務器

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

import socket

import re

import time

 

 

def service_client(new_socket):

 """爲這個客戶端服務"""

 

 # 1.接收瀏覽器發送過來的請求,即http請求

 # GET / HTTP/1.1

 # --------

 request = new_socket.recv(1024).decode('utf-8')

 

 # 判斷客戶端意外斷開鏈接返回空字符串

 if not request:

  # 關閉套接字並退出

  new_socket.close()

  print("==="*30)

  return

 

 # 分隔套接字

 request_lines = request.splitlines()

 print()

 print(">"*20)

 print(request_lines)

 

 file_name = ""

 ret = re.match(r"[^/]+(/[^ ]*)", request_lines[0])

 if ret:

  file_name = ret.group(1)

  if file_name == "/":

   file_name = "/index.html"

 

 # 2.返回http格式數據 給瀏覽器

 try:

  f = open("./html" + file_name, "rb")

 except:

  response = "HTTP/1.1 404 NOT FOUND\r\n"

  response += "Content-Type:text/html;charset=utf-8\r\n"

  response += "\r\n"

  response += "<h1>404 not found <br> 沒有發現所請求資源</h1>"

  response += str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))

  new_socket.send(response.encode('utf-8'))

 else:

  html_content = f.read()

  f.close()

  # 2.1準備發送給瀏覽器的數據---header

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

  response += "\r\n"

  # 2.2準備發送給瀏覽器的數據 ---body

  # 將response header發送給瀏覽器

  new_socket.send(response.encode("utf-8"))

  # 將response body發送給瀏覽器

  new_socket.send(html_content)

 

 # 關閉套接字

 new_socket.close()

 

 

def main():

 """用來完成整體的控制"""

 # 1.創建套接字

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

 # 端口複用

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

 # 2.綁定

 tcp_server_socket.bind(("", 7890))

 # 3.變爲套接字

 tcp_server_socket.listen(128)

 

 while True:

  # 4.等待客戶端的鏈接

  new_socket, client_addr = tcp_server_socket.accept()

 

  print(client_addr)

 

  # 5.爲這個客戶端服務

  service_client(new_socket)

 

 # 關閉監聽套接字

 tcp_server_socket.close()

 

 

if __name__ == '__main__':

 main()

以上就是本文的全部內容,希望對大家的學習有所幫助。

最後,小編想說一句話:我是一名python開發工程師,整理了一套最新的python系統學習教程,包括從基礎的python腳本到web開發、爬蟲、數據分析、數據可視化、機器學習,面試寶典,面試寶典,面試寶典。想要這些資料的可以加羣:877562786

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章