欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python?web.py啟動(dòng)https端口的方式

 更新時(shí)間:2023年05月04日 10:26:55   作者:Coding的葉子  
這篇文章主要介紹了python?web.py啟動(dòng)https端口,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

python web.py啟動(dòng)https端口

        web.py啟動(dòng)https端口需要ssl證書(shū),如果沒(méi)有ssl證書(shū),那么可以通過(guò)如下方式生成。具體可參考文末的補(bǔ)充介紹。

openssl genrsa -des3 -out server.key 1024
openssl req -new -key server.key -out server.csr
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
sudo openssl rsa -in server.key -out server.key

        示例程序如下所示:

# -*- coding: utf-8 -*-
"""
Created on Mon May 10 20:37:00 2021
@author: Administrator
"""
import web              #web.py
urls = (
        '/server' , 'server', 
        '/.*', 'notfound'     #localhost:port/其他任意界面,訪問(wèn)notfound類
        )
class MyApplication(web.application):
    def run(self, port=8080, *middleware):
        func = self.wsgifunc(*middleware)
        return web.httpserver.runsimple(func, ('0.0.0.0', port))
class server:
    def __init__(self):
        self.return_msg = {'errorCode': 0, 'msg': '系統(tǒng)正常!'}     
    def POST(self):                    #POST處理方式與GET一致
        # content  = web.input()
        # print('收到消息:', content.key1, content.key2, content.key3)
        x = web.input(myfile={})
        print('xxx: ', x.keys())
        return str(self.return_msg).replace('\'', '\"')
class notfound:
    def GET(self):
        print('--from notfound')
        return '404 not found'
    def POST(self):
        print('--from notfound')
        return '404 not found'
from cheroot.server import HTTPServer
from cheroot.ssl.builtin import BuiltinSSLAdapter
HTTPServer.ssl_adapter = BuiltinSSLAdapter(
        certificate='server.crt',
        private_key='server.key')
if __name__ == "__main__":
    app = MyApplication(urls ,globals())
    app.run(port=443)

補(bǔ)充:python web.py 開(kāi)啟https

參考英文網(wǎng)址http://heapkeeper-heap.github.io/hh/thread_1344.html

第一步:在shell中依次執(zhí)行以下命令,回答問(wèn)題,設(shè)置密碼生成證書(shū),包含三個(gè)文件***.crt 和***.key和***.csr,我分別重新命令為server.crt  server.csr  server.key

 openssl genrsa -des3 -out server.key 1024
    openssl req -new -key server.key -out server.csr
    openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
    mv server.key myserver.key
    mv server.crt myserver.crt

開(kāi)啟服務(wù),仿照下面代碼輸入即可,其中

from handle import Handle引入的我的方法模塊,在urls中調(diào)用(仿照微信公眾號(hào)開(kāi)發(fā)的例子,具體如果新手可以自己看),同時(shí)保存的文件路徑根據(jù)自己的寫(xiě)

import web
from handle import Handle
from web.wsgiserver import CherryPyWSGIServer
CherryPyWSGIServer.ssl_certificate = "/usr/ssl/server.crt"
CherryPyWSGIServer.ssl_private_key = "/usr/ssl/server.key"
urls = (
    '/wx', 'Handle',
)
if __name__ == '__main__':
    app = web.application(urls, globals())
    app.run()

然后開(kāi)始服務(wù) sudo python main.py 443(其中443是端口號(hào))

這個(gè)時(shí)候你需要輸入ssl之前自己設(shè)置的密碼,才能開(kāi)啟,但是這樣導(dǎo)致不能后臺(tái)隱藏,

但是在生成證書(shū)的文件夾下,執(zhí)行sudo openssl rsa -in server.key -out server.key即可無(wú)密碼,這樣就可以后臺(tái)執(zhí)行

nohup python main.py 443 &

到此這篇關(guān)于python web.py啟動(dòng)https端口的方式的文章就介紹到這了,更多相關(guān)python web.py啟動(dòng)https端口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論