日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

python實現靜態web服務器

系統 1942 0

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請求的格式:

            
GET /path HTTP/1.1
 Header1: Value1
 Header2: Value2
 Header3: Value3
          

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

2 HTTP POST請求的格式:

            
POST /path HTTP/1.1
 Header1: Value1
 Header2: Value2
 Header3: Value3

 body data goes here...
          

3 HTTP響應的格式:

            
200 OK
 Header1: Value1
 Header2: Value2
 Header3: Value3

 body data goes here...
          

HTTP響應如果包含body,也是通過\r\n\r\n來分隔的。
請再次注意,Body的數據類型由Content-Type頭來確定,如果是網頁,Body就是文本,如果是圖片,Body就是圖片的二進制數據。
當存在Content-Encoding時,Body數據是被壓縮的,最常見的壓縮方式是gzip,所以,看到Content-Encoding: gzip時,需要將Body數據先解壓縮,才能得到真正的數據。壓縮的目的在于減少Body的大小,加快網絡傳輸。

demo:靜態web服務器

            
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 += "
            

404 not found
沒有發現所請求資源

" 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()

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


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 拉萨市| 深水埗区| 治县。| 凌云县| 绥宁县| 茌平县| 乌兰察布市| 万源市| 巴里| 鄄城县| 天台县| 苏尼特右旗| 九龙坡区| 内乡县| 五指山市| 汪清县| 始兴县| 柘城县| 肇州县| 京山县| 和林格尔县| 陇南市| 鄢陵县| 宜阳县| 仙游县| 肇东市| 静乐县| 扎鲁特旗| 沧州市| 扬中市| 达日县| 平阴县| 蒙城县| 象州县| 峡江县| 柳江县| 桐梓县| 宜宾县| 巴东县| 斗六市| 册亨县|