Spring Bootで使われるアノテーション
【DIに関するアノテーション】
@Autowired
クラスのフィールドに付与することで、使いたいクラスをインスタンス化し、変数に設定してくれるアノテーション。
@Component
インスタンス化させたいクラスに付与するアノテーション。
このアノテーションを付与することでDIコンテナにBeanとして登録され、@Autowiredが付与されたフィールドにインスタンスが注入される。
@Controller
インスタンス化させたいクラスに付与するアノテーションその2。
クライアントとのデータ入出力を制御する(画面からHTTPリクエストを受け付ける)クラスに付与する。
@Service
インスタンス化させたいクラスに付与するアノテーションその3。
業務ロジックを提供するクラスに付与する。
@Repository
インスタンス化させたいクラスに付与するアノテーションその4。
データベースとのやりとりを行うクラスに付与する。
@Configuration
アノテーションを使ってのDIコンテナへのBean登録が複雑な場合、JavaConfigと呼ばれるBeanを生成するクラスを作成する。そのJavaConfigに付与するアノテーション。
@Bean
@Configurationが付与されたJavaConfig内のインスタンスを生成するメソッドに付与するアノテーション。
実装例
@Configuration
@Scope
インスタンスの生成・破棄のタイミングを指定するアノテーション。
実装例
@Controller
@Primary
優先的にDIを行いたいクラスに付与するアノテーション。
【Controllerクラスに関するアノテーション】
@RestController
REST API 用のControllerクラスに付与するアノテーション。
クラスにつけることでそのクラス内のメソッドの戻り値がHTTPのレスポンスボディとして返される。
@RequestMapping
リクエストURLに対して、どのクラス・メソッドが処理を実行するか定義するアノテーション。クラスあるいはメソッドに付与する。
GET・POSTといったHTTPメソッドを指定する「method」属性とURLのパスを指定する「value」属性を指定できる。
実装例
@GetMapping
@RequestMappingのGETリクエスト用アノテーション。
使用することで@RequestMappingで記述していたmethod属性を省略することができる。
@PostMapping
@RequestMappingのPOSTリクエスト用アノテーション。
@RequestParam
URLに含まれるクエリパラメータや、リクエストボディに含まれるパラメータを受け取るために使用するアノテーション。
下記属性を指定できる。
- name属性・value属性:リクエストパラメータを指定する。nameとvalueの役割に違いはない。
- required属性:パラメータはデフォルトでは必須になるため、パラメータの指定を任意にする場合、falseを指定する。
- defaultValue属性:リクエストパラメータが指定されなかった時のデフォルト値を指定する。
実装例
@GetMapping(value
@PathVariable
URLに含まれる動的なパラメータを受け取るためのアノテーション。
@RequestParamはクエリパラメータから値を抽出するのに対し、@PathVariableはURLパスから値を抽出する。
D実装例
@GetMapping(value
@ControllerAdvice
クラスに付与することで全てのControllerで共有するメソッドを用意することができるアノテーション。アプリケーション全体で共通化したい例外処理などに使用する。
以下のアノテーションがついたメソッドのみController間で共有できる。
@ExceptionHandler
メソッドに付与することで例外処理を実装できるアノテーション。
アノテーションの引数に例外クラスを指定することで、例外毎の処理を用意できる。
@InitBinder
@RequestParamや@PathVariableなどで受け取った値をオブジェクトにバインド(設定)する際に行う処理を定義できるアノテーション。
空文字の文字列項目をnullに変換する、文字列の空白を取り除く、といった処理を定義できる。
@ModelAttribute
指定したクラスにリクエストパラメータをバインドするアノテーション。
メソッドまたはメソッドの引数に付与できる。
SampleController.java
@RestController
SampleData.java
@Data
【Serviceクラスに関するアノテーション】
@Transactional
クラス・メソッドに付与することで、例外が発生すると自動でロールバックされるアノテーション。
非検査例外(RuntimeException)及びそのサブクラスが発生した場合はロールバック(実行前への巻き戻し)されるが、検査例外(Exception及びそのサブクラスでRuntimeException以外)が発生した場合は、ロールバックされずコミット(処理の確定)される。
【Repositoryクラスに関するアノテーション】
@Data
クラスに付与することで全フィールドに対してgetter/setterでアクセスすることができるようになるアノテーション。
hasCode()メソッドやequals()メソッド、toString()メソッドを自動生成してくれる。
@Entity
エンティティクラスであることを示すアノテーション。
データベースのテーブルとマッピングするクラスにつけつろ、クラス名と同じテーブル名を生成してくれたりする
@Table
テーブル名を設定するアノテーション。
通常はクラス名と同じテーブル名のデータをマッピングするため、クラス名とテーブル名が異なる場合はマッピングしたいテーブル名を設定する。
@Id
フィールドに付与し、主キーであることを示すアノテーション。
@Transient
マッピングしたくない(データベースに保存しない)フィールドに付与するアノテーション。
@Query
メソッドに付与することで任意のSQLを実行できるメソッドを用意できるアノテーション。
アノテーションの引数にクエリを書く。
@Modifying
@Queryアノテーションを使ってinsert・update・deleteをする際に必ず不要する必要があるアノテーション。
実装例
@Modifying
@JoinColumn
テーブル結合時、条件となる結合先テーブルのカラム名を指定するためのアノテーション。
結合先の情報となるフィールドに付与する。
name属性に結合先のキーとなるカラム名を指定する。
@OneToOne
テーブルと結合先テーブルが一対一の関係の場合に付与するアノテーション。
@OneToMany
テーブルと結合先テーブルが一対多の関係の場合に付与するアノテーション。
@ManyToOne
テーブルと結合先テーブルが多対一の関係の場合に付与するアノテーション。
実装例
@Entity
【バリデーションに関するアノテーション】
@Validated
バリデーション(入力チェック)を行いたいパラメータ・クラスに付与するアノテーション。
@GroupSequence
バリデーションの実行順を指定するアノテーション。
左に設定されたものから実行していく。
@DataTimeFormat
フォーマットを指定することで、受け取った値を日付型に変換するアノテーション。
@NumberFormat
フォーマットを指定することで、受け取った値を数値型に変換するアノテーション。
@NonNull
nullでないことをチェックするアノテーション。
※空文字・空白はOKになる
@NotEmpty
nullまたは空文字でないことをチェックするアノテーション。
※空白はOKになる
@NotBlank
null・空文字・空白でないことをチェックするアノテーション。
@Max
指定した値以下であるかをチェックするアノテーション。
@Min
指定した値以上であるかをチェックするアノテーション。
@Size
文字列の長さやListのsizeが指定した範囲内になるかチェックするアノテーション。
@AssertTrue
trueかどうかをチェックするアノテーション。
@AssertFalse
falseかどうかをチェックするアノテーション。
@Pattern
指定した正規表現に一致するかをチェックするアノテーション。
SampleData.java
@Data
SampleController.java
@RestController
【AOPに関するアノテーション】
@Aspect
横断的関心事を実装したメソッドであるAdviceを記述するAspectクラスに付与するアノテーション。
@Before
中心的関心事の呼び出し前に実行したいメソッドに付与するアノテーション。
@After
中心的関心事の呼び出し後に実行したいメソッドに付与するアノテーション。
@AfterReturning
中心的関心事が正常終了した後に実行したいメソッドに付与するアノテーション。
@Around
中心的関心事の呼び出し前・呼び出し後に実行したいメソッドに付与するアノテーション。
@AfterThrowing
中心関心事が例外をスローした後に実行するメソッドに付与するアノテーション。
@annotation
指定したアノテーションがついているメソッドを実行対象として指定するアノテーション。
実装例
// @GetMappingが付与されたメソッドの呼び出し前に実行する
@within
指定したアノテーションがついているクラスの全てのメソッドがAOPの対象となる。
実装例
// @Controllerが付与されたクラスの全メソッドの呼び出し前に実行する
【セキュリティに関するアノテーション】
@EnableWebSecurity
クラスに付与することでセキュリティ設定クラスを実装できるアノテーション。
実装時は、@Configurationをクラスに付与すること・WebSecurityConfigurerAdapterクラスを継承する必要がある。