>Java >java지도 시간 >springmvc 공통 주석

springmvc 공통 주석

angryTom
angryTom원래의
2019-07-20 16:18:463452검색

springmvc 공통 주석

추천 튜토리얼: Spring 튜토리얼

1. 컴포넌트 주석:

1. 클래스 정의 앞에 주석을 달면 그는 스프링 컨테이너에서 인식되어 빈으로 변환됩니다.

2. @Repository는 Dao 구현 클래스에 주석을 추가합니다(특수 @Component)

3. @Service는 비즈니스 로직 레이어에 주석을 추가하는 데 사용됩니다(특수 @Component). 4. @Controller는 제어 레이어 주석에 사용됩니다. (특수 @Component)

위의 네 가지 주석은 모두 클래스에 주석이 추가됩니다. 주석이 달린 클래스는 Spring에 의해 Bean으로 초기화되고 통합 관리됩니다.

2. 요청 및 매개변수 주석:

springmvc 공통 주석

1. @RequestMapping: 클래스 및 메서드에 적용할 수 있는 요청 주소 매핑을 처리하는 데 사용됩니다.

 ●value : 요청 요청의 매핑 주소 정의

 ●method : [GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE.] 등 주소 요청 방법을 정의합니다. 기본적으로 요청을 받습니다. 요청 방법이 정의된 방법과 다르면 요청이 성공하지 않습니다.

 ●params: 요청 요청에 반드시 포함되어야 하는 매개변수 값을 정의합니다.

 ●Headers: 요청 요청에 특정 요청 헤더가 포함되어야 함을 정의합니다. 예: RequestMapping(value = "/something", headers = "content-type=text/*")는 요청에 "/something"이 포함되어야 함을 나타냅니다. text/html", "text/plain"의 Content-type 헤더가 일치하는 요청입니다.

 ●consumes: 제출을 요청하는 콘텐츠 유형을 정의합니다.

 ●Produces: 반환할 콘텐츠 유형을 지정합니다. 요청 헤더의 (Accept) 유형에 지정된 유형이 포함된 경우에만 반환됩니다.

@RequestMapping(value="/requestTest.do",params = {"name=sdf"},headers = {"Accept-Encoding=gzip, deflate, br"},method = RequestMethod.GET)
     public String getIndex(){
         System.out.println("请求成功");
         return "index";
     }

 위 코드는 요청 방법이 GET 요청 및 요청 매개변수에는 매개변수 name=sdf가 포함되어야 하며, 요청 헤더에는 Accept-Encoding=gzip, deflate, br 헤더 유형이 있어야 합니다.

이런 식으로 주석을 통해 요청을 제한할 수 있습니다. springmvc 공통 주석

2.@RequestParam: 들어오는 매개변수의 값을 가져오는 데 사용됩니다

 ●value: 매개변수의 이름

 ●required: 들어오는 매개변수가 필수인지 여부를 정의하며 기본값은 true입니다. @RequestMapping의 params 속성 약간 비슷함)

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

두 가지 매개변수 입력 방법은 동일합니다. 선언된 값의 이름이 표시되는 경우에는 표시 선언이 없는 경우 매개변수 이름이 값과 동일합니다. 첫 번째 방법으로 선언하면 매개변수 이름과 함수 매개변수가 동일하게 입력됩니다. @PathViriable: 경로 매개변수 값을 정의하는 데 사용됩니다. {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";
    }

  페이지를 반환하지 않고 "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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.