Flask
或者其餘框架都是封裝的比較完善,咱們能夠不去關注路由、SESSION
等究竟是怎麼實現的,如今咱們使用socket
來實現一個帶有註冊、登陸功能的To do
網站,這樣能對後端框架了解的稍微更深刻一點(固然你也能夠直接去看Flask
源碼)。python
主程序runserver.py
代碼以下:編程
#!/usr/bin/env python # -*- coding:utf-8 -*- import socket from exts import Request from route import response_for_request from datetime import datetime def run_server(host='', port=1207): # 創建一個socket.socket()類s with socket.socket() as s: # 設置s在服務端關閉後立刻釋放端口,避免Address already in use錯誤 s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 綁定host和port s.bind((host, port)) while 1: # 開始監聽傳入鏈接,能夠掛起的最大鏈接數爲5 s.listen(5) # 接受鏈接,根據buffer_size不斷讀取內容 connection, address = s.accept() r = '' buffer_size = 1024 while 1: data = connection.recv(1024).decode('utf-8') r += data if len(data) < buffer_size: break # 防止瀏覽器傳空請求過來 if len(r.split()) < 2: continue # 最後取得的r是一個http請求頭字符串,對其解析,而後使用sendall返回相應的內容 request = Request(r) # 每次請求時打印時間,請求的方法和路徑 print(str(datetime.now())[:19], request.method, request.path) response = response_for_request(request) connection.sendall(response) connection.close() if __name__ == '__main__': run_server()
run_server
函數代碼的簡單說明能夠看註釋;from exts import Request
:從exts
導入一個Request
類,這個Request
類是本身編寫的,用於解析http
請求頭,這部分是很簡單的,在網上搜索http
請求相關內容,就能夠自行寫一個,包括返回請求頭的路徑、方法、各個字段以及body
部分等,都是字符串相關的操做。from route import response_for_request
:從route.py
導入相應函數,即傳入一個上一步中的Request
類,返回對應的網頁內容,具體實現將在後續講解。segmentfault
能夠說,主程序就已經編寫好了,整個邏輯也很簡單,使用socket
監聽鏈接,解析請求,返回請求對應的內容。後續只要去處理解析請求和響應部分便可,主程序能夠不用再修改。後端
下一篇文章:【python socket編程】—— 2.解析http請求頭瀏覽器