------------恢复内容开始------------
作用:用在接口类上,在编译之后会生成相应的接口实现类,是mybatis的注解。
位置:对应的某个接口类上面
如果想要每个接口都要变成实现类,那么需要在每个接口类上加上@Mapper注解,比较麻烦,解决这个问题用 @MapperScan
@Mapper 是对单个类的注解。是单个操作。
}
@MapperScan{
扫描mapper类的注解,就不用在每个mapper类上加@Mapper了
@MapperScan 是对整个包下的所有的接口类的注解。是批量的操作。
}
@Resource{
注入
@Resource默认按照ByName自动注入,由J2EE提供,
需要导入包javax.annotation.Resource。@Resource有两个重要的属性:name和type,
而Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。
所以,如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略
。如果既不制定name也不制定type属性,这时将通过反射机制使用byName自动注入策略。
@Resource装配顺序:
①如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常。
②如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常。
③如果指定了type,则从上下文中找到类似匹配的唯一bean进行装配,找不到或是找到多个,都会抛出异常。
④如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,
则回退为一个原始类型进行匹配,如果匹配则自动装配。
}
@Autowired{
注入
@Autowired为Spring提供的注解,需要导入包org.springframework.beans.factory.annotation.Autowired;
只按照byType注入。
一般配合@Repository使用
@Autowired注解是按照类型(byType)装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,
可以设置它的required属性为false。如果我们想使用按照名称(byName)来装配,可以结合@Qualifier注解一起使用。
@Repository
public interface USerDao extends BaseDao<AppealInfo>{
...
}
public
class
TestServiceImpl {
@Autowired
@Qualifier
(
"userDao"
)
private
UserDao userDao;
}
@RequestMapping(path = "/login", method=RequestMethod.POST,params={"username=kolbe","password=123456"}){
value:指定请求的实际地址,指定的地址可以是URI Template模式。
method:指定请求的method类型,GET、POST、PUT、DELETE等。
consumes:指定处理请求的提交内容类型(Content-Type),例如application/json、application/xml、text/html等。
produces:指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回。
params:指定request中必须包含某些参数值才让该方法处理。
headers:指定request中必须包含某些指定的header值,才能让该方法处理请求
}
@ResponseBody{
@ResponseBody的作用其实是将java对象转为json格式的数据。
}
@RestController{
//
//@ResponseBody
//@Controller
//@RestController是上面两个注解的合体
}
原文:https://www.cnblogs.com/wangjing1997/p/15009816.html