mac環境にて,Visual Studio Code を用いて Spring を使うための準備を備忘録として残す.
VScodeのプラグイン
以下の2つを利用する.ない場合はvscodeにて適宜ダウンロード.
- Extension Pack for Java
- Spring Boot Extension Pack
プロジェクトの作成手順
コマンドパレットからプロジェクトを作成する.
cmd+Shift+P からコマンドパレットを起動し,「Spring Initializr: Create a Gradle Project….」を選択する.
data:image/s3,"s3://crabby-images/259ab/259ab2a4efba6cfd1cc9c4b8f2aa43a7be94b3e3" alt=""
以下,画像の順番に設定をしていく.
data:image/s3,"s3://crabby-images/f8d33/f8d336850e141c80a9f91c5ffe0b2bc867197ed8" alt=""
data:image/s3,"s3://crabby-images/7e48a/7e48ab33376f8f9758ff19fb487a08553dee26d8" alt=""
data:image/s3,"s3://crabby-images/e1354/e135461fafe91ffab772705e685bc711584901b0" alt=""
data:image/s3,"s3://crabby-images/4473a/4473a44041a7ff52291280765a8548cd55811a34" alt=""
data:image/s3,"s3://crabby-images/b4322/b4322dc2fb19b9d826d2f6f513d09b16dea1f22a" alt=""
data:image/s3,"s3://crabby-images/266d0/266d04c46a7c071bb16f888185b25d7b9ba96ef2" alt=""
data:image/s3,"s3://crabby-images/b8026/b8026e48201358d249d4b62341c1c9b61b470be8" alt=""
あとは作成するディレクトリを選択して完了.
- Thymleafはテンプレートエンジン, javaファイル内の文字列をhtmlに表示する際に利用
- Lombokは Getter, Setter などをコンパイル時に自動生成してくれるソフト
Tutorial: Using Thymeleaf (ja)
Project Lombok
プロジェクト作成のルール
Springのプロジェクトが作成されると,以下のディレクトリ構成で出来上がる.
以下の3つのディレクトリにて作業をしていく.
data:image/s3,"s3://crabby-images/a5cbc/a5cbcbc238fa8cae45d97bddbd698bc068cd8a18" alt=""
- javaのファイルは
java/com/example/helloworld
内に配置 - htmlファイルは
templates
ディレクトリ内に配置 - css,jsファイルは
static
ディレクトリ内に配置
上記のファイル配置のルールを守らないとファイルが読み込まれないので気を付ける.
コントローラの作成
java/com/example/helloworld
にHelloController.javaを作成する.
//HelloController.java
package com.example.helloworld;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class HelloController {
@GetMapping("/hello")
public String hello(){
return "hello";
}
}
MVCモデルにおける,Controllerの役割を果たすファイルに該当します.
- @Controllerをつけることで,このクラスがコントローラであることを明示
- @GetMappingでルーティングを指定
hello()
メソッドの返り値について templates/hello.html
をレンダリングして返していることに注意..html
が明示されていないことに注意が必要.
ビューファイルの作成
templates
ディレクトリにhello.htmlを作成する.
<html>
<head>
<meta charset="UTF-8" />
<title>hello world</title>
</head>
<body>
<p>Hello World</p>
</body>
</html>
プログラムの起動
java/com/example/helloworld
/HelloworldApplication.javaにて,Runコマンドをクリックするとアプリが起動する.
data:image/s3,"s3://crabby-images/96307/96307fe5b04ad0d43f93529153f7cd6d1412a06a" alt=""
http://localhost:8080/hello をブラウザに入力すると,以下のように Hello World の表示が出てきます.
data:image/s3,"s3://crabby-images/90797/907975be2d907c7a5a5fde1b7082f1f612ec52a4" alt=""
- URLに書いた /hello とGetMappingアノテーション
@GetMapping("/hello")
の文字列は同じ文字列でないとエラーになる - 8080はポート番号を意味
Webサーバに接続するまでの流れとポート番号 | ITSakura
まとめ
VSCodeで JavaのSpring boot を使う準備方法について備忘録をまとめた.