donglugou6652 2018-10-24 06:07
浏览 841
已采纳

如何使用gorm创建与MySQL的SSL连接?

Can't seem to find any resource on creating a SSL connection to mysql using gorm. I am creating a non-ssl connection like this:

cfg := mysql.Config{
    User:   config.User,
    Passwd: config.Password,
    Addr:   fmt.Sprintf("%s:%d", config.Host, config.Port),
    Net:    "tcp",
    Params: options,
}

str := cfg.FormatDSN()
db, err := gorm.Open("mysql", str)

Passing 'ssl-ca' option in Param options with path to 'pem' file does not seem to work. Any heads up on this?

  • 写回答

1条回答 默认 最新

  • doushu5451 2019-01-16 17:25
    关注

    This is a fragment of my working code :

    isTLS := false
    
    if mysqlClientKey != "" && mysqlCaCert != ""  && mysqlClientCert != "" {
        isTLS = true
        rootCertPool := x509.NewCertPool()
        pem, err := ioutil.ReadFile("/path/mysqlCaCert")
        if err != nil {
            log.Fatal(err)
        }
        if ok := rootCertPool.AppendCertsFromPEM(pem); !ok {
            log.Fatal("Failed to append PEM.")
        }
        clientCert := make([]tls.Certificate, 0, 1)
        certs, err := tls.LoadX509KeyPair("/path/mysqlClientCert", "/path/mysqlClientKey")
        if err != nil {
            log.Fatal(err)
        }
        clientCert = append(clientCert, certs)
        mysql.RegisterTLSConfig("custom", &tls.Config{
            RootCAs:      rootCertPool,
            Certificates: clientCert,
        })
    }
    
    // try to connect to mysql database.
    cfg := mysql.Config{
        User:   username,
        Passwd: password,
        Addr:   server, //IP:PORT
        Net:    "tcp",
        DBName: database,
        Loc: time.Local,
        AllowNativePasswords: true,
        Params: o,
    }
    
    if isTLS == true {
        cfg.TLSConfig = "custom"
    }
    
    str := cfg.FormatDSN()
    
    db, err := gorm.Open("mysql", str)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 目标计数模型训练过程中的问题
  • ¥100 Acess连接SQL 数据库后 不能用中文筛选
  • ¥15 用友U9Cloud的webapi
  • ¥20 电脑拓展屏桌面被莫名遮挡
  • ¥20 ensp,用局域网解决
  • ¥15 Python语言实验
  • ¥15 我每周要在投影仪优酷上自动连续播放112场电影,我每一周遥控操作一次投影仪,并使得电影永远不重复播放,请问怎样操作好呢?有那么多电影看吗?
  • ¥20 电脑重启停留在grub界面,引导出错需修复
  • ¥15 matlab透明图叠加
  • ¥50 基于stm32l4系列 使用blunrg-ms的ble gatt 创建 hid 服务失败