前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >企业远程视频会议云服务EasyRTC-SFU版本支持 https 功能设计逻辑

企业远程视频会议云服务EasyRTC-SFU版本支持 https 功能设计逻辑

作者头像
EasyNVR
发布2020-09-11 09:38:55
6470
发布2020-09-11 09:38:55
举报
文章被收录于专栏:EasyNVREasyNVR

在EasyRTC-SFU软件中,后台管理程序使用 Go 语言开发。在部分应用场景中,为了安全,需要支持 HTTPS 协议。因此整个后台管理程序,需要支持 HTTP 和 HTTPS 同时运行。

在 EasyRTC-SFU 版本中使用 Gin 作为 Web 框架。在 Go 语言 Web 项目中,快速支持 HTTPS 仅需要使用 secure 项目作为处理 HTTPS 的中间件,就能很快的进行开发。两个项目的地址如下:

github.com/gin-gonic/gin github.com/unrolled/secure

具体代码如下:

代码语言:javascript
复制
func main() {
   r := gin.Default()
   https := gin.Default()
   app := app.NewApp()
 
   if app.Config().HttpsPort > 0 {
      httpsPort := fmt.Sprintf(":%d", app.Config().HttpsPort)
      https.Use(TlsHandler(httpsPort))
      routes.Setup(https, app)
      go https.RunTLS(httpsPort, app.Config().CertPath, app.Config().KeyPath)
   }
 
   routes.Setup(r, app)
 
   r.Run(fmt.Sprintf(":%d", app.Config().Port))
}
 
// 初始 TLS
func TlsHandler(httpsPort string) gin.HandlerFunc {
   return func(c *gin.Context) {
      secureMiddleware := secure.New(secure.Options{
         SSLRedirect: true,
         SSLHost:     httpsPort,
      })
      err := secureMiddleware.Process(c.Writer, c.Request)
      if err != nil {
         return
      }
      c.Next()
   }
}
代码语言:javascript
复制
https := gin.Default()

具体逻辑如下:

首先使用 Gin 生成对应的引擎 https。

代码语言:javascript
复制
https := gin.Default()

将 Gin 生成的引擎 https 添加中间件,中间件为 TlsHandler 方法处理。后面具体分析。生成引擎后,routes.Setup() 方法为安装对应路由处理程序,不在此展示。

最后使用 go 协程语法开启一个监听 httpsPort 端口的协程。其中 CertPath 和 KeyPath 为配置的公钥证书和私钥密码所在的路径。

代码语言:javascript
复制
https.Use(TlsHandler(httpsPort))
routes.Setup(https, app)
go https.RunTLS(httpsPort, app.Config().CertPath, app.Config().KeyPath)

如果程序中仅需要支持 HTTPS 协议,并且主线程中没有其他阻塞程序存在,则需要去除 go 关键字。

secure 为 Go 项目实现 https 的中间件程序。中间件的具体含义:A发送请求给B进行处理数据,此时可以额外添加C,把C作为A和B之间的中间桥梁,即由原先的A-B变为A-C-B。对于A和C来说,并不一定知道C的存在,这样代码逻辑更清晰。

TlsHandler 方法中的主要作用为使用 secure 项目处理请求和响应。具体代码为调用 secure.New(), 然后调用 Process() 方法把 请求 request 和响应 response 进行处理即可。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档