SpringMVC (2)

 

 

 

 

 

 

Spring web mvc

第二天

 

 

 

 

 

 

 


 

 

1  课程计划

1、高级参数绑定

a)       数组类型的参数绑定

b)       List类型的绑定

2、@RequestMapping注解的使用

3、Controller方法返回值

4、Springmvc中异常处理

5、图片上传处理

6、Json数据交互

7、Springmvc实现Restful

8、拦截器  

2  高级参数绑定

2.1    绑定数组

2.1.1  需求

在商品列表页面选中多个商品,然后删除。

2.1.2  需求分析

此功能要求商品列表页面中的每个商品前有一个checkbook,选中多个商品后点击删除按钮把商品id传递给Controller,根据商品id删除商品信息。

2.1.3  Jsp中实现:

在商品查询列表页面:

 

<c:forEachitems="${itemList }"var="item">

<tr>

     <td><inputname="ids"value="${item.id}"type="checkbox"></td>

     <td>${item.name }</td>

     <td>${item.price }</td>

     <td><fmt:formatDatevalue="${item.createtime}"pattern="yyyy-MM-dd HH:mm:ss"/></td>

     <td>${item.detail }</td>

     <td><ahref="${pageContext.request.contextPath }/itemEdit.action?id=${item.id}">修改</a></td>

</tr>

</c:forEach>

 

 

2.1.4  Controller

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());

          returnnull;

     }

或者:

查看结果:

 

2.2    将表单的数据绑定到List

2.2.1  需求

实现商品数据的批量修改。

2.2.2  需求分析

要想实现商品数据的批量修改,需要在商品列表中可以对商品信息进行修改,并且可以批量提交修改后的商品数据。

 

2.2.3  接收商品列表的pojo

List中存放对象,并将定义的List放在包装类中,使用包装pojo对象接收。不能直接通过集合属性的方式接收。必须放在包装对象中。

2.2.4  Jsp改造

页面定义如下:

 

 

<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>

 

Name属性必须是包装pojo的list属性+下标+元素属性。

 

Jsp做如下改造:

<c:forEach items="${itemList }" var="item" varStatus="status">

                    <tr>

                         <td>

                              <input name="ids" value="${item.id}" type="checkbox" />

                              <input name="itemList[${status.index}].id" value="${item.id}" type="hidden" />

                         </td>

                         <td><input name="itemList[${status.index}].name" value="${item.name}" type="text" /></td>

                         <td><input name="itemList[${status.index}].price" value="${item.price}" type="text" /></td>

                         <td><input name="itemList[${status.index}].createtime" value="<fmt:formatDate value="${item.createtime}" pattern="yyyy-MM-dd HH:mm:ss" />" type="text" /></td>

                         <td><input name="itemList[${status.index}].detail" value="${item.detail }" type="text" /></td>

 

                         <td><a href="${pageContext.request.contextPath }/itemEdit.action?id=${item.id}">修改</a></td>

                    </tr>

               </c:forEach>

 

varStatus属性常用参数总结下:

${status.index}     输出行号,从0开始。

${status.count}     输出行号,从1开始。

${status.current}  当前这次迭代的(集合中的)项

${status.first}  判断当前项是否为集合中的第一项,返回值为true或false

${status.last}  判断当前项是否为集合中的最后一项,返回值为true或false

begin、end、step分别表示:起始序号,结束序号,跳跃步伐。

 

 

2.2.5  Contrller

 

@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());

          returnnull;

     }

 

注意:接收List类型的数据必须是包装对象。

测试效果:

 

3  @RequestMapping

 

通过RequestMapping注解可以定义不同的处理器映射规则。

3.1    URL路径映射

比如:

@RequestMapping(value="/item")

 

3.2    窄化请求映射

在class上添加@RequestMapping(url)指定通用请求前缀, 限制此类下的所有方法请求url必须以请求前缀开头,通过此方法对url进行分类管理。

 

如下:

@RequestMapping放在类名上边,设置请求前缀

@Controller

@RequestMapping("/item")

 

方法名上边设置请求映射url:

@RequestMapping放在方法名上边,如下:

@RequestMapping("/queryItem ")

 

访问地址为:/item/queryItem

 

 

3.3    请求方法限定

u 如果没有限定请求的方法,默认是支持所有的方法(get,post,put,delete)

u 限定GET方法

@RequestMapping(method = RequestMethod.GET)

 

如果通过Post访问则报错:

