欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JDBC如何通過SSL方式連接MySQL

 更新時間:2025年02月21日 10:19:33   作者:不會畫畫的畫師  
文章介紹了如何配置MySQL以支持SSL連接,并通過JDBC進行安全連接,主要內容包括查看MySQL SSL支持、創(chuàng)建SSL連接用戶、配置用戶是否強制使用SSL、JDBC配置導入證書以及使用Go編寫一個簡單的HTTP文件服務器來提供SSL證書

環(huán)境說明

MySQL 版本

  • MySQL 5.7.26

pom.xml

<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <version>8.0.18</version>
</dependency>

JDK版本

  • JDK 1.8

MySQL配置SSL

查看MySQL是否支持SSL連接

  • 查看MySQL是否支持SSL
SHOW VARIABLES LIKE 'have_ssl'

如果hava_ssl對應的值為YES則支持SSL

  • 查詢ssl證書地址
show variables like '%ssl%';

ssl_ca對應的就是ssl證書名

創(chuàng)建SSL連接用戶

  • 創(chuàng)建用戶
CREATE USER 'ssler'@'%' IDENTIFIED BY '123456';
GRANT ALL ON *.* TO 'ssler'@'%'
  • 查看用戶是否使用ssl
SELECT ssl_type From mysql.user Where user="ssler"

截圖中ssl_type為空字符串,表示該用戶不強制要求使用ssl連接。

  • 配置用戶必須使用ssl連接
ALTER USER 'ssler'@'%' REQUIRE SSL;
FLUSH PRIVILEGES

此時再執(zhí)行

SELECT ssl_type From mysql.user Where user="ssler"

ANY表示必須使用ssl連接。

JDBC配置

導入證書

  • 使用jdk自帶的keytool導入mysql的客戶端證書到密鑰倉庫,并生成密鑰文件。
  • 根據上文查到的ca.pem,將其復制到目標主機上,然后執(zhí)行下述指令
$ keytool -import -trustcacerts -v -alias Mysql -file ca.pem -keystore "mysql.ks"
輸入密鑰庫口令:
再次輸入新口令:
所有者: CN=MySQL_Server_5.7.26_Auto_Generated_CA_Certificate
發(fā)布者: CN=MySQL_Server_5.7.26_Auto_Generated_CA_Certificate
序列號: 1
有效期為 Wed Apr 29 16:32:45 CST 2020 至 Sat Apr 27 16:32:45 CST 2030
證書指紋:
         MD5:  09:E7:41:84:08:B0:70:5F:AC:D6:03:61:CE:F4:50:DE
         SHA1: 6B:EE:FE:B4:74:89:A3:88:6C:49:22:44:6D:FB:88:DE:18:6A:7A:F6
         SHA256: 83:DD:8F:83:71:08:1D:36:D6:C0:2B:23:D2:E9:DC:84:0E:D6:ED:9A:E5:85:DF:7C:7C:52:33:9A:D7:83:0F:29
簽名算法名稱: SHA256withRSA
主體公共密鑰算法: 2048 位 RSA 密鑰
版本: 3

擴展:

#1: ObjectId: 2.5.29.19 Criticality=false
BasicConstraints:[
  CA:true
  PathLen:2147483647
]

是否信任此證書? [否]:  y
證書已添加到密鑰庫中
[正在存儲mysql.ks]

通過指令驗證證書是否導入:

$ keytool -list -keystore mysql.ks
輸入密鑰庫口令:
密鑰庫類型: jks
密鑰庫提供方: SUN

您的密鑰庫包含 1 個條目

mysql, 2020-6-9, trustedCertEntry,
證書指紋 (SHA1): 6B:EE:FE:B4:74:89:A3:88:6C:49:22:44:6D:FB:88:DE:18:6A:7A:F6

將證書放在目標服務器上

在密鑰倉庫文件生成的文件夾下,配置http服務器。

此處使用go寫一個http文件服務器:

package main

import "net/http"

func main()  {
	http.Handle("/", http.FileServer(http.Dir(".")))
	http.ListenAndServe(":9999", nil)
}

將編譯后的go程序放在與mysql.ks同一目錄下,并啟動即可

編寫JDBC代碼

public class JDBCMySQL {

