一、HttpServletRequest,HttpServletResponse,HttpSessionhtml
页面点击修改按钮,发起请求: http://localhost:8080/itemEdit.action?id=1 ,须要从请求的参数中把请求的id取出来。Id包含在Request对象中。能够从Request对象中取id。得到Request对象只须要在Controller方法的形参中添加一个参数便可。Springmvc框架会自动把Request对象传递给方法。前端
@RequestMapping(value = "/itemEdit.action") public ModelAndView toEdit(HttpServletRequest request) { String id = request.getParameter("id"); return null; }
除了能够在方法中添加HttpServletRequest形参以外,还能够添加其余的默认支持的参数类型,处理器形参中添加以下类型的参数处理适配器会默认识别并进行赋值。java
二、Modelweb
除了ModelAndView之外,还可使用Model来向页面传递数据,Model是一个接口,在参数里直接声明model便可。spring
若是使用Model则能够不使用ModelAndView对象,Model对象能够向页面传递数据,View对象则可使用String返回值替代。json
不论是Model仍是ModelAndView,其本质都是使用Request对象向jsp传递数据。数组
代码实现:浏览器
/** * 根据id查询商品,使用Model * * @param request * @param model * @return */ @RequestMapping("/itemEdit") public String queryItemById(HttpServletRequest request, Model model) { // 从request中获取请求参数 String strId = request.getParameter("id"); Integer id = Integer.valueOf(strId); // 根据id查询商品数据 Item item = this.itemService.queryItemById(id); // 把结果传递给页面 // ModelAndView modelAndView = new ModelAndView(); // 把商品数据放在模型中 // modelAndView.addObject("item", item); // 设置逻辑视图 // modelAndView.setViewName("itemEdit"); // 把商品数据放在模型中 model.addAttribute("item", item); return "itemEdit"; }
三、ModelMap缓存
ModelMap是Model接口的实现类,也能够经过ModelMap向页面传递数据。使用Model和ModelMap的效果同样,若是直接使用Model,springmvc会实例化ModelMap。tomcat
代码实现:
/** * 根据id查询商品,使用ModelMap * * @param request * @param model * @return */ @RequestMapping("/itemEdit") public String queryItemById(HttpServletRequest request, ModelMap model) { // 从request中获取请求参数 String strId = request.getParameter("id"); Integer id = Integer.valueOf(strId); // 根据id查询商品数据 Item item = this.itemService.queryItemById(id); // 把结果传递给页面 // ModelAndView modelAndView = new ModelAndView(); // 把商品数据放在模型中 // modelAndView.addObject("item", item); // 设置逻辑视图 // modelAndView.setViewName("itemEdit"); // 把商品数据放在模型中 model.addAttribute("item", item); return "itemEdit"; }
当请求的参数名称和处理器形参名称一致时会将请求参数与形参进行绑定。这样,从Request取参数的方法就能够进一步简化。
/** * 根据id查询商品,绑定简单数据类型 * * @param id * @param model * @return */ @RequestMapping("/itemEdit") public String queryItemById(int id, ModelMap model) { // 根据id查询商品数据 Item item = this.itemService.queryItemById(id); // 把商品数据放在模型中 model.addAttribute("item", item); return "itemEdit"; }
参数类型推荐使用包装数据类型,由于基础数据类型不能够为null,若是没传值,可能会引起异常。支持的数据类型有:
说明:对于布尔类型的参数,请求的参数值为true或false。或者1或0
请求url:http://localhost:8080/xxx.action?id=2&status=false 处理器方法:public String editItem(Model model,Integer id,Boolean status)
@RequestParam
使用@RequestParam经常使用于处理简单类型的绑定。
@RequestMapping("/itemEdit") public String queryItemById(@RequestParam(value = "itemId", required = true, defaultValue = "1") Integer id, ModelMap modelMap) { // 根据id查询商品数据 Item item = this.itemService.queryItemById(id); // 把商品数据放在模型中 modelMap.addAttribute("item", item); return "itemEdit"; }
若是提交的参数不少,或者提交的表单中的内容不少的时候,可使用简单类型接受数据,也可使用pojo接收数据。要求:pojo对象中的属性名和表单中input的name属性一致。
示例:
页面定义以下图:
pojo以下图:
请求的参数名称和pojo的属性名称一致,会自动将请求参数赋值给pojo的属性。
注意:提交的表单中不要有日期类型的数据,不然会报400错误。若是想提交日期类型的数据须要用到后面的自定义参数绑定的内容。
解决post乱码问题
提交发现,保存成功,可是保存的是乱码,在web.xml中加入:
<!-- 解决post乱码问题 --> <filter> <filter-name>encoding</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <!-- 设置编码参是UTF8 --> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
以上能够解决post请求乱码问题。
对于get请求中文参数出现乱码解决方法有两个:
修改tomcat配置文件添加编码与工程编码一致,以下:
<Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
另一种方法对参数进行从新编码:
String userName =new String(request.getParamter("userName").getBytes("ISO8859-1"),"utf-8") //ISO8859-1是tomcat默认编码,须要将tomcat编码后的内容按utf-8编码
包装对象定义以下:
public class QueryVo { private Item item; set/get。。。 }
页面定义以下图:
处理以下:
// 绑定包装数据类型 @RequestMapping("/queryItem") public String queryItem(QueryVo queryVo) { System.out.println(queryVo.getItem().getId()); System.out.println(queryVo.getItem().getName()); return "success"; }
因为日期数据有不少种格式,springmvc没办法把字符串转换成日期类型。因此须要自定义参数绑定。
前端控制器接收到请求后,找到注解形式的处理器适配器,对RequestMapping标记的方法进行适配,并对方法中的形参进行参数绑定。能够在springmvc处理器适配器上自定义转换器Converter进行参数绑定。
通常使用<mvc:annotation-driven/>注解驱动加载处理器适配器,能够在此标签上进行配置。
以下图修改itemEdit.jsp页面,显示时间
自定义Converter
//Converter<S, T> //S:source,须要转换的源的类型 //T:target,须要转换的目标类型 public class DateConverter implements Converter<String, Date> { @Override public Date convert(String source) { try { // 把字符串转换为日期类型 SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyy-MM-dd HH:mm:ss"); Date date = simpleDateFormat.parse(source); return date; } catch (ParseException e) { // TODO Auto-generated catch block e.printStackTrace(); } // 若是转换异常则返回空 return null; } }
配置Converter
咱们同时能够配置多个的转换器。
<!-- 配置注解驱动 --> <!-- 若是配置此标签,能够不用配置... --> <mvc:annotation-driven conversion-service="conversionService" /> <!-- 转换器配置 --> <bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> <property name="converters"> <set> <bean class="cn.itcast.springmvc.converter.DateConverter" /> </set> </property> </bean>
配置方式2(了解)
<!--注解适配器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <property name="webBindingInitializer" ref="customBinder"></property> </bean> <!-- 自定义webBinder --> <bean id="customBinder" class="org.springframework.web.bind.support.ConfigurableWebBindingInitializer"> <property name="conversionService" ref="conversionService" /> </bean> <!-- 转换器配置 --> <bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> <property name="converters"> <set> <bean class="cn.itcast.springmvc.convert.DateConverter" /> </set> </property> </bean>
注意:此方法须要独立配置处理器映射器、适配器,再也不使用<mvc:annotation-driven/>
表单以下:
<form action="${pageContext.request.contextPath }/queryItem.action" method="post"> 查询条件: <table width="100%" border=1> <tr> <td>商品id<input type="text" name="item.id" /></td> <td>商品名称<input type="text" name="item.name" /></td> <td><input type="submit" value="查询"/></td> </tr> </table> 商品列表: <table width="100%" border=1> <tr> <td>选择</td> <td>商品名称</td> <td>商品价格</td> <td>生产日期</td> <td>商品描述</td> <td>操做</td> </tr> <c:forEach items="${itemList }" var="item"> <tr> <td><input type="checkbox" name="ids" value="${item.id}"/></td> <td>${item.name }</td> <td>${item.price }</td> <td><fmt:formatDate value="${item.createtime}" pattern="yyyy-MM-dd HH:mm:ss"/></td> <td>${item.detail }</td> <td><a href="${pageContext.request.contextPath }/itemEdit.action?id=${item.id}">修改</a></td> </tr> </c:forEach> </table> </form>
页面选中多个checkbox向controller方法传递,自己属于一个form表单,提交url是queryItem.action
Controller方法中能够用String[]接收,或者pojo的String[]属性接收。两种方式任选其一便可。定义QueryVo,以下图:
ItemController修改queryItem方法:
/** * 包装类型 绑定数组类型,可使用两种方式,pojo的属性接收,和直接接收 * * @param queryVo * @return */ @RequestMapping("queryItem") public String queryItem(QueryVo queryVo, Integer[] ids) { System.out.println(queryVo.getItem().getId()); System.out.println(queryVo.getItem().getName()); System.out.println(queryVo.getIds().length); System.out.println(ids.length); return "success"; }
定义pojo,List中存放对象,并将定义的List放在包装类QueryVo中,使用包装pojo对象接收,以下图:
前端页面应该显示的html代码,以下图:
分析发现:name属性必须是list属性名+下标+元素属性。Jsp作以下改造:
<c:forEach items="${itemList }" var="item" varStatus="s"> <tr> <td><input type="checkbox" name="ids" value="${item.id}"/></td> <td> <input type="hidden" name="itemList[${s.index}].id" value="${item.id }"/> <input type="text" name="itemList[${s.index}].name" value="${item.name }"/> </td> <td><input type="text" name="itemList[${s.index}].price" value="${item.price }"/></td> <td><input type="text" name="itemList[${s.index}].createtime" value="<fmt:formatDate value="${item.createtime}" pattern="yyyy-MM-dd HH:mm:ss"/>"/></td> <td><input type="text" name="itemList[${s.index}].detail" value="${item.detail }"/></td> <td><a href="${pageContext.request.contextPath }/itemEdit.action?id=${item.id}">修改</a></td> </tr> </c:forEach>
测试效果以下图:
注意:接收List类型的数据必须是pojo的属性,若是方法的形参为ArrayList类型没法正确接收到数据。
经过@RequestMapping注解能够定义不一样的处理器映射规则。
@RequestMapping(value="item")或@RequestMapping("/item"),value的值是数组,能够将多个url映射到同一个方法
/** * 查询商品列表 * @return */ @RequestMapping(value = { "itemList", "itemListAll" }) public ModelAndView queryItemList() { // 查询商品数据 List<Item> list = this.itemService.queryItemList(); // 建立ModelAndView,设置逻辑视图名 ModelAndView mv = new ModelAndView("itemList"); // 把商品数据放到模型中 mv.addObject("itemList", list); return mv; }
在class上添加@RequestMapping(url)指定通用请求前缀, 限制此类下的全部方法请求url必须以请求前缀开头。可使用此方法对url进行分类管理,以下图:
此时须要进入queryItemList()方法的请求url为:http://127.0.0.1:8080/springmvc-web2/item/itemList.action或者http://127.0.0.1:8080/springmvc-web2/item/itemListAll.action
除了能够对url进行设置,还能够限定请求进来的方法
controller方法中定义ModelAndView对象并返回,对象中可添加model数据、指定view。
在Controller方法形参上能够定义request和response,使用request或response指定响应结果:
一、使用request转发页面,以下:
request.getRequestDispatcher("页面路径").forward(request, response)
request.getRequestDispatcher("/WEB-INF/jsp/success.jsp").forward(request, response);
二、能够经过response页面重定向:
response.sendRedirect("url")
response.sendRedirect("/springmvc-web2/itemEdit.action");
三、能够经过response指定响应结果,例如响应json数据以下:
response.getWriter().print("{\"abc\":123}");
/** * 返回void测试 * * @param request * @param response * @throws Exception */ @RequestMapping("queryItem") public void queryItem(HttpServletRequest request, HttpServletResponse response) throws Exception { // 1 使用request进行转发 // request.getRequestDispatcher("/WEB-INF/jsp/success.jsp").forward(request, // response); // 2 使用response进行重定向到编辑页面 // response.sendRedirect("/springmvc-web2/itemEdit.action"); // 3 使用response直接显示 response.getWriter().print("{\"abc\":123}"); }
controller方法返回字符串能够指定逻辑视图名,经过视图解析器解析为物理视图地址。
//指定逻辑视图名,通过视图解析器解析为jsp物理路径:/WEB-INF/jsp/itemList.jsp return "itemList";
Contrller方法返回字符串能够重定向到一个url地址,以下商品修改提交后重定向到商品编辑页面。
/** * 更新商品 * * @param item * @return */ @RequestMapping("updateItem") public String updateItemById(Item item) { // 更新商品 this.itemService.updateItemById(item); // 修改商品成功后,重定向到商品编辑页面 // 重定向后浏览器地址栏变动为重定向的地址, // 重定向至关于执行了新的request和response,因此以前的请求参数都会丢失 // 若是要指定请求参数,须要在重定向的url后面添加 ?itemId=1 这样的请求参数 return "redirect:/itemEdit.action?itemId=" + item.getId(); }
Controller方法执行后继续执行另外一个Controller方法。以下商品修改提交后转向到商品修改页面,修改商品的id参数能够带到商品修改方法中。
/** * 更新商品 * * @param item * @return */ @RequestMapping("updateItem") public String updateItemById(Item item) { // 更新商品 this.itemService.updateItemById(item); // 修改商品成功后,重定向到商品编辑页面 // 重定向后浏览器地址栏变动为重定向的地址, // 重定向至关于执行了新的request和response,因此以前的请求参数都会丢失 // 若是要指定请求参数,须要在重定向的url后面添加 ?itemId=1 这样的请求参数 // return "redirect:/itemEdit.action?itemId=" + item.getId(); // 修改商品成功后,继续执行另外一个方法 // 使用转发的方式实现。转发后浏览器地址栏仍是原来的请求地址, // 转发并无执行新的request和response,因此以前的请求参数都存在 return "forward:/itemEdit.action"; } //结果转发到editItem.action,request能够带过去 return "forward: /itemEdit.action";
springmvc在处理请求过程当中出现异常信息交由异常处理器进行处理,自定义异常处理器能够实现一个系统的异常处理逻辑。
系统中异常包括两类:预期异常和运行时异常RuntimeException,前者经过捕获异常从而获取异常信息,后者主要经过规范代码开发、测试经过手段减小运行时异常的发生。
系统的dao、service、controller出现都经过throws Exception向上抛出,最后由springmvc前端控制器交由异常处理器进行异常处理,以下图:
为了区别不一样的异常,一般根据异常类型进行区分,这里咱们建立一个自定义系统异常。若是controller、service、dao抛出此类异常说明是系统预期处理的异常信息。
public class MyException extends Exception { // 异常信息 private String message; public MyException() { super(); } public MyException(String message) { super(); this.message = message; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } }
public class CustomHandleException implements HandlerExceptionResolver { @Override public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler,Exception exception) { // 定义异常信息 String msg; // 判断异常类型 if (exception instanceof MyException) { // 若是是自定义异常,读取异常信息 msg = exception.getMessage(); } else { // 若是是运行时异常,则取错误堆栈,从堆栈中获取异常信息 Writer out = new StringWriter(); PrintWriter s = new PrintWriter(out); exception.printStackTrace(s); msg = out.toString(); } // 把错误信息发给相关人员,邮件,短信等方式 // TODO // 返回错误页面,给用户友好页面显示错误信息 ModelAndView modelAndView = new ModelAndView(); modelAndView.addObject("msg", msg); modelAndView.setViewName("error"); return modelAndView; } }
在springmvc.xml中添加:
<!-- 配置全局异常处理器 --> <bean id="customHandleException" class="cn.itcast.ssm.exception.CustomHandleException"/>
在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:
<Context docBase="D:\develop\upload\temp" path="/pic" reloadable="false"/> 访问http://localhost:8080/pic便可访问D:\develop\upload\temp下的图片。
也能够经过eclipse配置,以下图:
实现图片上传须要加入的jar包,以下图:
在springmvc.xml中配置文件上传解析器
<!-- 文件上传,id必须设置为multipartResolver --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 设置文件上传大小 --> <property name="maxUploadSize" value="5000000" /> </bean>
设置表单能够进行文件上传,以下图:
在更新商品方法中添加图片上传逻辑
/** * 更新商品 * * @param item * @return * @throws Exception */ @RequestMapping("updateItem") public String updateItemById(Item item, MultipartFile pictureFile) throws Exception { // 图片上传 // 设置图片名称,不能重复,可使用uuid String picName = UUID.randomUUID().toString(); // 获取文件名 String oriName = pictureFile.getOriginalFilename(); // 获取图片后缀 String extName = oriName.substring(oriName.lastIndexOf(".")); // 开始上传 pictureFile.transferTo(new File("C:/upload/image/" + picName + extName)); // 设置图片名到商品中 item.setPic(picName + extName); // --------------------------------------------- // 更新商品 this.itemService.updateItemById(item); return "forward:/itemEdit.action"; }
@RequestBody注解用于读取http请求的内容(字符串),经过springmvc提供的HttpMessageConverter接口将读到的内容(json数据)转换为java对象并绑定到Controller方法的参数上。
传统的请求参数:itemEdit.action?id=1&name=zhangsan&age=12
如今的请求参数:使用POST请求,在请求体里面加入json数据
{ "id": 1, "name": "测试商品", "price": 99.9, "detail": "测试商品描述", "pic": "123456.jpg" }
@RequestBody注解实现接收http请求的json数据,将json数据转换为java对象进行绑定
@ResponseBody注解用于将Controller的方法返回的对象,经过springmvc提供的HttpMessageConverter接口转换为指定格式的数据如:json,xml等,经过Response响应给客户端
@ResponseBody注解实现将Controller方法返回java对象转换为json响应给客户端。
若是须要springMVC支持json,必须加入json的处理jar,咱们使用Jackson这个jar,以下图:
/** * 测试json的交互 * @param item * @return */ @RequestMapping("testJson") // @ResponseBody public @ResponseBody Item testJson(@RequestBody Item item) { return item; }
若是不使用注解驱动<mvc:annotation-driven />,就须要给处理器适配器配置json转换器,参考以前学习的自定义参数绑定。
在springmvc.xml配置文件中,给处理器适配器加入json转换器:
<!--处理器适配器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean> </list> </property> </bean>
Restful就是一个资源定位及资源操做的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件能够更简洁,更有层次,更易于实现缓存等机制。
资源:互联网全部的事物均可以被抽象为资源
资源操做:使用POST、DELETE、PUT、GET,使用不一样方法对资源进行操做。 分别对应 添加、 删除、修改、查询。
传统方式操做资源
使用RESTful操做资源
使用RESTful风格开发的接口,根据id查询商品,接口地址是:http://127.0.0.1/item/1
咱们须要从url上获取商品id,步骤以下:
/** * 使用RESTful风格开发接口,实现根据id查询商品 * * @param id * @return */ @RequestMapping("item/{id}") @ResponseBody public Item queryItemById(@PathVariable() Integer id) { Item item = this.itemService.queryItemById(id); return item; }
若是@RequestMapping中表示为"item/{id}",id和形参名称一致,@PathVariable不用指定名称。若是不一致,例如"item/{ItemId}"则须要指定名称@PathVariable("itemId")。
访问时用:http://127.0.0.1/item/123?id=1
注意两个区别
Spring Web MVC 的处理器拦截器相似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。
实现HandlerInterceptor接口,以下:
public class HandlerInterceptor1 implements HandlerInterceptor { // controller执行后且视图返回后调用此方法 // 这里可获得执行controller时的异常信息 // 这里可记录操做日志 @Override public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { System.out.println("HandlerInterceptor1....afterCompletion"); } // controller执行后但未返回视图前调用此方法 // 这里可在返回用户前对模型数据进行加工处理,好比这里加入公用信息以便页面显示 @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { System.out.println("HandlerInterceptor1....postHandle"); } // Controller执行前调用此方法 // 返回true表示继续执行,返回false停止执行 // 这里能够加入登陆校验、权限拦截等 @Override public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2) throws Exception { System.out.println("HandlerInterceptor1....preHandle"); // 设置为true,测试使用 return true; } }
上面定义的拦截器再复制一份HandlerInterceptor2,注意新的拦截器修改代码:System.out.println("HandlerInterceptor2....preHandle");
在springmvc.xml中配置拦截器
<!-- 配置拦截器 --> <mvc:interceptors> <mvc:interceptor> <!-- 全部的请求都进入拦截器 --> <mvc:mapping path="/**" /> <!-- 配置具体的拦截器 --> <bean class="cn.itcast.ssm.interceptor.HandlerInterceptor1" /> </mvc:interceptor> <mvc:interceptor> <!-- 全部的请求都进入拦截器 --> <mvc:mapping path="/**" /> <!-- 配置具体的拦截器 --> <bean class="cn.itcast.ssm.interceptor.HandlerInterceptor2" /> </mvc:interceptor> </mvc:interceptors>
浏览器访问地址:http://127.0.0.1:8080/springmvc-web2/itemList.action
控制台打印:
HandlerInterceptor1..preHandle..
HandlerInterceptor2..preHandle..
HandlerInterceptor2..postHandle..
HandlerInterceptor1..postHandle..
HandlerInterceptor2..afterCompletion..
HandlerInterceptor1..afterCompletion..
浏览器访问地址:http://127.0.0.1:8080/springmvc-web2/itemList.action
运行流程:HandlerInterceptor1的preHandler方法返回false,HandlerInterceptor2返回true,运行流程以下:
HandlerInterceptor1..preHandle..
从日志看出第一个拦截器的preHandler方法返回false后第一个拦截器只执行了preHandler方法,其它两个方法没有执行,第二个拦截器的全部方法不执行,且Controller也不执行了。
HandlerInterceptor1的preHandler方法返回true,HandlerInterceptor2返回false,运行流程以下:
HandlerInterceptor1..preHandle..
HandlerInterceptor2..preHandle..
HandlerInterceptor1..afterCompletion..
从日志看出第二个拦截器的preHandler方法返回false后第一个拦截器的postHandler没有执行,第二个拦截器的postHandler和afterCompletion没有执行,且controller也不执行了。
处理流程
a) 判断用户名密码是否正确(在控制台打印)
b) 若是正确,向session中写入用户信息(写入用户名username)
c) 跳转到商品列表
a) 拦截用户请求,判断用户是否登陆(登陆请求不能拦截)
b) 若是用户已经登陆。放行
c) 若是用户未登陆,跳转到登陆页面。
一、编写登陆jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="${pageContext.request.contextPath }/user/login.action"> <label>用户名:</label> <br> <input type="text" name="username"> <br> <label>密码:</label> <br> <input type="password" name="password"> <br> <input type="submit"> </form> </body> </html>
二、用户登录Controller
@Controller @RequestMapping("user") public class UserController { /** * 跳转到登陆页面 * * @return */ @RequestMapping("toLogin") public String toLogin() { return "login"; } /** * 用户登陆 * * @param username * @param password * @param session * @return */ @RequestMapping("login") public String login(String username, String password, HttpSession session) { // 校验用户登陆 System.out.println(username); System.out.println(password); // 把用户名放到session中 session.setAttribute("username", username); return "redirect:/item/itemList.action"; } }
三、编写拦截器
@Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception { // 从request中获取session HttpSession session = request.getSession(); // 从session中获取username Object username = session.getAttribute("username"); // 判断username是否为null if (username != null) { // 若是不为空则放行 return true; } else { // 若是为空则跳转到登陆页面 response.sendRedirect(request.getContextPath() + "/user/toLogin.action"); } return false; }
四、 配置拦截器
只能拦截商品的url,因此须要修改ItemController,让全部的请求都必须以item开头,以下图:
在springmvc.xml配置拦截器
<mvc:interceptor> <!-- 配置商品被拦截器拦截 --> <mvc:mapping path="/item/**" /> <!-- 配置具体的拦截器 --> <bean class="cn.itcast.ssm.interceptor.LoginHandlerInterceptor" /> </mvc:interceptor>