淺析Python?WSGI的使用
第一次了解python
的WSGI
,可能描述的不太準確。
本篇文章所依賴的python
環(huán)境為:
什么是WSGI
WSGI
也稱之為web
服務器通用網關接口,全稱是web server gateway interface
。它定義了在python
中web
服務器與web
應用程序之間應該如何通信并且處理http
請求和響應的一個標準,注意,它只是一個協議,或者說是規(guī)范、標準,你也可以不按這個標準來,就像我們上一篇文章所寫的web
服務器那樣。
WSGI
也分為應用程序 和 服務器網關, 其中我們熟知的Flask
就是屬于應用程序,uWSGI
、wsgiref
屬于服務器網關。
個人感覺,WSGI
避免了造輪子,事情讓更擅長的人去做,寫服務器的,那就寫符合WSGI
規(guī)范的服務器就好,如果是寫應用端的,就寫符合WSGI
規(guī)范應用就好。不用在重復的寫輪子。
除此之外,WSGI
還能與傳統web
服務器對接,例如: nginx
、apache
等進行交互。
WSGI對應用程序規(guī)定了什么
WSGI
中規(guī)定了其應用程序必須是一個可被調用的對象,通常來說,該對象是一個函數或者是一個類。 該對象必須接收2個參數,分別是environ
字典 和 start_response
函數,并且在對象結束前,應該調用start_response
函數。而函數應該傳參status
和headers
,其中status
應該定義響應狀態(tài)碼以及短語,headers
應該定義響應頭。
如果用代碼來闡述的話,應該是這樣來寫的:
def application(environ, start_response): status = '200 OK' headers = [('Content-type', 'text/plain')] start_response(status, headers) return [b'Hello, world!']
其中,application
是一個可迭代的對象,接受了2個參數,一個是environ
,其類型是字典,還是一個是start_response
,其類型是函數,在application
結束前,應該調用start_response
函數,并且傳入status
和headers
值。
修改代碼寫出符合WSGI標準的web業(yè)務層
我們昨天寫的代碼,將返回一個Hello, Destined Person.
,我們來看下,如果我們使用WSGI
標準來寫業(yè)務層,我們應該如何定義,并且如何調用WSGI
服務器。
import wsgiref.simple_server def application(environ,start_response): status = "299 OK" headers = [("Content-type","text/html"),("Server","pdudo_web_sites")] start_response(status ,headers) return [b'Hello, Destined person."] s = wsgiref.simple_server.make_server('',8888,application) s .serve_forever()
上述,我們引入了一個符合WSGI
的服務器: wsgiref.simple_server
,我們僅需按照WSGI
的標準來編寫業(yè)務層,也就是上述的application
即可。我們在定義狀態(tài)碼的時候,估計將其設置為299 OK
,在設置請求頭的時候,設置了一個Server
為pdudo_web_sites
。
我們使用curl
請求一下服務器。
發(fā)現,哦,只要按照WSGI
規(guī)范來書寫,就可以很輕容的寫一個簡單的服務器。
總結
本篇文章,介紹了什么是WSGI
以及現在程序員寫python
的web
框架為什么要符合WSGI
,最后我們寫了一個業(yè)務函數,將其放到符合WSGI
標準的服務器wsgiref
上。文章寫的很亂,不是很好。
到此這篇關于淺析Python WSGI的使用的文章就介紹到這了,更多相關Python WSGI內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!