EclipseからMySQL接続

環境

手順

パースペクティブ「データベース開発」を開く

データベース接続ビューから以下の接続設定を作成。

ドライバーの定義

Jar
MySQL\Connector J 8.0\mysql-connector-java-8.0.11.jar
ドライバー・クラス
com.mysql.jdbc.Driver

プロパティー

プロパティー
データベース LOCAL_MySQL8.0
URL jdbc:mysql://localhost:3306?characterEncoding=UTF-8&serverTimezone=JST
ユーザー名 root
パスワード ●●●

引っかかった点

URLをjdbc:mysql://localhost:3306にして接続しようとしたところ以下のエラーが発生。

新規 汎用 JDBC への SQL モデル接続 接続の作成中にエラーが発生しました。(エラー: The server time zone value ' (W)' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.)

MySQLタイムゾーンが設定されていないため(?)

試したこと

my.cnfにデフォルトタイムゾーンを追加
[mysqld]
default-time-zone = +9:00

⇒変化なし

タイムゾーンテーブルにレコード追加
>mysql -u root mysql -p < C:\tmp\timezone_posix.sql

⇒変化なし

URLにタイムゾーン設定を追加

?characterEncoding=UTF-8&serverTimezone=JST

⇒接続成功!

課題

参考サイト

HamcrestでSecurityException

環境

Java 9 + JUnit 4.12でも確認

現象

JUnit 4ライブラリーに加えてhamcrest-library-1.3.jarをビルドパスに加えて1org.hamcrest.Matchersを使おうとしたところ、以下の例外が発生した。

java.lang.SecurityException: class "org.hamcrest.Matchers"'s signer information does not match signer information of other classes in the same package
    at java.base/java.lang.ClassLoader.checkCerts(Unknown Source)
    at java.base/java.lang.ClassLoader.preDefineClass(Unknown Source)
    at java.base/java.lang.ClassLoader.defineClass(Unknown Source)
    at java.base/java.security.SecureClassLoader.defineClass(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.defineClass(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.findClassOnClassPathOrNull(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClassOrNull(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(Unknown Source)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(Unknown Source)
    at java.base/java.lang.ClassLoader.loadClass(Unknown Source)
    at kurukuruz.test.UnitTest.test(UnitTest.java:12)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.base/java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:538)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)
Google翻訳

クラス "org.hamcrest.Matchers"の署名者情報が、同じパッケージ内の他のクラスの署名者情報と一致しません

原因

  • JUnit 4ライブラリーのorg.hamcrest.core_1.3.0v~.jar
  • hamcrest-library-1.3.jar

の間で署名者情報が一致しないことが原因らしい。

対策

hamcrest-core-1.3.jarをダウンロードしてビルドパスに追加し、順序をJUnitライブラリーより上にする。
hamcrest-library-1.3.jarの順序はどこでもOK。

その他

ダメだった方法

参考サイトでorg.hamcrest.core_1.3.0v~.jarの名前を変えて無効化するというような意見もあったが、JUnitライブラリーがビルドエラーを起こしたので却下した。

Mavenを使っている場合

hamcrest-libraryをpom.xmlに追加し2Maven依存関係の順序をJUnitライブラリーより上にする。
 ⇒SecurityException発生……。
JUnitライブラリーをビルドパスから除去して、JUnitもpom.xmlに追加する。
 ⇒成功!

参考サイト


  1. 職場でMavenが使えないためjarをダウンロードして追加した

  2. hamcrest-coreは記述不要 (hamcrest-libraryの依存関係に含まれるため)

はてブロのデザイン設定

デザインテーマ

シンプルでサイドバーが横にあるやつ
Epicを選択

横幅の調整

960pxって狭すぎやしないか……?
cssを調整

/* 全体の幅 */
#container {
    width: 1280px;
}
/* 記事+日付の幅 */
#wrapper {
    width: 1000px;
}
/* 記事の幅 */
#main {
    width:800px;
}
/* サイドバーの幅 */
#box2 {
    width: 220px;
}

課題

  • 横幅1280px未満の人はすみません
  • スマートフォンの人もすみません(動作未確認)