20行基于Python的PC端HTTPS服务器

基于Python的PC端HTTPS服务器

简介

最近做项目的时候,发现硬件开发的客户很不在行https的相关开发。所以做一个基于Python简单的20行左右的的https服务器部署的教程。

代码

# https_server.py
from http.server import HTTPServer, BaseHTTPRequestHandler
import ssl
from io import BytesIO


class SimpleHTTPRequestHandler(BaseHTTPRequestHandler):

    def do_GET(self):
        self.send_response(200)
        self.end_headers()
        self.wfile.write(b'Hello, world!')

    def do_POST(self):
        content_length = int(self.headers['Content-Length'])
        body = self.rfile.read(content_length)
        self.send_response(200)
        self.end_headers()
        response = BytesIO()
        response.write(b'This is POST request. Received: ')
        response.write(body)
        self.wfile.write(response.getvalue())


httpd = HTTPServer(('localhost', 8000), SimpleHTTPRequestHandler)
httpd.socket = ssl.wrap_socket (httpd.socket, keyfile="key.pem", certfile='cert.pem', server_side=True)

httpd.serve_forever()

代码里面的key.pem

-----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEA+PxIR+iPq2uZj8+IGMNQRZg8AyTjBiqMHK/iPbrA3jtoNY5/
t5al501zyzjepANQ1nDmRLs/O45//RnXlSXLD63+RK8DxBCzPysC7LB1D4lEPuQV
VCmRxpnJLkN2gsku7sYPlYRno3isGSLbAj3Kmr33xAcXpzd4iMv3hQL8C3/QzUh0
GhHRY91O66/vMSU7SanwTJ0uT/ePjsMqVQsxhByYdvYzKEqbaSqN7QPdUAjAx8IF
VVkPhW5m2XXGJegf1+tfXD4jztB9B4vEWDnscdX8oG4GWkRrycuExnflPY/S9eVv
iTsmhJZKGNjrAhXlXH62A6t8m+oHg8betBqBDwIDAQABAoIBAF8IO7Zmh1+QRB5l
wbZh5eOKRW2VyKjz2GKipyGUhETOO+olJ441C8GLCGVKoX/MXDBdCya0qV/b9fHu
yR/+OtETQfeJLVDKZv/3NLiOaT+yzr+KYrGq5B7/V5A246brjuRH6G7TCJOWXWmC
qkDiwM/rLgQ+CMMkIvdjkmfMSdNBBv3XS0hVU560zu/rYSK83obug4fT3VULUmf1
kH6J8KTguTpP1ZbHImbd3TWEEyX0HY5cbdvDf8E5fosYFfNGruNzxhw2cw4nCAVd
1iwAB7PmTNPDZKd9wL27bHcs4XWs7cGbKvDHS1RR0//i0KXx+nnquyWM/7SX8zeB
LuQ2MGECgYEA/4AcxPXYHVEfFErtsSbptk/1e9a/nisB4OCfjwk/vc6rNsHbUa5h
4xjHufXADEX5PrIhajbf0ej6a2987EpAqZdIj6KbYifcqJbZcfjmMfxOiwdHC0LL
gS6xTRLnFBvwsBxgEzdeNxh85/ACFdayeChG7Dqs5qS+ruJkTBhFxRkCgYEA+Xjo
sxiC28LpUaXKcH5kMqxnsXQCUAxPEvaEIbEB2GKXvRa/4PARB+qIKW2pidQ3I+dj
m4GHBVsvw0h/5Eh1Wm8x88+x85wVMRjjVALzUxf84oCGv7QSrHf6Cf0ynTzm907B
WSsNYhdJQY5a1C3hDuLSmfKA0HLDCl1C/FW8VGcCgYBS7SrpRn3hbg3vUS56nA2p
DaS4kAfbd0wByAYhr7fPjD+H4z2i8j11LvrMQZYWpbNzBO/RgIP+pmZ47lOWgbch
FCgJ7pYOMq/szCFBW66jNKfteew2HHTetd/4CxWTMkpZbqxEMGlU6o7H3N9gZTHB
zBjQ3W524au+KV6yUAJ9KQKBgQCQlPBYC5abgsTyGuHOfJHZhG28PH2yos+ZL+G4
HPvyyoEih3LBDKDyM4yiZfnh9WnXlxz1XQZBpm1yAiyMwymwNc1/fhmmFAl8IO5v
HB6lQ7u+EbsGk3hXGFmDPIj+8/Lv1WbdJMRm2xQLuFMPsV9D31Uq/46EQF6lPRO7
Znz1dQKBgQDaiWrDAEZbsj+Zz9n4WDEwY43L673y1JBAaoMt1JcqmYqXHNrd1/YF
U7M71mpB7pZTZGUjXJZakjPZ5MHqCq2ZmdTp9THb8tPnJHFSx0yCLwJD+gkLPDBt
RFU6tqAJIa1+29SWsrF3XkIXCLJwrIUFYYyCA+iCSi4N/svbZZFkIw==
-----END RSA PRIVATE KEY-----

代码里面的cert.pem

