SpringMVC 공통 주석
1, @Controller
SpringMVC에서 Controller는 DispatcherServlet이 배포한 요청을 처리하는 역할을 담당합니다. 사용자가 요청한 데이터를 처리하고 이를 Model에 캡슐화합니다. 비즈니스 처리 계층에 의해 처리된 후 모델을 해당 뷰로 반환하여 표시합니다. SpringMVC는 컨트롤러를 정의하는 매우 간단한 방법을 제공합니다. 특정 클래스를 상속하거나 특정 인터페이스를 구현할 필요가 없습니다. 클래스를 컨트롤러로 표시하기 위해 @Controller를 사용하고 @와 같은 주석을 사용하면 됩니다. RequestMapping 및 @RequestParam을 정의하여 URL 요청과 컨트롤러 메서드를 매핑하여 외부에서 컨트롤러에 액세스할 수 있도록 합니다. 또한 Controller는 HttpServletRequest 및 HttpServletResponse와 같은 HttpServlet 개체에 직접 의존하지 않으며 Controller의 메서드 매개 변수를 통해 유연하게 얻을 수 있습니다.
@Controller는 클래스를 표시하는 데 사용됩니다. 표시된 클래스는 SpringMVC 컨트롤러 개체입니다. 디스패치 프로세서는 주석이 달린 클래스의 메서드를 스캔하고 해당 메서드에 @RequestMapping 주석이 붙어 있는지 감지합니다. @Controller는 컨트롤러 클래스를 정의할 뿐이며 @RequestMapping이라는 주석이 달린 메서드는 실제로 요청을 처리하는 프로세서입니다. 단순히 클래스에 @Controller 마크를 사용하는 것만으로는 그것이 SpringMVC의 컨트롤러 클래스라고 말할 수 없습니다. 왜냐하면 현재 Spring은 이를 인식하지 못하기 때문입니다. 그렇다면 이를 인식하기 위해 Spring을 어떻게 사용합니까? 이때 관리를 위해 이 컨트롤러 클래스를 Spring에 넘겨주어야 합니다. 두 가지 방법이 있습니다.
(1) SpringMVC 구성 파일에 MyController의 Bean 객체를 정의합니다.
(2) SpringMVC 구성 파일에서 @Controller로 표시된 컨트롤러를 찾을 수 있는 위치를 Spring에 알려줍니다.
<!--方式一--> <bean class="com.host.app.web.controller.MyController"/> <!--方式二--> < context:component-scan base-package = "com.host.app.web" />//路径写到controller的上一层(扫描包详解见下面浅析)
2.@RequestMapping
RequestMapping은 요청 주소 매핑을 처리하는 데 사용되는 주석이며 클래스나 메서드에서 사용할 수 있습니다. 클래스에서 사용된다는 것은 요청에 응답하는 클래스의 모든 메서드가 이 주소를 상위 경로로 사용한다는 의미입니다.
RequestMapping 주석에는 6개의 속성이 있습니다. 아래에서는 설명을 위해 이를 세 가지 범주로 나눕니다(해당 예는 아래에 있음).
1. 값, 메소드;
값: 요청의 실제 주소를 지정합니다. 지정된 주소는 URI 템플릿 모드일 수 있습니다(나중에 설명됨).
method: 요청의 메소드 유형을 지정합니다. , PUT, DELETE 등
2, Consumers, presents
consumes: application/json, text/html과 같은 처리 요청의 제출 콘텐츠 유형(Content-Type)을 지정합니다.
produces: 콘텐츠를 지정합니다. 요청 헤더가 지정된 경우에만 반환되는 유형
3. params, headers
params: 지정된 요청은 그 앞에 특정 매개변수 값을 포함해야 합니다. 이 방법으로 처리할 수 있습니다.
헤더: 이 메서드가 요청을 처리하려면 지정된 요청에 지정된 특정 헤더 값이 포함되어야 합니다.
3. @Resource와 @Autowired
@Resource와 @Autowired는 모두 Bean 주입에 사용됩니다. 실제로 @Resource는 Spring의 주석이 아닙니다. 가져왔지만 Spring은 이 주석의 주입을 지원합니다.
1. 공통점
둘 다 필드와 세터 메소드에 작성할 수 있습니다. 둘 다 필드에 기록되면 setter 메소드를 작성할 필요가 없습니다.
2. 차이점
(1) @Autowired
@Autowired는 Spring에서 제공하는 주석이며 org.springframework.beans.factory.annotation.Autowired 패키지로 가져와야 하며 byType에 따라서만 주입됩니다.
public class TestServiceImpl { // 下面两种@Autowired只要使用一种即可 @Autowired private UserDao userDao; // 用于字段上 @Autowired public void setUserDao(UserDao userDao) { // 用于属性的方法上 this.userDao = userDao; } }
@Autowired 주석은 유형(byType)에 따라 종속 개체를 조합합니다. 기본적으로 종속 개체가 있어야 합니다. null 값이 허용되는 경우 해당 필수 속성을 false로 설정할 수 있습니다. 이름(byName)으로 조합하려면 @Qualifier 주석과 함께 사용할 수 있습니다.
public class TestServiceImpl { @Autowired @Qualifier("userDao") private UserDao userDao; }
(2) @Resource
@Resource는 기본적으로 J2EE에서 제공하는 ByName에 의해 자동 주입되며 javax.annotation.Resource 패키지를 가져와야 합니다. @Resource에는 name과 type이라는 두 가지 중요한 속성이 있으며 Spring은 @Resource 주석의 name 속성을 bean의 이름으로 확인하고 type 속성은 bean의 유형으로 확인합니다. 따라서 name 속성을 사용하면 byName 자동 주입 전략이 사용되고, type 속성을 사용하면 byType 자동 주입 전략이 사용된다. name이나 type 속성이 모두 지정되지 않으면 byName 자동 주입 전략이 리플렉션 메커니즘을 통해 사용됩니다.
public class TestServiceImpl { // 下面两种@Resource只要使用一种即可 @Resource(name="userDao") private UserDao userDao; // 用于字段上 @Resource(name="userDao") public void setUserDao(UserDao userDao) { // 用于属性的setter方法上 this.userDao = userDao; } }
참고: @Resource를 setter 메서드에 배치하는 것이 가장 좋습니다. 이는 객체 지향 사고에 더 부합하고 속성을 직접 조작하는 대신 set 및 get을 통해 속성을 조작하기 때문입니다.
@Resource 어셈블리 순서:
① 이름과 유형이 동시에 지정되면 어셈블리용 Spring 컨텍스트에서 일치하는 빈만 발견됩니다. 발견되지 않으면 예외가 발생합니다.
② 이름이 지정되면 해당 이름(id)과 일치하는 Bean을 어셈블리 컨텍스트에서 검색합니다. 찾을 수 없으면 예외가 발생합니다.
3 유형이 지정되면 어셈블리 컨텍스트에서 유사하게 일치하는 고유 Bean이 발견되거나 Bean이 여러 개 발견되면 예외가 발생합니다.
④如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配。
@Resource的作用相当于@Autowired,只不过@Autowired按照byType自动注入。
4、@ModelAttribute和 @SessionAttributes
代表的是:该Controller的所有方法在调用前,先执行此@ModelAttribute方法,可用于注解和方法参数中,可以把这个@ModelAttribute特性,应用在BaseController当中,所有的Controller继承BaseController,即可实现在调用Controller时,先执行@ModelAttribute方法。
@SessionAttributes即将值放到session作用域中,写在class上面。
具体示例参见下面:使用 @ModelAttribute 和 @SessionAttributes 传递和保存数据
5、@PathVariable
用于将请求URL中的模板变量映射到功能处理方法的参数上,即取出uri模板中的变量作为参数。如:
@Controller public class TestController { @RequestMapping(value="/user/{userId}/roles/{roleId}",method = RequestMethod.GET) public String getLogin(@PathVariable("userId") String userId, @PathVariable("roleId") String roleId){ System.out.println("User Id : " + userId); System.out.println("Role Id : " + roleId); return "hello"; } @RequestMapping(value="/product/{productId}",method = RequestMethod.GET) public String getProduct(@PathVariable("productId") String productId){ System.out.println("Product Id : " + productId); return "hello"; } @RequestMapping(value="/javabeat/{regexp1:[a-z-]+}", method = RequestMethod.GET) public String getRegExp(@PathVariable("regexp1") String regexp1){ System.out.println("URI Part 1 : " + regexp1); return "hello"; } }
6、@requestParam
@requestParam主要用于在SpringMVC后台控制层获取参数,类似一种是request.getParameter("name"),它有三个常用参数:defaultValue = "0", required = false, value = "isApp";defaultValue 表示设置默认值,required 铜过boolean设置是否是必须要传入的参数,value 值表示接受的传入的参数类型。
7、@ResponseBody
作用: 该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;
8、@Component
相当于通用的注解,当不知道一些类归到哪个层时使用,但是不建议。
9、@Repository
用于注解dao层,在daoImpl类上面注解。
推荐教程:《Java教程》
위 내용은 SpringMVC 공통 주석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!