SpringMVC--常用注解(详解)
2016-01-04 18:45
531 查看
SSH每个框架,都要有自己的xml配置文件,这些配置文件要跟源码同步,否则很容易报错。当初做网上商城项目的时候,就是因为这个原因,看的眼花缭乱,很是头疼。注解的作用跟配置文件的作用是一样的,它不仅仅包含功能性的代码实现,还可以添加元数据(对数据的描述)。但是跟注释功能一个天南一个海北,它不是用来为代码提供说明性文字的,而是实现程序功能的重要组成部分。下面,我对比的介绍一下SpringMVC常用的一些注解。
注册Bean到Spring上下文,Bean的默认ID为类名称首字母小写,也可以自己指定。
对比ssh注入方式:
对比spring.xml 向bean注入Service
value:设置访问地址
method:设置访问方式,常用的method=RequestMethod.POST,和method=RequestMethod.GET
headers:头域,可以设置浏览器支持的格式
params:访问参数设置
注解作用:
用来定义访问的url。可以是方法级别的,也可以是类级别的。两者可以协同工作,缩小选择范围。也可以隐藏代码的真实路径,更加具有安全性和可读性。
对比Servlet的get提交:
可以对成员变量、方法和构造函数进行标注,来完成自动装配工作。可以消除get,set方法。
action里面get,set注入
直接放在方法上,表示返回类型将会直接作为Http响应字节流输出,可以用于Ajax。
@Valid
注解作用:
实体设置+类+类的引用,直接将页面中封装的实体对象信息封装@Valid后面定义的实体中。
@RequestParam(required=,value="",defaultValue="")
参数:
required:参数是否必须,boolean类型,默认为true
value:传递的参数名称,String类型,可选项,有值则对应方法的参数
defaultValue:参数没有传递时为参数默认指定的值
leftData是页面框架中定义的全局变量,通过RequestParam就可以拿到全局变量的值,并赋值给scfquui了。
@PathVariable
注解作用:
用于方法中的参数,表示方法参数绑定到地址URL的模板
封装让我们的生活变的更加的灵活,简洁。博文如果有什么有待改进的地方,还望多多指点O(∩_∩)O~。
@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后面定义的实体中。
@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属性 跟实体字段一样,这样不用主动获取,就能自动的拿到页面控件的值了。
参数:
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了。
注解作用:
用于方法中的参数,表示方法参数绑定到地址URL的模板
封装让我们的生活变的更加的灵活,简洁。博文如果有什么有待改进的地方,还望多多指点O(∩_∩)O~。
相关文章推荐
- [置顶] Java 23种设计模式
- 【慕课笔记】第一章 JAVA初体验 第6节 程序的移植
- Java就业前景怎么样?学了后好找工作吗?
- Java中的注解
- spring mvc 初始化错误
- Java——Java数组
- Java基础-学习笔记(二)
- java BIO实例——ServerSocket、Socket编程
- JAVA之数据溢出
- Java动态代理
- JAVA安装串口包
- Java编程思想读书笔记(一)
- java.lang.NoClassDefFoundError
- java内存分配原理
- Java调试技巧01(使用条件断点)
- Struts2 result类型为stream见解
- 根据Map中的key进行排序
- JAVA字符串格式化-String.format()的使用
- IOS Java实现消息推送(APNS)
- SSH 环境搭建(Spring3+Struts2+Hibernate3)