質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

解決済

1回答

1871閲覧

JavaからMySQLへデータ追加する際、SSLのエラーについて

aminoxx_vg

総合スコア8

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2018/01/24 02:59

前提・実現したいこと

Javaで入力してもらったデータをMySQLのDBへ追加する部分を作成しています。
研修中で、SSLについては特に明記されておらず、使用の有無はどちらでも構わないとのことです。
SSLの知識が乏しく、何故このエラーが出てくるのかもわからない状況です。
このエラーメッセージの対応の仕方をご教授願います。
よろしくお願いします。

発生している問題・エラーメッセージ

Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification. サーバーの身元確認なしにSSL接続を確立することは推奨されません。 MySQL 5.5.45+、5.6.26+、5.7.6+の要件明示的なオプションが設定されていない場合、デフォルトでSSL接続を確立する必要があります。 SSLを使用しない既存のアプリケーションに準拠するため、verifyServerCertificateプロパティは 'false'に設定されています。 useSSL = falseを設定して明示的にSSLを無効にするか、useSSL = trueに設定してサーバー証明書の検証にtruststoreを指定する必要があります。

該当のソースコード

Java

1try { 2 Class.forName("com.mysql.jdbc.Driver"); 3 // JDBCドライバの登録 4 String driver = "org.gjt.mm.mysql.Driver"; 5 // データベースの指定 6 String server = "localhost"; // MySQLサーバ ( IP または ホスト名 ) 7 String dbname = "masta"; // データベース名 8 String url = "jdbc:mysql://" + server + "/" + dbname + "?useUnicode=true&characterEncoding=EUC_JP"; 9 String user = "root"; // データベース作成ユーザ名 10 String password = "root"; // データベース作成ユーザパスワード 11 Class.forName (driver); 12 // データベースとの接続 13 Connection con = DriverManager.getConnection(url, user, password); 14 // テーブル照会実行 15 Statement stmt = con.createStatement (); 16 String sql = "INSERT INTO masta ( 社員コード,社員名,部署,郵便番号,住所,電話番号,性別 ) VALUES (" 17 + cord + "," + name + "," + depa + "," + num + "," + add + "," + cal + "," + kind +");"; //sql文 18 ResultSet rs = stmt.executeQuery (sql); // 19 20 // データベースのクローズ 21 rs.close(); 22 stmt.close(); 23 con.close(); 24 } catch (SQLException e) { 25 System.err.println("SQL failed."); 26 e.printStackTrace (); 27 } catch (ClassNotFoundException ex) { 28 ex.printStackTrace (); 29 }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/01/24 03:19

対策:「サーバーの身元確認なしにSSL接続を確立することは推奨されません。 MySQL 5.5.45+、5.6.26+、5.7.6+の要件明示的なオプションが設定されていない場合、デフォルトでSSL接続を確立する必要があります。 SSLを使用しない既存のアプリケーションに準拠するため、verifyServerCertificateプロパティは 'false'に設定されています。 useSSL = falseを設定して明示的にSSLを無効にするか、useSSL = trueに設定してサーバー証明書の検証にtruststoreを指定する必要があります。 」と書かれてますが何がわからないのでしょうか?
退会済みユーザー

退会済みユーザー

2018/01/24 03:19

この警告はSSLの使用の有無を明確にしましょうてことです。
aminoxx_vg

2018/01/24 04:13

お返事ありがとうございます。SSL関連の記述方法を調べているのですが使い方が見つからずさまよっています。できれば参照するとよいサイトか記述例など教えて頂けますでしょうか。
guest

回答1

0

自己解決

String url = "jdbc:mysql://" + server + "/" + dbname

  • "useUnicode=true&characterEncoding=EUC_JP";


String url = "jdbc:mysql://" + server + "/" + dbname

  • "?autoReconnect=true&useSSL=false";

記述方法見つかって解決しました。

投稿2018/01/24 05:02

aminoxx_vg

総合スコア8

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問