    public static void main(String[] args) {
        Connection connection = null;
        String urlWithCe = "jdbc:mysql://192.168.254.82:13306/cloud?" +
                "useSSL=true&trustCertificateKeyStorePassword=123456&" +
                "trustCertificateKeyStoreUrl=http://localhost:9999/mysql.ks&" +
                "allowMultiQueries=true&" +
                "useUnicode&characterEncoding=UTF-8&" +
                "verifyServerCertificate=false&requireSSL=true";
        try {
            Class.forName("com.mysql.cj.jdbc.Driver");
            connection = DriverManager.getConnection(urlWithCe,
                    "ssler", "123456");
            PreparedStatement preparedStatement = connection.prepareStatement("select * from " +
                    "cm_user");
            System.out.println(preparedStatement.executeQuery().first());
        } catch (Exception exception) {
            exception.printStackTrace();
        }
    }
}
  • trustCertificateKeyStorePassword=123456為密鑰倉庫的密碼,在生成密鑰倉庫文件時配置;
  • trustCertificateKeyStoreUrl=http://localhost:9999/mysql.ks為證書放置在http服務器后的地址

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • MyBatis如何使用PageHelper實現分頁查詢

    MyBatis如何使用PageHelper實現分頁查詢

    這篇文章主要介紹了MyBatis如何使用PageHelper實現分頁查詢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • SpringBoot開發(fā)實戰(zhàn)系列之動態(tài)定時任務

    SpringBoot開發(fā)實戰(zhàn)系列之動態(tài)定時任務

    在我們日常的開發(fā)中,很多時候,定時任務都不是寫死的,而是寫到數據庫中,從而實現定時任務的動態(tài)配置,下面這篇文章主要給大家介紹了關于SpringBoot開發(fā)實戰(zhàn)系列之動態(tài)定時任務的相關資料,需要的朋友可以參考下
    2021-08-08
  • 詳解SpringBoot中如何使用Reactor模型

    詳解SpringBoot中如何使用Reactor模型

    Reactor模型主要提供了一種在Java虛擬機上構建非阻塞應用的方式,這種方式使用了響應式編程原理,通過響應式流標準來實現,下面我們就來看看它在SpringBoot中是如何使用的吧
    2024-04-04
  • 一篇文章帶你搞定JAVA內存泄漏

    一篇文章帶你搞定JAVA內存泄漏

    今天小編就為大家分享一篇關于Java內存泄漏問題處理方法經驗總結,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-07-07
  • Spring?controller校驗入參的方法詳解

    Spring?controller校驗入參的方法詳解

    項目中使用Springboot,在Controller中配置了@NotNull和@Valid,@Notnull不生效,@Valid生效,返回http?status為400,本文給大家介紹了Spring?controller校驗入參的方法,需要的朋友可以參考下
    2024-06-06
  • java多線程實現同步鎖賣票實戰(zhàn)項目

    java多線程實現同步鎖賣票實戰(zhàn)項目

    本文主要介紹了java多線程實現同步鎖賣票實戰(zhàn)項目,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01
  • Java的DelayQueue延遲隊列簡單使用代碼實例

    Java的DelayQueue延遲隊列簡單使用代碼實例

    這篇文章主要介紹了Java的DelayQueue延遲隊列簡單使用代碼實例,DelayQueue是一個延遲隊列,插入隊列的數據只有達到設置的延遲時間時才能被取出,否則線程會被阻塞,插入隊列的對象必須實現Delayed接口,需要的朋友可以參考下
    2023-12-12
  • Java中的CountDownLatch、CyclicBarrier和semaphore實現原理解讀

    Java中的CountDownLatch、CyclicBarrier和semaphore實現原理解讀

    這篇文章主要介紹了Java中的CountDownLatch、CyclicBarrier和semaphore實現原理詳解,CountDownLatch中調用await方法線程需要等待所有調用countDown方法的線程執(zhí)行,這就很適合一個業(yè)務需要一些準備條件,等準備條件準備好之后再繼續(xù)執(zhí)行,需要的朋友可以參考下
    2023-12-12
  • Java 注解學習筆記

    Java 注解學習筆記

    一直都在使用注解,但是一直都沒有用的很明白,后來被逼的發(fā)現不搞明白真的就沒有辦法愉快的寫代碼了,所以,這篇《Java中的注解學習筆記》就呼之欲出了
    2020-10-10
  • MyBatis如何調用存儲過程與存儲函數

    MyBatis如何調用存儲過程與存儲函數

    這篇文章主要介紹了MyBatis如何調用存儲過程與存儲函數,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11

最新評論