文章目录
Spring注解@Resource和@Autowired区别对比
参考链接:https://www.cnblogs.com/think-in-java/p/5474740.html
原博主GItHub:github:https://github.com/chenqimiao/
@Resource和@Autowired都是做bean的注入时使用,其实@Resource并不是Spring的注解,它的包是javax.annotation.Resource,需要导入,但是Spring支持该注解的注入。
- 1、共同点
两者都可以写在字段和setter方法上。两者如果都写在字段上,那么就不需要再写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值,可以设置它的required属性为false。如果我们想使用按照名称(byName)来装配,可以结合@Qualifier注解一起使用。如下:
public class TestServiceImpl {
@Autowired
@Qualifier("userDao")
private UserDao userDao;
}
- (2)@Resource
@Resource默认按照ByName自动注入,由J2EE提供,需要导入包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装配顺序:
①如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常。
②如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常。
③如果指定了type,则从上下文中找到类似匹配的唯一bean进行装配,找不到或是找到多个,都会抛出异常。
④如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配。
@Resource的作用相当于@Autowired,只不过@Autowired按照byType自动注入。
注解@RequestParam与@PathVariable如何获取参数
- @PathVariable的使用
@PathVariable绑定URI模板变量值;
@PathVariable是用来获得请求url中的动态参数;
@PathVariable用于将请求URL中的模板变量映射到功能处理方法的参数上。
//配置url和方法的一个关系@RequestMapping(“item/{itemId}”)
//下面演示两种用法
@RequestMapping("name/{nameId}")
Public String login(@PathVariable(value="nameId") String nameId){
//此处就能获取到nameId的值了
}
@RequestMapping("name/{nameId}/{where}")
public String login(@PathVariable(value="nameId") String nameId,@PathVariable(value="where" String where)){
//此处就能获取到nameId,和where的值了
}
- @RequestParam的使用
@RequestParam注解主要有哪些参数:
value:参数名字,即入参的请求参数名字,如username表示请求的参数区中的名字为username的参数的值将传入;
required:是否必须,默认是true,表示请求中一定要有相应的参数,否则将报404错误码;
defaultValue:默认值,表示如果请求中没有同名参数时的默认值,例如:
//-------我能想到的用法
//第一种用法
@RequestMapping(/value/tt)
public List<EasyUITreeNode> getItemTreeNode
(@RequestParam(value="id",defaultValue="0") long parentId)
//第二种用法
@RequestMapping(/value/tt)
public String doIt(@RequestParam String name){
//name 默认为必须传入的值
}
//第三中用法
@RequestMapping(/value/tt)
public String doIt(@RequestParam Map<String,String> map){
//传入的值通过map.get("参数")来获取
转发和重定向
个人理解
转发是服务器行为,重定向是客户端行为
转发过程只能在同一容器下
重定向可以到另外的容器
网上另一个博主讲的很清楚:https://www.cnblogs.com/Bhi9712/p/7270360.html
@requestMapping("/user")
public class UserController{
@requestMapping("save")
public String save(){
//转发
return "forward:/user/update.do";
}
@requestMapping("update")
public String update(){
//重定向
return "rediect:/user/save.do";
}
}
不常用注解@ModelAttribute和 @SessionAttributes
@ModelAttribute和 @SessionAttributes暂时没用到,用到再写