-----BEGIN CERTIFICATE-----
MIIDETCCAfkCFHy8QMeOi8eJ4K+ElfrPZgNtOqkCMA0GCSqGSIb3DQEBCwUAMEUx
CzAJBgNVBAYTAkFVMRMwEQYDVQQIDApTb21lLVN0YXRlMSEwHwYDVQQKDBhJbnRl
cm5ldCBXaWRnaXRzIFB0eSBMdGQwHhcNMjAwODI2MTM1NjQzWhcNMjMwNTI0MTM1
NjQzWjBFMQswCQYDVQQGEwJBVTETMBEGA1UECAwKU29tZS1TdGF0ZTEhMB8GA1UE
CgwYSW50ZXJuZXQgV2lkZ2l0cyBQdHkgTHRkMIIBIjANBgkqhkiG9w0BAQEFAAOC
AQ8AMIIBCgKCAQEA+PxIR+iPq2uZj8+IGMNQRZg8AyTjBiqMHK/iPbrA3jtoNY5/
t5al501zyzjepANQ1nDmRLs/O45//RnXlSXLD63+RK8DxBCzPysC7LB1D4lEPuQV
VCmRxpnJLkN2gsku7sYPlYRno3isGSLbAj3Kmr33xAcXpzd4iMv3hQL8C3/QzUh0
GhHRY91O66/vMSU7SanwTJ0uT/ePjsMqVQsxhByYdvYzKEqbaSqN7QPdUAjAx8IF
VVkPhW5m2XXGJegf1+tfXD4jztB9B4vEWDnscdX8oG4GWkRrycuExnflPY/S9eVv
iTsmhJZKGNjrAhXlXH62A6t8m+oHg8betBqBDwIDAQABMA0GCSqGSIb3DQEBCwUA
A4IBAQAllrDUL4il7eQBOQ+5vJ94VQcwefRPm8b9dLebvFAcEJVPSJWwABGPAGfI
vwhn37TlDDQmToAyNv9b/PG8HM+31zOxPdnbKF6ChltBfctWBMhQH9q2xa5yKP7j
ifrnKcl+1QOF70UDU0mRe7xBHBSPEr5wlGEPxapYgQd9c1LcRyC8H0Go3MAHscF8
xWih/IQDwhQy/fJ9dCLEzJEVxDQakMAj4HnvFVU1u5RdXnkp7LlHreVhMv0SBNsF
6ko2rUwae6kjkCfHohQfcUiIZCrUQ0ahNlB1iafVHGPjy6P2WhLrzB1q+NYNttKs
DVV8W440jfhfKjc2bmfDArsTICBa
-----END CERTIFICATE-----

整块代码去掉空行总共20行,原生Python3.0库即可支持。

解释

http和https的本质区别就只有如下一行,但从信息安全的角度看,这个cert.pem在没有key.pem是无法伪造的,cert.pem通常都是用PEM的X.501格式写。

httpd.socket = ssl.wrap_socket (httpd.socket, keyfile="key.pem", certfile='cert.pem', server_side=True)

有兴趣的同学可以在Ubuntu上用如下几行去生成自己的key.pem和cert.pem

openssl req -new > cert.csr
openssl rsa -in privkey.pem -out key.pem
openssl x509 -in cert.csr -out cert.pem -req -signkey key.pem -days 1001

对于不了解网络开发的同学解释一下:
localhost == 127.0.0.1叫做Loop back网络,只能本机访问。
如果想要跨电脑测试,首先必须两台电脑IP可以互相访问(这里有坑),然后将localhost改成自己的IP,或者有多个IP的电脑(有线和WiFi不同IP)的情况,可以直接使用:0.0.0.0

测试

服务端

首先在当前文件夹内执行

python https_server.py

Postman测试

无非是想验证服务端是否能收到网络中来自于https的访问。直接打开Postman创建一个新的request
在这里插入图片描述
在Request里的配置如下
在这里插入图片描述
第一次使用Postman会出现如下错误:
在这里插入图片描述
点击红框的禁用SSL验证,因为这个证数是自己生成的,所以无法认证。

在这里插入图片描述
测试成功。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python提供了多种方法来搭建简易文件服务器。其中一种方法是使用Python内置的http.server模块,该模块允许你通过简单的命令在本地启动一个HTTP服务器。你可以使用这个服务器来共享文件和访问文件。 另外一种方法是通过使用第三方库或框架来搭建文件服务器。例如,你可以使用GitHub上的一个名为httpsweet的Python库,这是一个基于Python3编写的HTTP/HTTPS文件服务器。你可以从https://github.com/eloypgz/httpsweet下载该库的源码并按照说明进编译生成文件服务器。 此外,你还可以使用FTP/FTPS文件服务器来传输文件,这种方法相对较为简单,因为有很多相关的软件可供选择。但是,关于HTTP/HTTPS文件服务器的搭建方法相对较少,而且网上的方法也比较杂乱。然而,你可以通过使用Python来搭建一个简易的HTTP/HTTPS文件服务器。你可以先从GitHub下载源码,然后按照说明进搭建。 总结来说,你可以使用Python内置的http.server模块或第三方库来搭建简易文件服务器。具体选择哪种方法取决于你的需求和喜好。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【Python】创建一个简易服务器并实现移动端快速访问电脑文件](https://blog.csdn.net/ZHOU_YONG915/article/details/127739573)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python搭建简易HTTP/HTTPS文件服务器](https://blog.csdn.net/hanyunkaka/article/details/120470355)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值