package servlet; import domain.User; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.List; /* * 用戶登陸的Servlet * */ @WebServlet("/login") public class LoginServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { req.setCharacterEncoding("utf-8"); resp.setCharacterEncoding("utf-8"); //接收數據 String username = req.getParameter("username"); String password = req.getParameter("password"); //從ServletContext域中得到保存用戶信息集合 List<User> list = (List<User>) this.getServletContext().getAttribute("list"); for (User user:list){ //判斷用戶名是否正確 if (username.equals(user.getUsername())){ //判斷密碼是否正確 if (password.equals(user.getPassword())){ //用戶名密碼都正確 //登陸成功 //判斷記住用戶名複選框是否勾選 String remember = req.getParameter("remember"); if ("true".equals(remember)){ //完成記住用戶名的功能 Cookie cookie = new Cookie("username",username); //設置有效路徑 cookie.setPath("/login.jsp"); //設置有效時間 cookie.setMaxAge(60*60*24); //將cookie回寫到瀏覽器 resp.addCookie(cookie); } //將用戶的信息保存到Session中 req.getSession().setAttribute("user",user); resp.sendRedirect("/success.jsp"); return; } } } //登陸失敗 req.setAttribute("msg","用戶名或密碼錯誤!"); req.getRequestDispatcher("/login.jsp").forward(req,resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } }
package utils; import javax.servlet.http.Cookie; public class CookieUtils { public static Cookie findCookie(Cookie[] cookies,String name){ if (cookies==null){ //說明客戶端沒有攜帶Cookie return null; }else { //說明客戶端攜帶Cookie for (Cookie cookie:cookies){ if (name.equals(cookie.getName())){ return cookie; } } return null; } } }
<%@page import="domain.User"%> <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登陸成功</title> <link rel="stylesheet" href="./css/login.css"> </head> <body> <% if(session.getAttribute("user")!=null){ User user = (User)session.getAttribute("user"); System.out.println(user.getPath()); // 得到絕對路徑最後一個\的位置 int idx = user.getPath().lastIndexOf("\\"); // 得到文件上傳的惟一文件名: String fileName = user.getPath().substring(idx+1); %> <div class="login"> <div class="header"> <h1>登陸成功</h1> </div> <div class="content"> <table align="center"> <tr> <td align="center"><img src="/img/<%= fileName %>" /></td> </tr> <tr> <td align="center">歡迎<%= user.getNickname() %>,登陸成功!</td> </tr> </table> </div> </div> <% }else{ %> <div class="login"> <div class="header"> <h1>您尚未登陸!請先去<a href="/login.jsp">登陸</a>!</h1> </div> </div> <% } %> </body> </html>
若是有朋友是按照上篇的代碼一路敲過來的,這裏有個問題,就是啓動服務器後你必須先訪問/initServlet去執行init()方法,不然你註冊的信息將沒法存儲。css
在這再給你教另一種方法,就是在Web.xml中配置InitServlet,當服務器一啓動,init()方法就馬上被執行,不用你再去手動訪問了,操做過程以下:html
第一步:找到web.xml,配置以下圖所示的信息java
<!DOCTYPEweb-appPUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<servlet>
<servlet-name>initServlet</servlet-name>
<servlet-class>servlet.InitServlet</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>initServlet</servlet-name>
<url-pattern>/initServlet</url-pattern>
</servlet-mapping>
</web-app>
第二步:去掉@WebServlet(「/initServlet」)註解web
好了,這樣就完成了,如今已開啓服務器,就能夠直接訪問註冊頁面進行註冊了。 設計模式
寫到這案例算是結束了,這裏面用了MVC的設計模式,運用了JSP,Servlet裏面的知識,有Web四大域對象的使用,參數的請求和接收,轉發和重定向,集合的使用,還有Cookie和Session的使用,表單數據的接收,文件的上傳,涉及的方面多,但不超綱,都是JavaSE中學過的部分,在這作個系統性的應用,我的認爲此案例適合於初學者練手,但願能幫助到一些真正須要的朋友。瀏覽器
*****************************************************************************************************服務器
個人博客園地址:https://www.cnblogs.com/zyx110/cookie