【python】-- web框架本質

web框架 

1、web框架簡述

全部的Web應用,本質上其實就是一個socket服務端,用戶的瀏覽器其實就是一個socket客戶端。css

import socket


def handle_request(client):
    buf = client.recv(1024)
    client.send("HTTP/1.1 200 OK\r\n\r\n".encode("utf8"))
    client.send("Hello, Word".encode("utf8"))


def main():
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    sock.bind(("localhost", 9000))
    sock.listen(5)
  
    while True:
        connection, address = sock.accept()
        handle_request(connection)
        connection.close()
  
if __name__ == "__main__":
    main()

上述經過socket來實現了其本質,而對於真實開發中的python web程序來講,通常會分爲兩部分:服務器程序和應用程序。服務器程序負責對socket服務器進行封裝,並在請求到來時,對請求的各類數據進行整理。應用程序則負責具體的邏輯處理。爲了方便應用程序的開發,就出現了衆多的Web框架,例如:Django、Flask、web.py 等。不一樣的框架有不一樣的開發方式,可是不管如何,開發出的應用程序都要和服務器程序配合,才能爲用戶提供服務。這樣,服務器程序就須要爲不一樣的框架提供不一樣的支持。這樣混亂的局面不管對於服務器仍是框架,都是很差的。對服務器來講,須要支持各類不一樣框架,對框架來講,只有支持它的服務器才能被開發出的應用使用。這時候,標準化就變得尤其重要。咱們能夠設立一個標準,只要服務器程序支持這個標準,框架也支持這個標準,那麼他們就能夠配合使用。一旦標準肯定,雙方各自實現。這樣,服務器能夠支持更多支持標準的框架,框架也可使用更多支持標準的服務器html

 

WSGI(Web Server Gateway Interface)是一種規範,它定義了使用python編寫的web app與web server之間接口格式,實現web app與web server間的解耦。前端

python標準庫提供的獨立WSGI服務器稱爲wsgiref。python

from wsgiref.simple_server import make_server


def RunServer(environ, start_response):
    #environ 客戶端發來的所有數據
    #start_response 封裝要返回給用戶的數據,響應頭狀態
    start_response('200 OK', [('Content-Type', 'text/html')])
    #返回給客戶端的內容
    return [bytes('<h1>Hello, web!</h1>', encoding='utf-8'), ]

if __name__ == '__main__':
    httpd = make_server('', 8000, RunServer)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()

  

 

2、自定義web框架示例:

一、框架jquery

經過python標準庫提供的wsgiref模塊開發一個本身的Web框架.web

from wsgiref.simple_server import make_server


def index():
    return [bytes('<h1>Hello, index!</h1>', encoding='utf-8'), ]


def login():
    return [bytes('<h1>Hello, login!</h1>', encoding='utf-8'), ]


def routers():

    urlpatterns = {
        '/index': index,
        '/login': login}

    return urlpatterns


def RunServer(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/html')])
    url = environ['PATH_INFO']  # 經過打斷點能夠查看客戶端發過來數據中PATH_INFO是什麼值
    urlpatterns = routers()
    func = None
    if url in urlpatterns:
        func = urlpatterns[url]
    if func:
        return func()
    else:
        return [bytes('<h1>404 not fount</h1>', encoding='utf-8'), ]

if __name__ == '__main__':
    httpd = make_server("localhost", 9000, RunServer)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()

 

二、讀取HTML文件返回給客戶端數據庫

在現實的Web請求中通常會返回一個複雜的符合HTML規則的字符串,因此通常將要返回給用戶的HTML寫在指定文件中,而後再返回。瀏覽器

from wsgiref.simple_server import make_server


def index():
    with open("index.html", "rb") as f:
        data = f.read()
        return [data, ]


def login():
    with open("login.html", "rb") as f:
        data = f.read()
        return [data, ]


def routers():

    urlpatterns = {
        '/index': index,
        '/login': login}

    return urlpatterns


def RunServer(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/html')])
    url = environ['PATH_INFO']  # 經過打斷點能夠查看客戶端發過來數據中PATH_INFO是什麼值
    urlpatterns = routers()
    func = None
    if url in urlpatterns:
        func = urlpatterns[url]
    if func:
        return func()
    else:
        return [bytes('<h1>404 not fount</h1>', encoding='utf-8'), ]

if __name__ == '__main__':
    httpd = make_server("localhost", 9000, RunServer)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()

 

三、MVC和MTV模式服務器

MTV模式本質上與MVC模式沒有什麼差異,也是各組件之間爲了保持鬆耦合關係,只是定義上有些許不一樣。app

  • MVC: Model 數據庫   View 模板文件         Controller 業務處理
  • MTV: Model 數據庫   Template模板文件    View業務處理(後續的Django框架就是MTV模式)

 

 

3、前端組件介紹

前面幾篇博文主要是前端基礎知識,這裏補充介紹一些常見的前端組件,以供參考的同時,還能避免重複造輪子。

  • EasyUI(功能豐富,不過代價略高,不只須要修改css樣式,還須要修改js)
  • jQueryUI(css樣式單調)
  • Bootstrap(推薦使用,ps:@media響應式 ,@font-face字體形式圖標)
相關文章
相關標籤/搜索