HTTP Status 405 - Request method 'POST' notsupported

 

例如:

@RequestMapping(value="/editItem",method=RequestMethod.GET)

u 限定POST方法

 

@RequestMapping(method = RequestMethod.POST)

 

如果通过get访问则报错:

HTTP Status 405 - Request method 'GET' notsupported

 

u GET和POST都可以

@RequestMapping(method={RequestMethod.GET,RequestMethod.POST})

 

 

4  controller的方法返回值

4.1    返回ModelAndView

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

 

4.2    返回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串");

 

 

4.3    返回字符串

4.3.1  逻辑视图名

 

controller方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址。

//指定逻辑视图名,经过视图解析器解析为jsp物理路径:/WEB-INF/jsp/item/editItem.jsp

return "/item/editItem";

 

4.3.2  Redirect重定向

Contrller方法返回结果重定向到一个url地址,如下商品修改提交后重定向到商品查询方法,参数无法带到商品查询方法中。

//重定向到queryItem.action地址,request无法带过去

return "redirect:/queryItem.action";

 

redirect方式相当于“response.sendRedirect()”,转发后浏览器的地址栏变为转发后的地址,因为转发即执行了一个新的request和response。

由于新发起一个request原来的参数在转发时就不能传递到下一个url,如果要传参数可以/item/queryItem.action后边加参数,如下:

/item/queryItem?...&…..

 

 

4.3.3  forward转发

controller方法执行后继续执行另一个controller方法,如下商品修改提交后转向到商品修改页面,修改商品的id参数可以带到商品修改方法中。

//结果转发到editItem.actionrequest可以带过去

return"forward:/editItem.action";

 

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

 

5  异常处理器

 

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

        

5.1    异常处理思路

         系统中异常包括两类:预期异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发、测试通过手段减少运行时异常的发生。

         系统的dao、service、controller出现异常都通过throwsException向上抛出,最后由springmvc前端控制器交由异常处理器进行异常处理,如下图:

 

         一般在处理异常的时候,应当在发生异常时,讲异常信息输出到日志文件,再通知相关的人员进行系统的维护。并且给用户一个友好的提示,比如:您的网络有异常,请稍后再试。

 

 

5.2    自定义异常类

         为了区别不同的异常通常根据异常类型自定义异常类,这里我们创建一个自定义系统异常,如果controller、service、dao抛出此类异常说明是系统预期处理的异常信息。

 

         public class CustomException extends Exception {

 

    /** serialVersionUID*/

    private static final long serialVersionUID = -5212079010855161498L;

   

    public CustomException(String message){

       this.message = message;

    }

 

    //异常信息

    private String message;

 

    public String getMessage() {

       returnmessage;

    }

 

    publicvoid setMessage(String message) {

       this.message = message;

    }

}

 

 

5.3    自定义异常处理器

 

publicclass CustomExceptionResolver implements HandlerExceptionResolver {

 

    @Override

    public ModelAndViewresolveException(HttpServletRequest request,

           HttpServletResponseresponse, Object handler, Exception ex) {

 

       ex.printStackTrace();

 

       CustomExceptioncustomException = null;

      

       //如果抛出的是系统自定义异常则直接转换

       if(ex instanceof CustomException){

           customException= (CustomException)ex;

       }else{

           //如果抛出的不是系统自定义异常则重新构造一个系统错误异常。

           customException= new CustomException("系统错误,请与系统管理员联系!");

       }

      

       ModelAndViewmodelAndView = new ModelAndView();

       modelAndView.addObject("message", customException.getMessage());

       modelAndView.setViewName("error");

 

       returnmodelAndView;

    }

 

}

 

取异常堆栈:

try {

              

          } catch (Exception e) {

               StringWriter s = new StringWriter();

               PrintWriter printWriter = new PrintWriter(s);

               e.printStackTrace(printWriter);

               s.toString();

          }

 

5.4    错误页面

 

<%@pagelanguage="java"contentType="text/html;charset=UTF-8"

pageEncoding="UTF-8"%>

<%@tagliburi="http://java.sun.com/jsp/jstl/core"prefix="c"%>

<%@tagliburi="http://java.sun.com/jsp/jstl/fmt"prefix="fmt"%>

<!DOCTYPEhtmlPUBLIC"-//W3C//DTD HTML 4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">

<title>错误页面</title>

 

</head>

<body>

您的操作出现错误如下:<br/>

${message }

</body>

 

</html>

 

 

 

