美文网首页
springmvc使用

springmvc使用

作者: 長得太帥忚四種檌 | 来源:发表于2017-12-29 17:58 被阅读14次

    springmvc高级参数绑定

    • 数组绑定
      表单中如果有多个相同的name需要提交数据, 服务器可以使用数组的方式接收该参数!
      jsp页面:
    <table width="100%" border=1>
    <tr>
        <td>商品名称</td>
        <td>商品价格</td>
        <td>生产日期</td>
        <td>商品描述</td>
        <td>操作</td>
    </tr>
    <tr>
        <td><input name="ids" value="1" type="checkbox"></td>
        <td>台式机</td>
        <td>3000.0</td>
        <td>2016-02-03 13:22:53</td>
        <td></td>
        <td><a href="/springmvc-web/itemEdit.action?id=1">修改</a></td>
    </tr>
    <tr>
        <td><input name="ids" value="2" type="checkbox"></td>
        <td>笔记本</td>
        <td>6000.0</td>
        <td>2015-02-09 13:22:57</td>
        <td></td>
        <td><a href="/springmvc-web/itemEdit.action?id=2">修改</a></td>
    </tr>
    <tr>
        <td><input name="ids" value="3" type="checkbox"></td>
        <td>背包</td>
        <td>200.0</td>
        <td>2015-02-06 13:23:02</td>
        <td></td>
        <td><a href="/springmvc-web/itemEdit.action?id=3">修改</a></td>
    </tr>
    </table>
    

    Controller方法中可以用String[]接收,或者pojo的String[]属性接收。两种方式任选其一即可。

        @RequestMapping("/queryitem")
        public String queryItem(QueryVo queryVo, String[] ids) {
            System.out.println(queryVo.getItems().getName());
            System.out.println(queryVo.getItems().getPrice());
            System.out.println(ids.toString());
            return null;
        }
    

    或者

    public class QueryVo {
        private Items items;
        private String[] ids;
    }
    
    • List绑定
      表单中如果有多个pojo元素要提交, 可以绑定到List中

    1.在pojo类中定义一个List属性

    public class QueryVo {
        private Items items;
        private String[] ids;
        private List<Items> itemList;
    }
    

    2.页面定义如下:
    Name属性必须是包装pojo的list属性+下标+元素属性

    <tr>
    <td>
    <input type="text" name=" itemsList[0].id" value="${item.id}"/>
    </td>
    <td>
    <input type="text" name=" itemsList[0].name" value="${item.name }"/>
    </td>
    <td>
    <input type="text" name=" itemsList[0].price" value="${item.price}"/>
    </td>
    </tr>
    <tr>
    <td>
    <input type="text" name=" itemsList[1].id" value="${item.id}"/>
    </td>
    <td>
    <input type="text" name=" itemsList[1].name" value="${item.name }"/>
    </td>
    <td>
    <input type="text" name=" itemsList[1].price" value="${item.price}"/>
    </td>
    </tr> 
    

    @RequestMapping

    • URL路径映射
      @RequestMapping(value="/item")或@RequestMapping("/item)
      value的值是数组,可以将多个url映射到同一个方法
    • 窄化请求映射
      在class上添加@RequestMapping(url)指定通用请求前缀, 限制此类下的所有方法请求url必须以请求前缀开头,通过此方法对url进行分类管理。

    如下:
    @RequestMapping放在类名上边,设置请求前缀
    @Controller
    @RequestMapping("/item")

    方法名上边设置请求映射url:
    @RequestMapping放在方法名上边,如下:
    @RequestMapping("/queryItem ")

    访问地址为:/item/queryItem

    • 请求方法限定
      限定GET方法
      @RequestMapping(method = RequestMethod.GET)

    如果通过Post访问则报错:
    HTTP Status 405 - Request method 'POST' not supported

    限定POST方法
    @RequestMapping(method = RequestMethod.POST)

    GET和POST都可以
    @RequestMapping(method={RequestMethod.GET,RequestMethod.POST})

    如果没有限定, 那么任意请求方式都可以!

    controller方法返回值

    • 返回ModelAndView
      controller方法中定义ModelAndView对象并返回,对象中可添加model数据、指定view。

    • 返回void
      在controller方法形参上可以定义request和response,使用request或response指定响应结果:
      1、使用request转向页面,如下:
      request.getRequestDispatcher("页面路径").forward(request, response);

    2、也可以通过response页面重定向:
    response.sendRedirect("url")

    3、也可以通过response指定响应结果,例如响应json数据如下:
    response.setCharacterEncoding("utf-8");
    response.setContentType("application/json;charset=utf-8");
    response.getWriter().write("json串");

    • 返回字符串
    1. 逻辑视图名
      controller方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址
    //指定逻辑视图名,经过视图解析器解析为jsp物理路径:/WEB-INF/jsp/item/editItem.jsp
    return "item/editItem";
    
    1. Redirect重定向
      Contrller方法返回结果重定向到一个url地址,如下商品修改提交后重定向到商品查询方法,参数无法带到商品查询方法中。
    //重定向到queryItem.action地址,request无法带过去
    return "redirect:queryItem.action";
    

    redirect方式相当于“response.sendRedirect()”,转发后浏览器的地址栏变为转发后的地址,因为转发即执行了一个新的request和response。
    由于新发起一个request原来的参数在转发时就不能传递到下一个url,如果要传参数可以/item/queryItem.action后边加参数,如下:
    /item/queryItem?...&…

    1. forward转发
      controller方法执行后继续执行另一个controller方法,如下商品修改提交后转向到商品修改页面,修改商品的id参数可以带到商品修改方法中。
    //结果转发到editItem.action,request可以带过去
    return "forward:editItem.action";
    

    forward方式相当于“request.getRequestDispatcher().forward(request,response)”,转发后浏览器地址栏还是原来的地址。转发并没有执行新的request和response,而是和转发前的请求共用一个request和response。所以转发前请求的参数在转发后仍然可以读取到。

    异常处理器

    springmvc在处理请求过程中出现异常信息交由异常处理器进行处理,自定义异常处理器可以实现一个系统的异常处理逻辑。

    1.自定义异常处理器

    public class CustomExceptionResolver implements HandlerExceptionResolver {
    
        @Override
        public ModelAndView resolveException(HttpServletRequest request,
                HttpServletResponse response, Object handler, Exception ex) {
    
            ex.printStackTrace();
    
            CustomException customException = null;
            
            //如果抛出的是系统自定义异常则直接转换
            if(ex instanceof CustomException){
                customException = (CustomException)ex;
            }else{
                //如果抛出的不是系统自定义异常则重新构造一个系统错误异常。
                customException = new CustomException("系统错误,请与系统管理 员联系!");
            }
            
            ModelAndView modelAndView = new ModelAndView();
            modelAndView.addObject("message", customException.getMessage());
            modelAndView.setViewName("error");
    
            return modelAndView;
        }
    
    }
    

    2.配置到springmvc中

    <!-- 异常处理器 -->
        <bean id="handlerExceptionResolver" class="com.gongxm.exceptionResolver.CustomExceptionResolver"/>
    

    图片上传

    • 配置虚拟目录
    在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:
    <Context docBase="F:\develop\upload\temp" path="/pic" reloadable="false"/>
    访问 http://localhost:8080/pic 即可访问F:\develop\upload\temp下的图片。
    
    • jar包
      CommonsMultipartResolver解析器依赖 commons-fileupload 和 commons-io

    • 配置解析器

        <!-- 文件上传,ID必须是multipartResolver -->
        <bean id="multipartResolver"
            class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
            <!-- 设置上传文件的最大尺寸为5MB -->
            <property name="maxUploadSize">
                <value>5242880</value>
            </property>
        </bean>
    
    • controller
        @RequestMapping("/editItemSubmit")
        public String editItemSubmit(Items items, MultipartFile pictureFile)throws Exception{
            //原始文件名称
            String pictureFile_name =  pictureFile.getOriginalFilename();
            //新文件名称
            String newFileName = UUID.randomUUID().toString()+pictureFile_name.substring(pictureFile_name.lastIndexOf("."));
            //上传图片
            File uploadPic = new .File("F:/develop/upload/temp/"+newFileName);
            //向磁盘写文件
            pictureFile.transferTo(uploadPic);
    }
    
    • jsp页面:
      form添加enctype="multipart/form-data":
    <form id="itemForm"
    action="${pageContext.request.contextPath }/item/editItemSubmit.action"
            method="post" enctype="multipart/form-data">
    

    file的name与controller形参一致:

    <tr>
        <td>商品图片</td>
        <td><input type="file" name="pictureFile" /></td>
    </tr>
    

    json数据交互

    • @RequestBody
      作用:
      @RequestBody注解用于读取http请求的内容(字符串),通过springmvc提供的HttpMessageConverter接口将读到的内容转换为json、xml等格式的数据并绑定到controller方法的参数上。
      List.action?id=1&name=zhangsan&age=12

    @RequestBody注解实现接收http请求的json数据,将json数据转换为java对象

    • @ResponseBody
      作用:
      该注解用于将Controller的方法返回的对象,通过HttpMessageConverter接口转换为指定格式的数据如:json,xml等,通过Response响应给客户端

    @ResponseBody注解实现将controller方法返回对象转换为json响应给客户端

    • 环境配置
      Springmvc默认用MappingJacksonHttpMessageConverter对json数据进行转换,需要加入jackson的包
      jackson-core 和 jackson-mapper两个包

    静态资源映射

    如果在DispatcherServlet中设置url-pattern为 / 则必须对静态资源进行访问处理。
    spring mvc 的<mvc:resources mapping="" location="">实现对静态资源进行映射访问。
    如下是对js文件访问配置:
    <mvc:resources location="/js/" mapping="/js/**"/>

    拦截器

    Spring Web MVC 的处理器拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。
    
    • 实现HandlerInterceptor接口
    Public class HandlerInterceptor1 implements HandlerInterceptor{
    
        /**
         * controller执行前调用此方法
         * 返回true表示继续执行,返回false中止执行
         * 这里可以加入登录校验、权限拦截等
         */
        @Override
        Public boolean preHandle(HttpServletRequest request,
                HttpServletResponse response, Object handler) throws Exception {
            // TODO Auto-generated method stub
            Return false;
        }
        /**
         * controller执行后但未返回视图前调用此方法
         * 这里可在返回用户前对模型数据进行加工处理,比如这里加入公用信息以便页面显示
         */
        @Override
        Public void postHandle(HttpServletRequest request,
                HttpServletResponse response, Object handler,
                ModelAndView modelAndView) throws Exception {
            // TODO Auto-generated method stub
            
        }
        /**
         * controller执行后且视图返回后调用此方法
         * 这里可得到执行controller时的异常信息
         * 这里可记录操作日志,资源清理等
         */
        @Override
        Public void afterCompletion(HttpServletRequest request,
                HttpServletResponse response, Object handler, Exception ex)
                throws Exception {
            // TODO Auto-generated method stub
            
        }
    
    }
    
    • 拦截器配置
      针对某种mapping配置拦截器
    <bean
        class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
        <property name="interceptors">
            <list>
                <ref bean="handlerInterceptor1"/>
                <ref bean="handlerInterceptor2"/>
            </list>
        </property>
    </bean>
        <bean id="handlerInterceptor1" class="springmvc.intercapter.HandlerInterceptor1"/>
        <bean id="handlerInterceptor2" class="springmvc.intercapter.HandlerInterceptor2"/>
    

    针对所有mapping配置全局拦截器

    <!--拦截器 -->
    <mvc:interceptors>
        <!--多个拦截器,顺序执行 -->
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="cn.itcast.springmvc.filter.HandlerInterceptor1"></bean>
        </mvc:interceptor>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="cn.itcast.springmvc.filter.HandlerInterceptor2"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
    

    相关文章

      网友评论

          本文标题:springmvc使用

          本文链接:https://www.haomeiwen.com/subject/hhqwgxtx.html