SpringMVC--常用注解(详解)

纵然是瞬间 提交于 2019-12-09 02:16:19

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~。
---------------------
作者:ZeroWM
来源:CSDN
原文:https://blog.csdn.net/wangmei4968/article/details/50457539
版权声明:本文为博主原创文章,转载请附上博文链接!

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!