5.5    异常处理器配置

在springmvc.xml中添加:

 

<!-- 异常处理器 -->

<beanid="handlerExceptionResolver"class="cn.itcast.ssm.controller.exceptionResolver.CustomExceptionResolver"/>

 

5.6    异常测试

修改商品信息,id输入错误提示商品信息不存在。

 

修改controller方法“editItem”,调用service查询商品信息,如果商品信息为空则抛出异常:

// 调用service查询商品信息

       Itemsitem = itemService.findItemById(id);

      

       if(item == null){

           throw new CustomException("商品信息不存在!");

       }

 

 

 

在service中抛出异常方法同上。

 

6  上传图片

 

6.1    配置虚拟目录

在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:

<Context docBase="F:\develop\upload\temp"path="/pic" reloadable="false"/>

 

访问http://localhost:8080/pic即可访问F:\develop\upload\temp下的图片。

 

也可以通过eclipse配置:

 

 

6.2    添加jar包

CommonsMultipartResolver解析器依赖commons-fileupload和commons-io,加入如下jar包:

6.3    配置文件上传的解析器

<!-- 文件上传 -->

    <bean id="multipartResolver"

    class="org.springframework.web.multipart.commons.CommonsMultipartResolver">

       <!-- 设置上传文件的最大尺寸为5MB -->

       <property name="maxUploadSize">

           <value>5242880</value>

       </property>

<property name="defaultEncoding"value="utf-8"></property>

    </bean>

 

 

 

6.4    图片上传

u controller:

 

