当前位置: 首页 > news >正文

fastapi(https)+openssl+测试(双向校验)

第一步生成根证书
# Generate CA private key
openssl genrsa -out ca.key 2048
# Generate CSR
openssl req -new -key ca.key -out ca.csr
# Generate Self Signed certificate(CA 根证书)
openssl x509 -req -days 365 -in ca.csr -signkey ca.key -out ca.crt第二步生成服务端证书:
# server.key 为私钥
openssl genrsa -out server.key 2048
#这里的/cn是必须添加的 是服务端的域名或者是etc/hosts中的ip别名 也可以是使用*
openssl req -new -key server.key -subj "/CN=192.168.31.53" -out server.csr
openssl x509 -req -in server.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out server.crt -days 3650第三步生成客户端证书:
openssl genrsa -out client.key 2048
# /cn是服务端的域名 或者是etc/hosts中的ip别名 也可以是使用* 加端口号会验证不通过有待研究
openssl req -new -key client.key -subj "/CN=192.168.31.53" -out client.csr
openssl x509 -req -in client.csr -CA ca.crt -CAkey ca.key -CAcreateserial  -out client.crt -days 3650
以上内容来自Android+OkHttp3+Golang(Gin)+OpenSSL单双向校验(一)_Time-Traveler的博客-CSDN博客Fastapi关键代码
uvicorn.run(app='server:app', host='0.0.0.0', port=8084, reload=True, log_level="info",ssl_keyfile="./ssl/server.key",ssl_cert_reqs=1,ssl_ca_certs="./ssl/ca.crt",ssl_certfile="./ssl/server.crt")

测试代码

http = urllib3.PoolManager(cert_file='./ssl/client.crt',cert_reqs='CERT_REQUIRED',ca_certs='./ssl/ca.crt',key_file='./ssl/client.key')
request_context = http.connection_from_host('192.168.31.53',port=8084,scheme='https')r1 = request_context.request('GET', "/test")
print(r1.data.decode('utf-8'))

http://www.lryc.cn/news/36081.html

相关文章:

  • TiDB Server
  • S3C2440移植Linux4.19.275内核以及过程中遇到的问题
  • 解忧杂货铺(二):UML时序图
  • 微信小程序的代码由哪些结构组成?
  • Cloud Kernel SIG月度动态:发布 ANCK 新版本及 Plugsched v1.2.0
  • Jedis 使用详解(官方原版)
  • 关于Pytorch中的张量学习
  • 基于Transformer的目标检测算法学习记录
  • 嵌入式学习笔记——使用寄存器编程实现按键输入功能
  • 打卡小达人之路:Spring Boot与Redis GEO实现商户附近查询
  • Apache HTTP Server <2.4.56 mod_proxy_uwsgi 模块存在请求走私漏洞(CVE-2023-27522)
  • JUC并发编程设计模式
  • HTTPS加密解析
  • Python每日一练(20230309)
  • 哈希表题目:数组的度
  • 初识rollup 打包、配置vue脚手架
  • 软考网络工程师证书有用吗?
  • postgresql 自动备份 bat实现
  • gdb:在命令行中会莫名暂停;detach-on-fork
  • 【3.9】RedisAOF日志、字符串、操作系统进程管理
  • 安装mayavi的成功步骤
  • vue+echarts.js 实现中国地图——根据数值表示省份的深浅——技能提升
  • [oeasy]python0104_指示灯_显示_LED_辉光管_霓虹灯
  • Easy Deep Learning——卷积层
  • 深入分析@Bean源码
  • Web Components学习(1)
  • Element-UI实现复杂table表格结构
  • Azure AD 与 AWS 单一帐户SSO访问集成,超详细讲解,包括解决可能出现的错误问题
  • lvgl 笔记 按钮部件 (lv_btn) 和 开关部件 (lv_switch)
  • Python高频面试题——生成器(最通俗的讲解)