Cookie和Session-学习笔记04【Session之验证码案例】
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                Cookie和Session-学习笔记04【Session之验证码案例】
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                - Java后端 學習路線 筆記匯總表【黑馬程序員】
目錄
第7節 Session之驗證碼案例
案例_驗證碼_需求&分析
案例_驗證碼_代碼實現
login.jsp頁面效果
將驗證碼存入session
案例_驗證碼_細節處理
細節處理1:美化頁面
細節處理2:一次性 驗證碼
代碼總覽
案例效果
代碼1-login.jsp
代碼2-LoginServlet.java
代碼3-CookieTest.java
代碼4-CheckCodeServlet.java
代碼5-success.jsp
第7節 Session之驗證碼案例
案例_驗證碼_需求&分析
1. 案例需求:
 ?? ?1. 訪問帶有驗證碼的登錄頁面login.jsp
 ?? ?2. 用戶輸入用戶名,密碼以及驗證碼。
 ?? ??? ?* 如果用戶名和密碼輸入有誤,跳轉登錄頁面,提示:用戶名或密碼錯誤;
 ?? ??? ?* 如果驗證碼輸入有誤,跳轉登錄頁面,提示:驗證碼錯誤;
 ?? ??? ?* 如果全部輸入正確,則跳轉到主頁success.jsp,顯示:用戶名,歡迎您。
 2. 分析:...