//商品修改提交

    @RequestMapping("/editItemSubmit")

    public String editItemSubmit(Items items, MultipartFilepictureFile)throws Exception{

      

       //原始文件名称

       StringpictureFile_name = pictureFile.getOriginalFilename();

       //新文件名称

       StringnewFileName = UUID.randomUUID().toString()+pictureFile_name.substring(pictureFile_name.lastIndexOf("."));

      

       //上传图片

       FileuploadPic = new java.io.File("F:/develop/upload/temp/"+newFileName);   

       //向磁盘写文件

       pictureFile.transferTo(uploadPic);

 

.....

 

 

u 页面:

 

 

 

form添加enctype="multipart/form-data":

<formid="itemForm"

action="${pageContext.request.contextPath }/item/editItemSubmit.action"

       method="post"enctype="multipart/form-data">

       <inputtype="hidden"name="pic"value="${item.pic }"/>

 

 

filenamecontroller形参一致:

<tr>

    <td>商品图片</td>

    <td><c:iftest="${item.pic !=null}">

           <imgsrc="/pic/${item.pic}"width=100height=100/>

           <br/>

       </c:if><input type="file"name="pictureFile"/></td>

</tr>

 

 

 

 

7  json数据交互

7.1    为什么要使用JSON数据

JSON数据的数据的格式比较简单,解析比较简单,应用比较多。特别是:手机客户端使用JSON数据交互比较多。

7.2    @RequestBody

作用:

@RequestBody注解用于读取http请求的内容(字符串),通过springmvc提供的HttpMessageConverter接口将读到的内容转换为json、xml等格式的数据并绑定到controller方法的参数上。

 

本例子应用:

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

 

7.3    @ResponseBody

作用:

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

 

本例子应用:

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

 

框架默认执行转换

@ResponseBody 也可以转换直接返回string (此时string就不是逻辑视图了)

 

 

7.4    请求json,响应json实现:

7.4.1  环境准备

Springmvc默认用MappingJackson2HttpMessageConverter对json数据进行转换,需要加入jackson的包,如下:

7.4.2  配置json转换器

在注解适配器中加入messageConverters

 

<!--注解适配器 -->

    <bean    class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">

       <propertyname="messageConverters">

       <list>

    <beanclass="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"></bean>

       </list>

       </property>

    </bean>

 

注意:如果使用<mvc:annotation-driven/> 则不用定义上边的内容。

 

需求:通过POST传递JSON数据  到后台,后台接收JSON数据 并转换成JAVA对象,然后返回给页面。

7.4.3  controller编写

// 商品修改提交json信息,响应json信息

    @RequestMapping("/editItemSubmit_RequestJson")

    public@ResponseBody Items editItemSubmit_RequestJson(@RequestBody Items items) throws Exception {

       System.out.println(items);

       //itemService.saveItem(items);

       return items;

 

    }

 

7.4.4  页面js方法编写:

第一:拷贝JS到工程中

第二:在页面中引入 js:

<script type="text/javascript"

         src="${pageContext.request.contextPath}/js/jquery.min.js">

</script>

 

 

//请求json响应json

    function request_json(){

       $.ajax({

           type:"post",

       url:"${pageContext.request.contextPath}/item/editItemSubmit_RequestJson.action",

           contentType:"application/json;charset=utf-8",

           data:'{"name":"测试商品","price":99.9}',

           success:function(data){

              alert(data);

           }

       });

    }

 

7.4.5  测试结果:

 

从上图可以看出请求的数据是json格式

 

 

8  RESTful支持

8.1    什么是restful?

 

Restful就是一个资源定位及资源操作的风格。不是标准也不是协议,只是一种风格,是对http协议的诠释。

 

资源定位:互联网所有的事物都是资源,要求没有参数

Url格式:http://blog.csdn.net/beat_the_world/article/details/45621673

资源操作:使用put、delete、postget,使用不同方法对资源进行操作。

 

分别对应添加、删除、修改、查询。一般使用时还是post和get。Put和Delete几乎不使用。

优点:

                  1.描述简单,一目了然。多用于通过此开发风格传递json数据,xml的数据。

                  2.轻量级,只是依照http协议。

8.2    需求

RESTful方式实现商品信息查询,展示编辑商品的信息页面。

 

8.3    添加DispatcherServlet的restful配置

 

<servlet>

       <servlet-name>springmvc</servlet-name>

    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

       <init-param>

           <param-name>contextConfigLocation</param-name>

           <param-value>classpath:spring/springmvc.xml</param-value>

       </init-param>

    </servlet>

    <servlet-mapping>

       <servlet-name>springmvc</servlet-name>

       <url-pattern>/</url-pattern>

    </servlet-mapping>

 

 

 

 

8.4    URL 模板模式映射

@RequestMapping(value="/viewItems/{id}"){×××}占位符,请求的URL可以是“/viewItems/1”或“/viewItems/2”,通过在方法中使用@PathVariable获取{×××}中的×××变量。

@PathVariable用于将请求URL中的模板变量映射到功能处理方法的参数上。

 

/**

      * 通过ID获取商品数据

      *

      * @param request

      * @return

      * @throws CustomException

      *

      * {id} 表示一个占位符   里面id 的值通过注解  @PathVariable  映射到形参中 id  (形参和占位符中的变量要一致)

      * @PathVariable中的VALUE  用于映射形参的值和占位符中的变量   value 中的id  和占位符的ID一致就可以了。

      */

     @RequestMapping("/itemEdit/{id}")

     public String getItemsById(Model model,@PathVariable(value="id") Integer idsssssss) throws CustomException {

          // 获取商品信息

          Items items = service.getItemsById(idsssssss);

         

          model.addAttribute("item", items);

          return"editItem";

     }

 

如果RequestMapping中表示为"/itemEdit/{id}",如果id和形参名称一致,@PathVariable不用指定名称。

 

 

 

8.5    静态资源访问<mvc:resources>

如果在DispatcherServlet中设置url-pattern为 / 则必须对静态资源进行访问处理。

 

spring mvc 的<mvc:resources mapping="" location="">实现对静态资源进行映射访问。

如下是对js文件访问配置:

<mvc:resources location="/js/" mapping="/js/**"/>

 

 

 

 

9  拦截器

9.1    定义

       Spring Web MVC 的处理器拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。

 

9.2    拦截器定义

实现HandlerInterceptor接口,如下:

 

public class HandlerInterceptor1 implements HandlerInterceptor{

 

    /**

     * controller执行前调用此方法

     * 返回true表示继续执行,返回false中止执行

     * 这里可以加入登录校验、权限拦截等

     */

    @Override

    Publicboolean preHandle(HttpServletRequestrequest,

           HttpServletResponseresponse, Object handler) throws Exception {

       // TODO Auto-generated method stub

       Returnfalse;

    }

    /**

     * controller执行后但未返回视图前调用此方法

     * 这里可在返回用户前对模型数据进行加工处理,比如这里加入公用信息以便页面显示

     */

    @Override

    Publicvoid postHandle(HttpServletRequestrequest,

           HttpServletResponseresponse, Object handler,

           ModelAndViewmodelAndView) throws Exception {

       // TODO Auto-generated method stub

      

    }

    /**

     * controller执行后且视图返回后调用此方法

     * 这里可得到执行controller时的异常信息

     * 这里可记录操作日志,资源清理等

     */

    @Override

    Publicvoid afterCompletion(HttpServletRequestrequest,

           HttpServletResponseresponse, Object handler, Exception ex)

           throws Exception {

       // TODO Auto-generated method stub

    }

 

}

 

9.3    拦截器配置

9.3.1  针对某种特定的处理器映射器配置拦截器(了解)

<bean

class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">

    <propertyname="interceptors">

       <list>

           <refbean="handlerInterceptor1"/>

           <refbean="handlerInterceptor2"/>

       </list>

    </property>

</bean>

<beanid="handlerInterceptor1"class="springmvc.intercapter.HandlerInterceptor1"/>

<beanid="handlerInterceptor2"class="springmvc.intercapter.HandlerInterceptor2"/>

 

 

9.3.2  针对所有mapping配置全局拦截器(重点)

 

<mvc:interceptor>

    <mvc:mapping path="/**"/>

    <bean class="com.itheima.ssm.interceptor.HandlerInterceptor1"></bean>

</mvc:interceptor>

<mvc:interceptor>

    <mvc:mapping path="/**"/>

    <bean class="com.itheima.ssm.interceptor.HandlerInterceptor2"></bean>

</mvc:interceptor>

 

9.4    正常流程测试

 

9.4.1  代码:

定义两个拦截器分别为:HandlerInterceptor1和HandlerInteptor2,每个拦截器的preHandler方法都返回true。

 

 

9.4.2  运行流程

HandlerInterceptor1..preHandle..

HandlerInterceptor2..preHandle..

 

HandlerInterceptor2..postHandle..

HandlerInterceptor1..postHandle..

 

HandlerInterceptor2..afterCompletion..

HandlerInterceptor1..afterCompletion..

 

 

9.5    中断流程测试

9.5.1  代码:

定义两个拦截器分别为:HandlerInterceptor1和HandlerInteptor2。

 

 

9.5.2  运行流程

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没有执行,第二个拦截器的postHandlerafterCompletion没有执行,且controller也不执行了。

 

总结:(了解)

preHandle按拦截器定义顺序调用

postHandler按拦截器定义逆序调用

afterCompletion按拦截器定义逆序调用

 

postHandler在拦截器链内所有拦截器返回成功调用

afterCompletion只有于之相对应的preHandle返回true才调用

9.6    拦截器应用

在某种情况下,访问URL需要用户登录之后才能让其访问。

9.6.1  登录的流程

1.编写一个登录的页面,需要再编写一个controller的方法,用于显示登录的页面,url:/user/showLogin

2.登录页面中有一个提交表单的动作,url:/user/Login

         1)验证用户名和密码

         2)验证通过则设置用户信息到session中

         3)方向,比如跳转到列表页面

