您的位置:首页 > 编程语言 > Java开发

SpringMVC--常用注解(详解)

2016-01-04 18:45 531 查看
  SSH每个框架,都要有自己的xml配置文件,这些配置文件要跟源码同步,否则很容易报错。当初做网上商城项目的时候,就是因为这个原因,看的眼花缭乱,很是头疼。注解的作用跟配置文件的作用是一样的,它不仅仅包含功能性的代码实现,还可以添加元数据(对数据的描述)。但是跟注释功能一个天南一个海北,它不是用来为代码提供说明性文字的,而是实现程序功能的重要组成部分。下面,我对比的介绍一下SpringMVC常用的一些注解。

@Controller

注解作用:

注册Bean到Spring上下文,Bean的默认ID为类名称首字母小写,也可以自己指定。

@Controller
@RequestMapping("/danyuan")
public class FqDanyuanAction extends BaseAction {
}

对比ssh注入方式:

对比spring.xml 向bean注入Service
<!-- 商品模块的Action -->
<bean id="productAction" class="cn.itcast.shop.product.action.ProductAction" scope="prototype">
<property name="productService" ref="productService"/>
</bean>


@RequestMapping(value="",method={"",""},headers={},params={"",""})

参数:

value:设置访问地址

method:设置访问方式,常用的method=RequestMethod.POST,和method=RequestMethod.GET

headers:头域,可以设置浏览器支持的格式

params:访问参数设置

注解作用:

用来定义访问的url。可以是方法级别的,也可以是类级别的。两者可以协同工作,缩小选择范围。也可以隐藏代码的真实路径,更加具有安全性和可读性。

对比Servlet的get提交:

public void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{}
RequestMapping囊括了更多可配置的参数,不仅仅有提交表单的方式,而且有方法级别响应url请求的地址等信息,更加灵活。

@Autowired

注解作用:

可以对成员变量、方法和构造函数进行标注,来完成自动装配工作。可以消除get,set方法。

@Autowired
private FqGongnengService gongnengService;

action里面get,set注入

// 注入商品的Service
private ProductService productService;

public void setProductService(ProductService productService) {
this.productService = productService;
}


@ResponseBody

注解作用:

直接放在方法上,表示返回类型将会直接作为Http响应字节流输出,可以用于Ajax。


@Valid

注解作用:

实体设置+类+类的引用,直接将页面中封装的实体对象信息封装@Valid后面定义的实体中。

@RequestMapping(value="/editDishInfo.json", method=RequestMethod.POST)
@ResponseBody
public Object updateDishInfo(@Valid SnDishInfo dishInfo, BindingResult result,  HttpServletRequest request){
if(result.hasErrors()){
return getServiceErrors(result);
}
//获取当前登录用户的用户名
String loginuser = getLoginUsername(request);

dishInfo.setLmuser(loginuser);
//修改菜品分类信息
return dishInfoService.updateDishInfo(dishInfo, request);

}
有了这个注解,就不用request.getParameter("")了,jsp页面上控件的name属性  跟实体字段一样,这样不用主动获取,就能自动的拿到页面控件的值了。


@RequestParam(required=,value="",defaultValue="")

参数:

required:参数是否必须,boolean类型,默认为true

value:传递的参数名称,String类型,可选项,有值则对应方法的参数

defaultValue:参数没有传递时为参数默认指定的值

/**
* 获取单元列表数据
*
* @param scfquuid
* @param page
* @param pagesize
* @param sortname
* @param sortorder
* @param request
* @return
*/
@RequestMapping(value="/listdata.json" , method={RequestMethod.GET, RequestMethod.POST})
public ListData listdata(@RequestParam(value="leftData")String scfquuid,
Integer page, Integer pagesize, String sortname, String sortorder, HttpServletRequest request){
if(page==null){
page = 1;
}
if(pagesize==null){
pagesize = getDefaultPageSize();
}

ListData data = danyuanService.list(scfquuid, page, pagesize, sortname, sortorder);
return data;
}

leftData是页面框架中定义的全局变量,通过RequestParam就可以拿到全局变量的值,并赋值给scfquui了。


@PathVariable

注解作用:

用于方法中的参数,表示方法参数绑定到地址URL的模板

封装让我们的生活变的更加的灵活,简洁。博文如果有什么有待改进的地方,还望多多指点O(∩_∩)O~。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: