SpringMVC--常用注解(详解)

来源:互联网 发布:软件售后服务计划书 编辑:程序博客网 时间:2024/04/29 07:43


  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方法。

        @Autowiredprivate FqGongnengService gongnengService;

action里面get,set注入

       // 注入商品的Serviceprivate ProductService productService;public void setProductService(ProductService productService) {this.productService = productService;}


@ResponseBody

注解作用:

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


@Valid

注解作用:

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

@RequestMapping(value="/editDishInfo.json", method=RequestMethod.POST)@ResponseBodypublic 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~。



1 0
原创粉丝点击