案例_驗證碼_代碼實現
login.jsp頁面效果
將驗證碼存入session
????
案例_驗證碼_細節處理
細節處理1:美化頁面
細節處理2:一次性 驗證碼
代碼總覽
案例效果
用戶名:zhangsan、密碼:123
代碼1-login.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head><title>login</title><script>window.onload = function () {document.getElementById("img").onclick = function () {this.src = "/day16/checkCodeServlet?time=" + new Date().getTime();}}</script><style>div {color: red;}</style> </head> <body><form action="/day16/loginServlet" method="post"><table><tr><td>用戶名</td><td><input type="text" name="username"></td></tr><tr><td>密碼</td><td><input type="password" name="password"></td></tr><tr><td>驗證碼</td><td><input type="text" name="checkCode"></td></tr><tr><td colspan="2"><img id="img" src="/day16/checkCodeServlet"></td></tr><tr><td colspan="2"><input type="submit" value="登錄"></td></tr></table></form><div><%=request.getAttribute("cc_error") == null ? "" : request.getAttribute("cc_error")%></div><div><%=request.getAttribute("login_error") == null ? "" : request.getAttribute("login_error") %></div> </body> </html>代碼2-LoginServlet.java
package cn.itcast.servlet;import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException;@WebServlet("/loginServlet") public class LoginServlet extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//1.設置request編碼request.setCharacterEncoding("utf-8");//2.獲取參數String username = request.getParameter("username");String password = request.getParameter("password");String checkCode = request.getParameter("checkCode");//3.先獲取生成的驗證碼HttpSession session = request.getSession();String checkCode_session = (String) session.getAttribute("checkCode_session");//刪除session中存儲的驗證碼session.removeAttribute("checkCode_session");//3.先判斷驗證碼是否正確if (checkCode_session != null && checkCode_session.equalsIgnoreCase(checkCode)) {//忽略大小寫進行比較//驗證碼正確//判斷用戶名和密碼是否一致if ("zhangsan".equals(username) && "123".equals(password)) {//需要調用UserDao查詢數據庫//登錄成功//存儲信息,用戶信息session.setAttribute("user", username);//重定向到success.jspresponse.sendRedirect(request.getContextPath() + "/success.jsp");} else {//登錄失敗//存儲提示信息到requestrequest.setAttribute("login_error", "用戶名或密碼錯誤");//轉發到登錄頁面request.getRequestDispatcher("/login.jsp").forward(request, response);}} else {//驗證碼不一致//存儲提示信息到requestrequest.setAttribute("cc_error", "驗證碼錯誤");//轉發到登錄頁面request.getRequestDispatcher("/login.jsp").forward(request, response);}}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {this.doPost(request, response);} }代碼3-CookieTest.java
package cn.itcast.cookie;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.net.URLDecoder; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.Date;/*** 在服務器中的Servlet判斷是否有一個名為lastTime的cookie* 1. 有:不是第一次訪問* 1. 響應數據:歡迎回來,您上次訪問時間為:2018年6月10日11:50:20* 2. 寫回Cookie:lastTime=2018年6月10日11:50:01* 2. 沒有:是第一次訪問* 1. 響應數據:您好,歡迎您首次訪問* 2. 寫回Cookie:lastTime=2018年6月10日11:50:01*/@WebServlet("/cookieTest") public class CookieTest extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//設置響應的消息體的數據格式以及編碼response.setContentType("text/html;charset=utf-8");//1.獲取所有CookieCookie[] cookies = request.getCookies();boolean flag = false;//沒有cookie為lastTime//2.遍歷cookie數組if (cookies != null && cookies.length > 0) {for (Cookie cookie : cookies) {//3.獲取cookie的名稱String name = cookie.getName();//4.判斷名稱是否是:lastTimeif ("lastTime".equals(name)) {//有該Cookie,不是第一次訪問flag = true;//有lastTime的cookie//設置Cookie的value//獲取當前時間的字符串,重新設置Cookie的值,重新發送cookieDate date = new Date();SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");String str_date = sdf.format(date);System.out.println("編碼前:" + str_date);//URL編碼str_date = URLEncoder.encode(str_date, "utf-8");System.out.println("編碼后:" + str_date);cookie.setValue(str_date);//設置cookie的存活時間cookie.setMaxAge(60 * 60 * 24 * 30);//一個月response.addCookie(cookie);//響應數據//獲取Cookie的value,時間String value = cookie.getValue();System.out.println("解碼前:" + value);//URL解碼:value = URLDecoder.decode(value, "utf-8");System.out.println("解碼后:" + value);response.getWriter().write("<h1>歡迎回來,您上次訪問時間為:" + value + "!</h1>");break;}}}if (cookies == null || cookies.length == 0 || flag == false) {//沒有,第一次訪問//設置Cookie的value//獲取當前時間的字符串,重新設置Cookie的值,重新發送cookieDate date = new Date();SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");String str_date = sdf.format(date);System.out.println("編碼前:" + str_date);//URL編碼str_date = URLEncoder.encode(str_date, "utf-8");System.out.println("編碼后:" + str_date);Cookie cookie = new Cookie("lastTime", str_date);//設置cookie的存活時間cookie.setMaxAge(60 * 60 * 24 * 30);//一個月response.addCookie(cookie);response.getWriter().write("<h1>您好,歡迎您首次訪問!</h1>");}}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {this.doPost(request, response);} }代碼4-CheckCodeServlet.java
package cn.itcast.servlet;import javax.imageio.ImageIO; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.awt.*; import java.awt.image.BufferedImage; import java.io.IOException; import java.util.Random;@WebServlet("/checkCodeServlet") public class CheckCodeServlet extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {int width = 100;int height = 50;//1.創建一對象,在內存中圖片(驗證碼圖片對象)BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);//2.美化圖片//2.1 填充背景色Graphics g = image.getGraphics();//畫筆對象g.setColor(Color.PINK);//設置畫筆顏色g.fillRect(0, 0, width, height);//2.2畫邊框g.setColor(Color.BLUE);g.drawRect(0, 0, width - 1, height - 1);String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghigklmnopqrstuvwxyz0123456789";//生成隨機角標Random ran = new Random();StringBuilder sb = new StringBuilder();for (int i = 1; i <= 4; i++) {int index = ran.nextInt(str.length());//獲取字符char ch = str.charAt(index);//隨機字符sb.append(ch);//2.3寫驗證碼g.drawString(ch + "", width / 5 * i, height / 2);}String checkCode_session = sb.toString();//將驗證碼存入sessionrequest.getSession().setAttribute("checkCode_session", checkCode_session);//2.4畫干擾線g.setColor(Color.GREEN);//隨機生成坐標點for (int i = 0; i < 10; i++) {int x1 = ran.nextInt(width);int x2 = ran.nextInt(width);int y1 = ran.nextInt(height);int y2 = ran.nextInt(height);g.drawLine(x1, y1, x2, y2);}//3.將圖片輸出到頁面展示ImageIO.write(image, "jpg", response.getOutputStream());}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {this.doPost(request, response);} }代碼5-success.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head><title>Title</title> </head> <body><h1><%=request.getSession().getAttribute("user")%>,歡迎您</h1> </body> </html>加油~? ?ヾ(?°?°?)ノ゙
總結
以上是生活随笔為你收集整理的Cookie和Session-学习笔记04【Session之验证码案例】的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: Cookie和Session-学习笔记0
- 下一篇: JSP、EL和JSTL-学习笔记01【J
