こんにちは。バックエンドエンジニアの奥村です。
javaの環境構築記事はまだまだeclipseが多いので、今回はvscodeでspring bootの環境構築を行います。
事前準備
事前にvscodeの拡張をインストールしておきます。
以下をインストールしておくことで、補完機能など使えるようになります。
- Etension Pack for Java
- Spring Boot Extension Pack
spring boot プロジェクト生成
コマンドパレットから、Gradleプロジェクトのspring bootを選択します
data:image/s3,"s3://crabby-images/b0279/b027973684866ff2311ef5a70216851fe197a309" alt=""
spring bootのバージョンを選択します。
data:image/s3,"s3://crabby-images/0ffe2/0ffe2937f40fb7a2756a24de0e48f14d3a1df123" alt=""
言語を選択します。今回はjavaなのでjavaを選択します。
data:image/s3,"s3://crabby-images/112c2/112c29534e87e01abcd59ebdfc79476ebbd05e7d" alt=""
パッケージ名を入力します。
data:image/s3,"s3://crabby-images/236c4/236c4e11b5227ff3b4ef98155188091e12a6f9e8" alt=""
プロジェクト名を入力します。
data:image/s3,"s3://crabby-images/37290/37290f83e30223adacad2d98d83cd7ef3406293d" alt=""
パッケージタイプはjarを選択します。
data:image/s3,"s3://crabby-images/95554/955540e30f9fd98acf8e7579371dd997a42187fa" alt=""
javaのバージョンを選択します。
data:image/s3,"s3://crabby-images/c0612/c0612b471eb1e2bad4cb4bccd3e44f3aada069df" alt=""
ライブラリを選択します。ここで選択したライブラリはbuild.gradelのdependenciesに入ります。
data:image/s3,"s3://crabby-images/c8838/c88387c3757ed304f60c79377fc7b442079ba131" alt=""
Spring Web | |
Lombok | setterやgetterなどの冗長なコードの記述を省けます |
Spring Boot DevTools | ファイルを保存した瞬間に、webアプリケーションを自動で再起動してくれます |
Thymeleaf | spring_bootが標準で使うテンプレートエンジンです |
ライブラリを選択し、Enterを押すと以下のような構造でファイルができます
data:image/s3,"s3://crabby-images/92730/92730f7e49937f4f77f48ea6af316e73e74d4c80" alt=""
Hello Worldを出力
今回memoアプリの作成を行いたいと思いますが、まずはhello wroldを出力するところまで書きたいと思います。
src/main/resources/templates配下にindex.htmlを作成します。
data:image/s3,"s3://crabby-images/2981c/2981cb1703f53dfcc6eba677d603a268d784f67d" alt=""
<!DOCTYPE html>
<html>
<head>
<title>hello world</title>
</head>
<body>
<h2>Hello World</h2>
</body>
</html>
data:image/s3,"s3://crabby-images/9b000/9b00041113806c334395f2d68ee47154864cc210" alt=""
src/main/java/com/example/memo/配下にcontroller/MemoController.javaを作成します
package com.example.memo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* controller
*/
@Controller
public class MemoController {
@RequestMapping("index")
public String index() {
return "index";
}
}
indexメソッドでreturn indexをしている部分でindex.htmlを返しています。
実行
上部にある実行ボタンを押すと、コンパイルとサーバーの起動を行ってくれる
data:image/s3,"s3://crabby-images/4e1e6/4e1e680ce19bd394c3e634c40e70d2249ab11f84" alt=""
localhost:8080にアクセスすると、hello worldの表示が確認できた
data:image/s3,"s3://crabby-images/7983e/7983ed61eb5c05626364a4bac819aa15864f4a3c" alt=""