Heim > Backend-Entwicklung > Golang > Wie verwende ich TLS 1.2 mit dem MySql Go-Treiber?

Wie verwende ich TLS 1.2 mit dem MySql Go-Treiber?

WBOY
Freigeben: 2024-02-10 09:40:09
nach vorne
749 Leute haben es durchsucht

如何将 TLS 1.2 与 MySql Go 驱动程序一起使用?

php-Editor Yuzi stellt Ihnen in diesem Artikel die Verwendung von TLS 1.2 mit dem MySQL Go-Treiber vor. TLS 1.2 ist ein sicheres Transportprotokoll, das zum Schutz der Sicherheit der Netzwerkkommunikation dient. Wenn Sie den MySQL Go-Treiber zum Herstellen einer Verbindung zu einer Datenbank verwenden, kann die Aktivierung von TLS 1.2 die Sicherheit der Datenübertragung verbessern. In diesem Artikel erfahren Sie, wie Sie TLS 1.2 mit dem MySQL Go-Treiber konfigurieren und verwenden, um eine sichere Datenbankverbindung herzustellen. Wenn Sie den Anleitungen dieses Artikels folgen, können Sie TLS 1.2 problemlos mit dem MySQL Go-Treiber verwenden, um Ihre Daten und Kommunikation zu schützen.

Frageninhalt

Wir müssen tls1.2 verwenden, um eine Verbindung zu unserem MySQL-Server herzustellen. In unserer Java-Anwendung verwenden wir die folgende JDBC-URL -

jdbc:mysql://xxxx-001-dev.cluster-xx-2.rds.amazonaws.com/bats?**enabledtlsprotocols=tlsv1.2**
Nach dem Login kopieren

Ich kann keine ähnliche Konfiguration erreichen, wenn ich in unserer Go-Anwendung eine Verbindung zu MySQL herstelle -

cfg1 := mysql.config{
        user:                 "admin",
        passwd:               "xxxxxxx",
        net:                  "tcp",
        addr:                 "xxxx-001-dev.cluster-xx-2.rds.amazonaws.com:3306",
        dbname:               "xxxx",
        allownativepasswords: true,
    }

    sql.open("mysql", cfg1.formatdsn())
Nach dem Login kopieren

Ich habe versucht, die folgende Aussage hinzuzufügen. Aber es hilft nicht, es wirft den folgenden Fehler -

// enabledtlsprotocolstlsv1.2
    cfg1 := mysql.config{
        user:                 "admin",
        passwd:               "xxxxxx",
        net:                  "tcp",
        addr:                 "xxxx-001-dev.cluster-xx-2.rds.amazonaws.com:3306",
        dbname:               "xxxx",
        allownativepasswords: true,
    }

    cfg1.tls.minversion = tls.versiontls12
    cfg1.tls.maxversion = tls.versiontls12

    sql.open("mysql", cfg1.formatdsn())
Nach dem Login kopieren

Fehler-

panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xc0000005 code=0x1 addr=0xf8 pc=0x64ac21]

goroutine 1 [running]:
main.main()
        C:/cmb-mmt/chp-schema-validation/main.go:28 +0x61
Nach dem Login kopieren

Wir verwenden MySQL-Version 5.7.12

Lösung

Der folgende Code löst dieses Problem. und ich kann erfolgreich eine Verbindung zu MySQL herstellen.

cfg1 := mysql.Config{
        User:                 cfg.Db.Dev.User,
        Passwd:               cfg.Db.Dev.Pass,
        Net:                  "tcp",
        Addr:                 "cxx-cxxx-auroramysql-001-dev.xxxxxxxxx.us-west-2.rds.amazonaws.com:3306",
        DBName:               "xxxx",
        AllowNativePasswords: true,
        TLSConfig:            "skip-verify",
        TLS:                  &tls.Config{MinVersion: tls.VersionTLS12, MaxVersion: tls.VersionTLS12},
    }
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie verwende ich TLS 1.2 mit dem MySql Go-Treiber?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage