ホームページ >Java >&#&チュートリアル >springmvc でよく使用される 5 つのアノテーション
#1. コンポーネント タイプのアノテーション:
1. @Component クラス定義の前に @Component アノテーションを追加すると、 Spring コンテナの識別と Bean への変換です。
2. @Repository は Dao 実装クラス (特別な @Component) にアノテーションを付けます
3. @Service は、ビジネス ロジック層 (特別な @Component) に注釈を付けるために使用されます (特別な @Component)
4. @Controller は、コントロール層に注釈を付けるために使用されます (特別な@Component)
上記 4 つのアノテーションはすべてクラスにアノテーションが付けられており、アノテーションが付けられたクラスは Spring によって Bean として初期化され、統一的に管理されます。
## 2. リクエストとパラメータのタイプのアノテーション:
# 1 . @RequestMapping: リクエスト アドレス マッピングを処理するために使用され、クラスとメソッドに適用できます。
値: リクエストリクエストのマッピングアドレスを定義します。メソッド: [GET を含むリクエストアドレスリクエストのメソッドを定義します。 、POST、HEAD、OPTIONS、PUT、PATCH、DELETE、TRACE.] getリクエストはデフォルトで受け付けられますが、リクエストメソッドが定義されたメソッドと異なる場合、リクエストは成功しません。
Params: リクエストリクエストに含める必要があるパラメータ値を定義します。
ヘッダー: リクエスト リクエストには、次のような特定の指定されたリクエスト ヘッダーが含まれる必要があることを定義します。 RequestMapping(value = "/something", headers = "content-type=text/*" )一致するリクエストとなるためには、リクエストに「text/html」、「text/plain」の Content-type ヘッダーが含まれている必要があることを示します。
●consumes: 送信が要求されるコンテンツのタイプを定義します。
●生成: 返されるコンテンツ タイプを指定します。リクエスト ヘッダーの (Accept) タイプに指定されたタイプが含まれる場合にのみ、そのコンテンツ タイプが返されます。
## 上記のコードは、リクエスト メソッドが GET リクエストであることを示しています。リクエスト パラメータにはパラメータ name=sdf が含まれ、リクエスト ヘッダーのタイプ ヘッダーは Accept-Encoding=gzip, deflate, br である必要があります。
このようにして、アノテーションを通じてリクエストを制限できます。
2.@RequestParam: 受信パラメータの値を取得するために使用されます
値: パラメータの名前必須:定義 受信パラメータが必須かどうか、デフォルトは true (@RequestMapping の params 属性と同様)
@RequestMapping(value="/requestTest.do",params = {"name=sdf"},headers = {"Accept-Encoding=gzip, deflate, br"},method = RequestMethod.GET) public String getIndex(){ System.out.println("请求成功"); return "index"; }
パラメータを入力する 2 つの方法は同じです。と表示されるので、パラメータを入力します パラメータ名は値と同じです 明示的な宣言がない場合は、最初の方法で宣言したように、入力パラメータ名は関数パラメータの変数名と同じになります。
##3.@PathViriable: パス パラメーター値の定義に使用されます
● value: パラメータの名前#required: 受信パラメータが必須の値であるかどうかを定義@RequestMapping("/requestParams1.do")
public String requestParams1(@RequestParam(required = false) String name){
System.out.println("name = "+name);
return "index";
}
@RequestMapping("/requestParams2.do")
public String requestParams2(@RequestParam(value = "name",required = false) String names){
System.out.println("name = "+names);
return "index";
}
4.@ResponseBody: メソッドに基づいて動作し、戻り結果全体を特定の形式 (json やXML 形式。
@RequestMapping("/{myname}/pathVariable2.do") public String pathVariable2(@PathVariable(value = "myname") String name){ System.out.println("myname = "+name); return "index"; }
## ページは返されませんが、文字列「index」が出力されますこれは実際には次のコードに似ています。
PrintWriter out = resp.getWriter(); out.print("index"); out.flush();
5、@CookieValue:用于获取请求的Cookie值
@RequestMapping("/requestParams.do") public String requestParams(@CookieValue("JSESSIONID") String cookie){ return "index"; }
6、@ModelAttribute:
用于把参数保存到model中,可以注解方法或参数,注解在方法上的时候,该方法将在处理器方法执行之前执行,然后把返回的对象存放在 session(前提时要有@SessionAttributes注解) 或模型属性中,@ModelAttribute(“attributeName”) 在标记方法的时候指定,若未指定,则使用返回类型的类名称(首字母小写)作为属性名称。
@ModelAttribute("user") public UserEntity getUser(){ UserEntity userEntityr = new UserEntity(); userEntityr.setUsername("asdf"); return userEntityr; } @RequestMapping("/modelTest.do") public String getUsers(@ModelAttribute("user") UserEntity user){ System.out.println(user.getUsername()); return "/index"; }
如上代码中,使用了@ModelAttribute("user")注解,在执行控制器前执行,然后将生成一个名称为user的model数据,在控制器中我们通过注解在参数上的@ModelAttribute获取参数,然后将model应用到控制器中,在jsp页面中我们同样可以使用它,
<body> ${user.username} </body>
7、@SessionAttributes
默认情况下Spring MVC将模型中的数据存储到request域中。当一个请求结束后,数据就失效了。如果要跨页面使用。那么需要使用到session。而@SessionAttributes注解就可以使得模型中的数据存储一份到session域中。配合@ModelAttribute("user")使用的时候,会将对应的名称的model值存到session中,
@Controller @RequestMapping("/test") @SessionAttributes(value = {"user","test1"}) public class LoginController{ @ModelAttribute("user") public UserEntity getUser(){ UserEntity userEntityr = new UserEntity(); userEntityr.setUsername("asdf"); return userEntityr; } @RequestMapping("/modelTest.do") public String getUsers(@ModelAttribute("user") UserEntity user ,HttpSession session){ System.out.println(user.getUsername()); System.out.println(session.getAttribute("user")); return "/index"; } }
结合上一个例子的代码,加了@SessionAttributes注解,然后请求了两次,第一次session中不存在属性名为user的值,第二次请求的时候发现session中又有了,这是因为,这是因为第一次请求时,model数据还未保存到session中请求结束返回的时候才保存,在第二次请求的时候已经可以获取上一次的model了
注意:@ModelAttribute("user") UserEntity user获取注解内容的时候,会先查询session中是否有对应的属性值,没有才去查询Model。
以上がspringmvc でよく使用される 5 つのアノテーションの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。