ホームページ  >  記事  >  Java  >  springmvc の共通アノテーション

springmvc の共通アノテーション

angryTom
angryTomオリジナル
2019-07-20 16:18:463413ブラウズ

springmvc の共通アノテーション

#推奨チュートリアル:

Spring チュートリアル

#1. コンポーネント タイプのアノテーション:

1. @Component クラス定義の前に @Component アノテーションを追加すると、 Spring コンテナの識別と Bean への変換です。

2. @Repository は Dao 実装クラス (特別な @Component) にアノテーションを付けます

3. @Service は、ビジネス ロジック層 (特別な @Component) に注釈を付けるために使用されます (特別な @Component)

4. @Controller は、コントロール層に注釈を付けるために使用されます (特別な@Component)

上記 4 つのアノテーションはすべてクラスにアノテーションが付けられており、アノテーションが付けられたクラスは Spring によって Bean として初期化され、統一的に管理されます。

springmvc の共通アノテーション

## 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 である必要があります。

このようにして、アノテーションを通じてリクエストを制限できます。 springmvc の共通アノテーション

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";
    }

このパスは {myname} をパス パラメータとして宣言します。その後、このパスは任意の値を指定すると、@PathVariable は値に基づいてパスの値を取得できます。

4.@ResponseBody: メソッドに基づいて動作し、戻り結果全体を特定の形式 (json やXML 形式。

@RequestMapping("/{myname}/pathVariable2.do")    public String pathVariable2(@PathVariable(value = "myname") String name){
        System.out.println("myname = "+name);        return "index";
    }

springmvc の共通アノテーション## ページは返されませんが、文字列「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了

1068779-20171027175359008-1504110330 (1).png

注意:@ModelAttribute("user") UserEntity user获取注解内容的时候,会先查询session中是否有对应的属性值,没有才去查询Model。

以上がspringmvc の共通アノテーションの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。