ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
本稿はSpring Frameworkのプロジェクトの作成~基本的な動作を説明します。
主な項目は以下の通り。
・プロジェクトの作成&初期動作確認
・DB接続(MySQLを使用)
・DI
・画面で入出力
・AOP ※AOPに関してはこちらを参照
前提
eclipse, tomcatのインストールをしている。(まだの方はこちら)
eclipseにSpringのプラグインを導入している。(まだの方はこちら)
本稿はWindows OSを前提として進めます。(読み替え可能なら他のOSでも問題なし)
プロジェクトの作成
プロジェクトの作成はこちらの記事を参照してください。
※今回のプロジェクトタイプは「Spring MVC Project」、プロジェクト名は「SpringMVC」、パッケージ名は「com.example.springmvc」にして下さい。
サーバーの設定とプロジェクトの紐づけ
こちらを参照してください。
動作確認
この段階で、とりあえずデフォルトの画面が開くかどうか動作チェックをしましょう。
サーバーを起動させた状態で以下のURLを入力して、画面が表示されるか確認しましょう。
http://localhost:8080/springmvc/
表示されない場合はもう一度、設定内容を確認してください。※特にプロジェクト作成の項目をチェック
DBの作成
データベースを使用するので、今回はMySQLを用意します。
Windowsの場合、MySQLを単独でインストールすると色々と設定がめんどくさいので、今回はXAMPPのMySQLを使用します。XAMPPのインストールはこちらを参照。
MySQLにデータベースおよびテーブルを作成しましょう。以下のコマンドを実行します。
CREATE DATABASE spring_db CHARACTER SET utf8 COLLATE utf8_bin; USE spring_db; CREATE TABLE users ( |
JDBCを記載
pom.xmlに以下の記述を追加しましょう。
<!-- JDBC --> <!-- CGLIB --> |
※ついでにCGLIBというライブラリも記載しておきましょう。このライブラリはInterfaceの実装でないbeanをInjectionする際に必要となります。
DB接続設定
「src/maim/resources」に以下の内容の「jdbc.properties」ファイルを作成しましょう。
jdbc.driverClassName=com.mysql.jdbc.Driver |
DB設定用のクラスを用意します。
「com.example.springmvc.config」パッケージを作成して、以下の内容の「DBConfig.java」を作成しましょう。
@Configuration @Autowired @Bean @Bean @Bean |
@PropertySourceで先ほど作成した「jdbc.properties」を読み込み、datasource()メソッド内で設定内容をリターンしています。
メソッド内を見るとenvironmentから設定を取得していることが分かります。
このように、読み込まれた設定情報は自動的にEnvironmentにインジェクションされます。
後述しますが、あるクラスからDBアクセスをする際にはJdbcTemplateクラスを通してDBへアクセスすることになります。
DataSourceTransactionManagerはトランザクションが発生する際に使用することになります。
DBの設定は以上となります。
DBから値を取得
それでは実際にDBから値を取得しましょう。
デフォルトで用意されているHomeControllerを以下のように書き換えましょう。
@Controller private static final Logger logger = LoggerFactory.getLogger(HomeController.class); @Autowired @RequestMapping(value = "/", method = RequestMethod.GET) Date date = new Date(); String formattedDate = dateFormat.format(date); model.addAttribute("serverTime", formattedDate); //ユーザーを取得 model.addAttribute("users", users); return "home"; } |
インジェクションしたJdbcTemplateを通じてDBにアクセスしています。
これをmodelに格納することで画面側で格納した値を使用することができるようになります。
画面への出力
デフォルトで用意されている「home.jsp」にユーザー情報を表示する処理を追加します。
usersはList<MAP<String, Object>>型なので、for文で回してMAPのキー名を指定して値を取得します。
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <P> The time on the server is ${serverTime}. </P> <c:forEach var="user" items="${users}"> </html> |
Maven ビルド
実際に画面を確認したいので、プロジェクトをMavenでビルドしましょう。
プロジェクトを右クリック → 実行 → 「Maven ビルド」を選択します。
ゴールの項目に「package」と入力して実行ボタンを押しましょう。
「BUILD SUCCESS」が表示されれば成功です。
ユーザー情報出力の確認
画面を確認してみましょう。
サーバーを起動させてhttp://localhost:8080/springmvc/にアクセスします。
上記のようにユーザー情報が表示されればOKです。(無論、本番でパスワード表示などありえないですが)
- インストール(eclipseプラグイン)
- プロジェクトの作成
- Spring Bootプロジェクトの作成
- Spring Bootプロジェクトの実行
- Spring BootでHello World!
- アノテーション一覧
- DB接続設定からエンティティおよびリポジトリの作成、値の取得まで(JPA編)
- DB接続設定や値の取得(JdbcTemplate編)
- ビューから値をモデルに格納しコントローラーで受け取る方法
- コントローラーにてモデルに値を格納してビューに渡す方法
- テンプレートエンジン
- ModelとModelAndViewの違い
- AOPの使用方法
- classpath: 内部ファイルの読み込み
- file: 外部ファイルの読み込み
- CSVファイルアップロード方法(Ajax)
- CSVファイルダウンロード方法(Ajax)
- Spring Bootプロジェクトのビルドと本番環境へのデプロイ方法(内部tomcat使用)
- Application.propertiesの環境依存設定の分割方法
- JPAにおけるEntityManagerの取得方法
- JPAにおけるjava.sql.Connectionの取得方法
- エラー一覧
- jarの引数を受け取る方法
- Spring BootでGmailからメール送信
- 複数のDBに接続する設定(Spring Boot & JPA編)
- ポート番号の変更
- Basic認証の実装と特定のURLに限定する方法
- Spring SecurityのBasic認証の無効化
- 独自のエラーページを定義する方法
- プロパティファイルの値やjar実行時の引数を取得する方法
人気ページ
最近更新/作成されたページ
- LaravelでMySQLのSTR_TO_DATE関数を使用するとnullが返却される問題 NEW! (2023-11-29 07:15:58)
- エラー一覧 (2023-11-28 21:17:33)
- Google Search Consoleとは NEW! (2023-11-25 21:22:56)
- Bing Webmaster Toolsとは NEW! (2023-11-25 21:21:25)
- 「次世代フォーマットでの画像の配信」の解決方法 NEW! (2023-11-23 01:11:03)
- 「適切なサイズの画像」の解決方法 NEW! (2023-11-23 01:06:03)
- 「アニメーション コンテンツでの動画フォーマットの使用」の解決方法 NEW! (2023-11-23 01:02:55)
- PageSpeed Insightsとは NEW! (2023-11-23 01:01:11)
- 詳細説明付きgRPCクイックスタート NEW! (2023-11-22 23:08:44)
- IT用語一覧 NEW! (2023-11-22 22:58:29)
最近コメントのあったページ
- version less than X.X is not supported. (2023-11-28 22:29:23)
- version less than X.X is not supported. (2023-11-28 02:37:37)
- version less than X.X is not supported. (2023-11-27 05:57:22)
- プロキシ (2023-11-26 01:37:44)
- プロジェクトの作成と削除 (2023-11-25 12:06:48)
- version less than X.X is not supported. (2023-11-23 20:33:16)
- プロジェクトの作成と削除 (2023-11-23 07:33:38)
- プロジェクトの作成と削除 (2023-11-23 05:07:37)
- version less than X.X is not supported. (2023-11-22 23:07:25)
- version less than X.X is not supported. (2023-11-22 01:49:54)
最近の質問
- c.wiki (2023-09-14 10:51:04)
- $(document).ready(function() { ... ってなに? (2023-04-17 11:02:56)
- 質問です (2020-02-20 12:19:36)
- フリーランスの単価って高いですか? (2020-02-12 19:56:16)
- 情報系のaoを受けるつもりなんですが何かおすすめのソフトはありますか? (2020-02-12 19:54:22)
- test3 (2020-02-08 23:50:54)
- セレクトボックスのCSSのcontentで三角の部分が押せない (2019-07-03 13:06:10)
- GCPのwp-config.phpでpermission denied (2019-06-05 20:04:08)
- Spring FrameworkのEntityのカラム名の大文字小文字、アンスコについて (2019-02-01 07:13:49)
- PHP(Laravel)からPythonのプログラムを呼び出したいのですがどうすればよいでしょうか。 (2018-12-06 06:26:57)
- djangoを本番環境にデプロイしたいのですがどのレンタルサーバー or VPSサーバーがよいですか (2018-12-01 12:04:18)
- Django administrationのUsernameとPasswordについて (2018-11-30 11:55:20)
- Google Adsenseでアダルトコンテンツと誤認されてしまいました。 (2018-09-09 17:15:36)
- Google MapsをUnityで使用する方法&料金 (2018-08-28 02:37:26)
- Amazon PA-APIのSort=salesrankが効かない (2018-07-21 08:54:25)
- 楽観ロックと悲観ロックの違い (2018-01-11 05:05:33)
- レンタルサーバーって沢山ありますけどどこがいいでしょうか?AWSってどうなんですか? (2018-01-09 10:03:20)
- ディープラーニングのライブラリってどれがオススメですか? (2018-01-06 05:15:40)
- Webスクレイピングってどこまでが違法なんでしょうか? (2018-01-06 05:09:08)
- 人工知能(AI)、機械学習、ディープラーニングの違い (2018-01-06 02:40:44)
コメントを削除してもよろしいでしょうか?
コメントがありません