3.拦截器的流程

         校验:如果是显示登录页面的请求或者是登录验证的请求,则不用拦截。

        

         当用户请求时,被拦截,如果session有值,则放行

 

         否则重定向到登录页面。

 

9.6.2  用户登录的Controller

先创建一个登录的页面。

//跳转到用户登录的页面

     @RequestMapping("/user/showLogin")

     public String showLogin(){

          return"login";

     }

    

     //登录的验证

     @RequestMapping("/user/Login")

     public String login(String username,String password,HttpSession session){

          if("123".equals(username) && "456".equals(password)){

               //2.1根据用户名和密码查询数据库验证,如果查询到,设置session信息,并返回商品列表页面

               session.setAttribute("user", username);

               return"itemList";

          }

          //2.2 如果登录不成功,直接重定向到登录的页面。

 

          return"redirect:/user/showLogin";

     }

 

9.6.3  用户身份认证

 

拦截器部分代码如下:

@Override

     publicboolean preHandle(HttpServletRequest request, HttpServletResponse response, Object hanlder) throws Exception {

          //首先从当前的url中获取访问的路径,如果/user/showLogin /user/Login (不需要拦截)

          String pathrequest = request.getRequestURL().toString();

          if(pathrequest.contains("Login")){

               returntrue;

          }

          //如果不是,就需要拦截进行验证。

          Object object = request.getSession().getAttribute("user");

          //session中获取用户的信息

               if(object!=null){

                    //如果有,说明登录,就放行

                    returntrue;

               }

          //如果没有,跳转到登录的页面

          response.sendRedirect(request.getContextPath()+"/user/showLogin");

          returnfalse;

     }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值