SpringMVC--常用注解(详解)


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


@Controller

注解作用:

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

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

对比ssh注入方式:

对比spring.xml 向bean注入Service


	

@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~。



你可能感兴趣的:(前端)