springMVC_11攔截器實現登入
阿新 • • 發佈:2018-12-27
一. 思路
- controller實現核對使用者名稱和密碼,如果核對正確則儲存到session中並且跳轉到主頁
- 系統中包含諸多介面,部分介面不需要登入即可進行訪問,通過攔截器實現判斷是否是不需要登入的介面和使用者是否登入(通過session),如果登入或者是不需要登陸的見面,則不進行攔截,如果不滿足上述條件,則跳轉到登入頁面,攔截器返回false
二. 案例
1.匯入jar包
commons-logging-1.1.1.jar jackson-annotations-2.5.4.jar jackson-core-2.5.4.jar jackson-databind-2.5.4.jar spring-aop-4.1.6.RELEASE.jar spring-beans-4.1.6.RELEASE.jar spring-context-4.1.6.RELEASE.jar spring-core-4.1.6.RELEASE.jar spring-expression-4.1.6.RELEASE.jar spring-tx-4.1.6.RELEASE.jar spring-web-4.1.6.RELEASE.jar spring-webmvc-4.1.6.RELEASE.jar
如果使用上傳檔案功能,需要額外匯入
commons-fileupload-1.2.2.jar commons-io-2.0.1.jar
2.配置web.xml檔案
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"web.xmlid="WebApp_ID" version="3.0"> <display-name>05springMVC_data_2</display-name> <!-- 過濾實現表單資料傳輸過程編碼問題 --> <filter> <filter-name>encoding</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <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>*.do</url-pattern> </filter-mapping> <!--springMVC標配 --> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!—設定controller配置檔案位置--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> </web-app>
3.建立配置檔案mvc.xml在目錄src下
4.使用者實體類User
package com.ahd.entity; public class User { private String username; private String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "User [username=" + username + ", password=" + password + "]"; } }User
5.建立controller類LoginController
package com.ahd.controller; import javax.servlet.http.HttpSession; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import com.ahd.entity.User; @Controller public class LoginController { @RequestMapping("/login") public String Login(User user,HttpSession session){ if(user.getUsername().equals("ahdg")&&user.getPassword().equals("111111")){ session.setAttribute("user", user); return "index.jsp"; } return "login.jsp"; } @RequestMapping("/add") //本方法為測試方法 public String add(User user,HttpSession session){ System.out.println("add"); return "index.jsp"; } }
6.建立攔截器類LoginController
package com.ahd.interceptor; import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; public class LoginInterceptor implements HandlerInterceptor{ //設定不被攔截的頁面 private List<String> allowedPass; @Override public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { // TODO Auto-generated method stub } @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { // TODO Auto-generated method stub } @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception { // TODO Auto-generated method stub //獲取url地址 String url=request.getRequestURI().toString(); //先判斷session中是否有登入資訊 Object user=request.getSession().getAttribute("user"); if(user!=null){ return true; } for(String temp:allowedPass){ if(url.endsWith(temp)){ return true; } } response.sendRedirect(request.getContextPath()+"/login.jsp"); return false; } public void setAllowedPass(List allowedPass) { this.allowedPass = allowedPass; } }
7.配置mvc.xml檔案
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 配置handerAdapter 介面卡 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/> <!-- 檔案上傳配置 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 設定編碼格式 --> <property name="defaultEncoding" value="utf-8"></property> <!-- 設定檔案大小 --> <property name="maxUploadSize" value="10485760000"></property> <!-- 設定緩衝區大小 --> <property name="maxInMemorySize" value="40960"></property> </bean> <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <bean class="com.ahd.interceptor.LoginInterceptor"> <property name="allowedPass"> <list> <value>login.do</value> </list> </property> </bean> </mvc:interceptor> </mvc:interceptors> <!-- spring容器掃描指定包下的所有類,如果類上有註解 那麼根據註解產生相應bean物件已經對映資訊 --> <context:component-scan base-package="com.ahd.controller"/> </beans>
8.編寫前端頁面
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> ${user}<br/> <a href="fileupload.jsp" >檔案上傳fileupload.jsp</a><br/> <a href="fileupload1.jsp" >檔案批量上傳fileupload.jsp</a><br/> <a href="login.jsp" >登入</a> </body> </html>index.jsp
login.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'login.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <form action="login.do" method="post"> 使用者名稱:<input type="text" name="username" /><br/> 密 碼:<input type="password" name="password" /><br/> <input type="submit" value="submit" /><br/> </form> </body> </html>login.jsp