當用戶沒有登錄,直接訪問servlet容器時,就會跳轉到登陸頁面去讓用戶登錄。(還可以用filter過濾器進行統一過濾,那種方法很簡單,建議使用過濾器攔截嗎,見訪問頁面時,判斷用戶是否登錄,若沒有登錄,將跳轉到登錄頁面(二))
1.登錄頁面login.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> <!-- 請求轉發 --> <% String authority = (String)request.getAttribute("authority"); %> <% out.print(authority); %> <form action="UserLoginServlet" method="post"> username:<input type="text" value="<%=null == request.getAttribute("username")?"" : request.getAttribute("username") %>" name="username"><br> password:<input type="text" name="password"><br> authority:<select name="authority"> <option value="1" <%="1".equals(authority)?"selected = selected" : "" %>>common user</option> <option value="2" <%="2".equals(authority)?"selected = selected" : "" %>>adminstrator</option> </select> <br> <input type="submit"> </form> <!-- 重定向 -->> <%String error = request.getParameter("error"); String authority1 = request.getParameter("authority"); %> <form action="UserLoginServlet" method="post"> username:<input type="text" value="<%=null == request.getParameter("username")?"" : request.getParameter("username") %>" name="username"><br> password:<input type="text" name="password"><br> authority:<select name="authority"> <option value="1" <%="1".equals(authority1)?"selected = selected" : "" %>>common user</option> <option value="2" <%="2".equals(authority1)?"selected = selected" : "" %>>adminstrator</option> </select> <br> <input type="submit"> </form> </body> </html>
2.web.xml文件配置

<!-- session 實例 start--> <servlet> <servlet-name>UserLoginServlet</servlet-name> <servlet-class>com.servlet.UserLoginServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>UserLoginServlet</servlet-name> <url-pattern>/session/UserLoginServlet</url-pattern> </servlet-mapping> <servlet> <servlet-name>QueryServlet</servlet-name> <servlet-class>com.servlet.QueryServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>QueryServlet</servlet-name> <url-pattern>/session/QueryServlet</url-pattern> </servlet-mapping> <!-- session 實例 end-->
3.servlet(
com.servlet.LoginServlet
)

package com.servlet; import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { String username = req.getParameter("username"); String password = req.getParameter("password"); String repassword = req.getParameter("repassword"); int age = Integer.parseInt(req.getParameter("age")); String result = ""; if(age > 18) { result = "success"; } else { result += "age <= 18"; } if(!password.equals(repassword)) { result += "password != repassword"; } req.setAttribute("username", username); req.setAttribute("age", age); //c重定向 resp.sendRedirect("result.jsp"); //轉發 // RequestDispatcher rd = req.getRequestDispatcher("result.jsp"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } }
4.主頁面(index.jsp)

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="com.javabean.User" %> <!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> <a href="QueryServlet">query</a><br> <% User user = (User)session.getAttribute("user"); if(null == user) { response.sendRedirect("login.jsp"); } if("2".equals(((User)session.getAttribute("user")).getAuthority())){ %> <a href="UpdateServlet">update</a> <%} %> </body> </html>
5.QueryServlelt.java

package com.servlet; import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import com.javabean.User; public class QueryServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { HttpSession session = req.getSession(); if(null == session.getAttribute("user")) { resp.sendRedirect("login.jsp"); return ; } User user = (User)session.getAttribute("user"); if("1".equals(user.getAuthority()))//表示普通用戶 { System.out.println("sihbai"); }else { System.out.println("chenggong"); } } }
6.UpdateServlet.java

package com.servlet; import java.io.IOException; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import com.javabean.User; public class UserLoginServlet extends HttpServlet { @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { String username = (String)req.getParameter("username"); String password = (String)req.getParameter("password"); String authority = (String)req.getParameter("authority"); if("1".equals(authority)) { //登錄的是普通用戶 if("zhangsan".equals(username) && "123".equals(password)) { //將用戶的信息放置到session中 User user = new User(); user.setUsername(username); user.setPassword(password); user.setAuthority(authority); HttpSession session = req.getSession(); session.setAttribute("user", user); req.getRequestDispatcher("index.jsp").forward(req, resp); return; } } else if("2".equals(authority)) { //登錄的是系統管理員 if("lisi".equals(username) && "456".equals(password)) { //將用戶的信息放置到session中 User user = new User(); user.setUsername(username); user.setPassword(password); user.setAuthority(authority); HttpSession session = req.getSession(); session.setAttribute("user", user); req.getRequestDispatcher("index.jsp").forward(req, resp); return; } } //表示登錄失敗 System.out.println("shibai"); //請求轉發模式 // req.setAttribute("username", username); // req.setAttribute("authority",authority); // RequestDispatcher rd = req.getRequestDispatcher("login.jsp"); // rd.forward(req, resp); //重定向 resp.sendRedirect("login.jsp?error=true&username="+username+"&authority="+authority); } }