Spring常⽤注解和标签
标签注⼊时,属性必须要有对应name的set⽅法,否则会报错
注解和标签是SpringMVC的,//没有事物层
1、@Controller
负责DispatcherServlet分发的请求,他把⽤户的请求数据封装成Model,然后吧改Model返回给view进⾏展⽰。
特点:⽆需继承或实现某类接⼝,只需"@"标记,结合@requestMapping和@requestParam,即可被外界访问,
不依赖HttpServletRequest、httpServletResponse
@Controller标记的类如何交给Spring来管理?
1. <bean class="ller.MyController"></bean> 指定具体类
2. <context:component-scan base-package="ller"/> 指定包名
2、@RequestMapping
⽤来处理请求路径的映射,⽤在类上,表⽰该类中相应所有请求的⽅法,都应该以该路径作为⽗路径
属性:
value:指定请求的路径
method:指定请求的method类型,GET,PUT.DELETE.POST
consumes:指定处理请求的提交内容类型(Content-Type),application/json,text/html
produces:指定返回的内容类型,仅当request请求头中(Accept)的类型中包含改指定类型时才返回
params: request请求中必须包含某些指定的参数时才让该⽅法处理
header:request请求中必须包含某些指定的header值,才让该⽅法处理
3、@Resource和@Autowired
两者均做bean注⼊时使⽤的,其实@Resource是javax.annotation.Resource,需要导⼊,但Spring⽀持该注解
不同点:
Autowired:
Spring提供的注解,只按照类型注⼊。默认情况下要求依赖对象必须存在,如果允许null值,可设置reuqired属性为false,
如果还想使⽤name来注⼊ ,可结合@Qualifier注解
@Autowired
@Qualifier("userDao")
private UserDao userDao;
Resource:
有j2EE提供,@Resource有两个重要属性,name和type,特点是,指定什么,就按照哪种⽅式来注⼊
resource和autowired注解的区别public class TestServiceImpl {
@Resource(name="userDao")
private UserDao userDao; // ⽤于字段上
@Resource(name="userDao")
public void setUserDao(UserDao userDao) { // ⽤于属性的setter⽅法上
this.userDao = userDao;
注,将Resource放在set⽅法上更符合⾯向对象的思想,对set⽅法操作⽽不是直接对属性进⾏操作
4、@ModelAttribute和@SessionAttribute
代表在所有的Controller在执⾏之前,先执⾏,@ModelAttribute⽅法,可⽤于注解和⽅法参数中
【【可以把这个@ModelAttribute特性,应⽤在BaseController当中,所有的Controller继承BaseController,即可实现在调⽤Controller时,先执⾏@ModelAttribute⽅法。】】
5、@PathVarible
将请求URL中的模板变量映射到功能处理⽅法的参数上,即取出模板中的变量作为参数
@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后台控制层获取参数,类似⼀种是Parameter("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类上⾯注解。
添加剂:
1、 @RequestMapping:使⽤RequestMapping来映射request请求与处理器
指定请求路径的三种⽅式:
1.普通的具体的值 ,当然包含占位符 *
2.可以指定为含有某变量的⼀类值(URI Template Patterns with Path Variables)–restful风格;
@RequestMapping("/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") Integer id2) {
System.out.println("testPathVariable: " + id2);
return SUCCESS;
}
3.可以指定为含正则表达式的⼀类值( URI Template Patterns with Regular Expressions);
@RequestMapping("/spring-web/{symbolicName:[a-z-]+}-{version:\d\.\d\.\d}.{extension:\.[a-z]}")
public void handle(@PathVariable String version, @PathVariable String extension) {
// ...
}
}
⾼级⽤法:
requestMapping:
1.param属性:
@RequestMapping (value= "testParams" , params={ "param1=value1" , "param2" , "!param3" })
public String testParams() {
System. out .println( "" );
return "testParams" ;
}
⽤@RequestMapping 的params 属性指定了三个参数,这些参数都是针对请求参数⽽⾔的,它们分别表⽰参数param1 的值必须等于value1 ,参数param2 必须存在,值⽆所谓,参数param3 必须不存在,只有当请求/testParams.do 并且满⾜指定的三个参数条件的时候才能访问到该⽅法。所以当请求/testParams.do?param1=value1¶m2=value2 的时候能够正确访问到该testParams ⽅法,当请求/testParams.do?param1=value1¶m2=value2¶m3=value3 的时候就不能够正常的访问到该⽅法,因为在
@RequestMapping 的params 参数⾥⾯指定了参数param3 是不能存在的。
@RequestMapping (value= "testMethod" , method={RequestMethod. GET , RequestMethod. DELETE })
public String testMethod() {
return "method" ;
}
在上⾯的代码中就使⽤method 参数限制了以GET 或DELETE ⽅法请求/testMethod 的时候才能访问到该Controller 的testMethod ⽅法。
3.headers属性
@RequestMapping (value= "testHeaders" , headers={ "host=localhost" , "Accept" })
public String testHeaders() {
return "headers" ;
}
headers 属性的⽤法和功能与params 属性相似。在上⾯的代码中当请求/testHeaders.do 的时候只有当请求头包含Accept 信息,且请求的host 为localhost 的时候才能正确的访问到testHeaders ⽅法。
-----------------------------------------------------
@RequestMapping 标记的处理器⽅法⽀持的⽅法参数和返回类型
1. ⽀持的⽅法参数类型
(1 )HttpServlet 对象,主要包括HttpServletRequest 、HttpServletResponse 和HttpSession 对象。 这些参数Spring 在调⽤处理器⽅法的时候会⾃动给它们赋值,所以当在处理器⽅法中需要使⽤到这些对象的时候,可以直接在⽅法上给定⼀个⽅法参数的申明,然后在⽅法体⾥⾯直接⽤就可以了。但是有⼀点需要注意的是在使⽤HttpSession 对象的时候,如果此时HttpSession 对象还没有建⽴起来的话就会有问题。
(2 )Spring ⾃⼰的WebRequest 对象。 使⽤该对象可以访问到存放在HttpServletRequest 和HttpSession 中的属性值
(3 )InputStream 、OutputStream 、Reader 和Writer 。 InputStream 和Reader 是针对HttpServletRequest ⽽⾔的,可以从⾥⾯取数据;OutputStream 和Writer 是针对HttpServletResponse ⽽⾔的,可以往⾥⾯写数据。
(4 )使⽤@PathVariable 、@RequestParam 、@CookieValue 和@RequestHeader 标记的参数。
(5 )使⽤@ModelAttribute 标记的参数。
(6 )java.util.Map 、Spring 封装的Model 和ModelMap 。 这些都可以⽤来封装模型数据,⽤来给视
图做展⽰。
(7 )实体类。 可以⽤来接收上传的参数。
(8 )Spring 封装的MultipartFile 。 ⽤来接收上传⽂件的。
(9 )Spring 封装的Errors 和BindingResult 对象。 这两个对象参数必须紧接在需要验证的实体对象参数之后,它⾥⾯包含了实体对象的验证结果。
2. ⽀持的返回类型
(1 )⼀个包含模型和视图的ModelAndView 对象。
(2 )⼀个模型对象,这主要包括Spring 封装好的Model 和ModelMap ,以及java.util.Map ,当没有视图返回的时候视图名称将由RequestToViewNameTranslator 来决定。
(3 )⼀个View 对象。这个时候如果在渲染视图的过程中模型的话就可以给处理器⽅法定义⼀个模型参数,然后在⽅法体⾥⾯往模型中添加值。
(4 )⼀个String 字符串。这往往代表的是⼀个视图名称。这个时候如果需要在渲染视图的过程中需要模型的话就可以给处理器⽅法⼀个模型参数,然后在⽅法体⾥⾯往模型中添加值就可以了。
(5 )返回值是void 。这种情况⼀般是我们直接把返回结果写到HttpServletResponse 中了,如果没有写的话,那么Spring 将会利⽤RequestToViewNameTranslator 来返回⼀个对应的视图名称。如果视图中需要模型的话,处理⽅法与返回字符串的情况相同。
(6 )如果处理器⽅法被注解@ResponseBody 标记的话,那么处理器⽅法的任何返回类型都会通过HttpMessageConverters 转换之后写到HttpServletResponse 中,⽽不会像上⾯的那些情况⼀样当做视图或者模型来处理。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论