python 內(nèi)置庫wsgiref的使用(WSGI基礎入門)
wsgiref簡單示例
運行以下示例程序后,在瀏覽器中輸入以http://127.0.0.1:9999/開頭的隨意一個url都可以看到返回結果。實例程序中所有url都會以同一個App進行處理,實際生產(chǎn)環(huán)境中不同的url肯定是需要映射到不同的App上的,但這部分本文不作講解。
# wsgiref是Python自帶的內(nèi)置庫,它用來開發(fā)者對wsgi進行測試用的,不可以用在生產(chǎn)環(huán)境中from wsgiref.simple_server import make_server, demo_app# wsgi也是基于socket server編寫# 默認情況下會將所有url都傳入demo_app進行處理,具體可參考demo_app源碼# app參數(shù)可以是任何可調(diào)用對象,但是內(nèi)部處理需要參考demo_app源碼,即environ處理、start_response調(diào)用、返回值類型ws = make_server(’127.0.0.1’, 9999, demo_app)# 啟動服務ws.serve_forever()
demo_app源碼
def demo_app(environ,start_response): from io import StringIO stdout = StringIO() print('Hello world!', file=stdout) print(file=stdout) # environ是一個字典,包含了所有請求信息 h = sorted(environ.items()) for k,v in h:print(k,’=’,repr(v), file=stdout) # return之前需要調(diào)用start_response設置響應頭信息 start_response('200 OK', [(’Content-Type’,’text/plain; charset=utf-8’)]) return [stdout.getvalue().encode('utf-8')] # 一個可迭代對象,元素為byte類型,元素內(nèi)容依據(jù)start_response中指定的Content-Type來指定
demo_app類定義的兩種方式
# 第一種方式:定義類的__init__和__iter__方法,前者用來接收和處理environ和start_response,后者生成一個可迭代對象# make_server中app參數(shù)只需傳入類名即可class ApplicationClass: def __init__(self, environ, start_response):self.e = environself.sr = start_response def __iter__(self):from io import StringIOstdout = StringIO()print('Hello world!', file=stdout)print(file=stdout)h = sorted(self.e.items())for k, v in h: print(k, ’=’, repr(v), file=stdout)self.sr('200 OK', [(’Content-Type’, ’text/plain; charset=utf-8’)])yield from [stdout.getvalue().encode('utf-8')]# 第二種方式:定義__call__方法,接收和處理environ和start_response,并返回一個可迭代對象# make_server中app參數(shù)需要傳入類的實例class ApplicationInstance: def __call__(self, environ, start_response):from io import StringIOstdout = StringIO()print('Hello world!', file=stdout)print(file=stdout)h = sorted(environ.items())for k, v in h: print(k, ’=’, repr(v), file=stdout)start_response('200 OK', [(’Content-Type’, ’text/plain; charset=utf-8’)])return [stdout.getvalue().encode('utf-8')]3. WSGI web服務器和應用程序
WSGI web服務器
本質(zhì)上是一個TCP服務器,監(jiān)聽在特定的端口上。 支持HTTP協(xié)議,能夠解析HTTP請求報文,能夠按HTTP協(xié)議將響應數(shù)據(jù)封裝為報文并返回給瀏覽器。 實現(xiàn)了WSGI協(xié)議,該協(xié)議約定了和應用程序之間的接口,即url到app之間的映射。WSGI應用程序
遵從WSGI協(xié)議。 本身是一個可調(diào)用對象。 調(diào)用start_response,返回響應頭部。 返回包含正文的可迭代對象。以上就是python 內(nèi)置庫wsgiref的使用(WSGI基礎入門)的詳細內(nèi)容,更多關于python wsgiref的使用的資料請關注好吧啦網(wǎng)其它相關文章!
相關文章:
1. chat.asp聊天程序的編寫方法2. 一文掌握在Vue3中書寫TSX的使用方法3. 利用FastReport傳遞圖片參數(shù)在報表上展示簽名信息的實現(xiàn)方法4. ASP.NET Core按用戶等級授權的方法5. .NET 中配置從xml轉(zhuǎn)向json方法示例詳解6. phpstudy apache開啟ssi使用詳解7. ASP常用日期格式化函數(shù) FormatDate()8. 怎樣才能用js生成xmldom對象,并且在firefox中也實現(xiàn)xml數(shù)據(jù)島?9. HTML中的XML數(shù)據(jù)島記錄編輯與添加10. 推薦一個好看Table表格的css樣式代碼詳解
