Java Web實(shí)現(xiàn)登錄頁(yè)面驗(yàn)證碼驗(yàn)證功能
一、驗(yàn)證碼
驗(yàn)證碼本質(zhì)上是一張圖片,圖片內(nèi)容會(huì)隨著程序的運(yùn)行而隨機(jī)生成
驗(yàn)證碼的作用:防止應(yīng)用惡意發(fā)送數(shù)據(jù),一定程度上避免了惡意程序?qū)W(wǎng)站的攻擊。
驗(yàn)證碼本質(zhì)上是一張圖片,圖片內(nèi)容的準(zhǔn)確解析不容易用程序來(lái)實(shí)現(xiàn)。
驗(yàn)證碼的繪制:繪制驗(yàn)證碼圖片不僅僅需要隨機(jī)生成要繪制的內(nèi)容,同時(shí)要配合Java中與繪圖有關(guān)的一套API來(lái)完成。
二、效果演示
驗(yàn)證碼Demo
三、給出完整代碼
(1)服務(wù)器端代碼ActionServlet.java
package session; 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; /** * 服務(wù)器端合并Servlet * * @author QianliangGuo */ public class ActionServlet extends HttpServlet { @Override protected void service(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException { // 設(shè)置編碼 request.setCharacterEncoding("utf-8"); // 獲得session HttpSession session = request.getSession(); //設(shè)置session超時(shí)時(shí)間為10秒 // session.setMaxInactiveInterval(10); // 獲得請(qǐng)求路徑 String uri = request.getRequestURI(); // 拆分路徑,只保留login.do中的login String action = uri.substring(uri.lastIndexOf("/") + 1,uri.lastIndexOf(".")); // 判斷請(qǐng)求路徑是否為登錄 if (action.equals("login")) { String uname = request.getParameter("uname"); String pwd = request.getParameter("pwd"); //獲得用戶(hù)提交的驗(yàn)證碼字符 String vcode = request.getParameter("vcode"); //獲得session中存儲(chǔ)的最新驗(yàn)證碼字符 String code = session.getAttribute("code").toString(); if (code.equals(vcode) &&uname.equals("123") && pwd.equals("123") ) { // 將登錄的用戶(hù)綁定到session session.setAttribute("uname", uname); // 重定向到index.jsp // response.sendRedirect("index.jsp"); //如果禁用了Cookie,使用URL重寫(xiě) response.sendRedirect(response.encodeRedirectURL("index.jsp")); } else { // 登錄失敗,就轉(zhuǎn)發(fā)到login.jsp request.setAttribute("msg", "輸入有誤,請(qǐng)重新登錄!"); request.getRequestDispatcher("login.jsp").forward(request,response); } }else if(action.equals("logout")){ //使session失效 session.invalidate(); response.sendRedirect("login.jsp"); } } }
(2)繪制驗(yàn)證碼CodeServlet.java
package session; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.image.BufferedImage; import java.io.IOException; import java.io.OutputStream; import java.util.Random; import javax.imageio.ImageIO; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; /** * 繪制驗(yàn)證碼 * * @author QianliangGuo */ public class CodeServlet extends HttpServlet { @Override protected void service(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { //驗(yàn)證碼的servlet //0.創(chuàng)建空白圖片 BufferedImage image = new BufferedImage(100,30,BufferedImage.TYPE_INT_RGB); //1.獲取圖片畫(huà)筆 Graphics g = image.getGraphics(); Random r = new Random(); //2.設(shè)置畫(huà)筆顏色 g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255))); //3.繪制矩形的背景 g.fillRect(0, 0, 100, 30); //4.調(diào)用自定義的方法,獲取長(zhǎng)度為5的字母數(shù)字組合的字符串 String number = getNumber(5); //獲得session HttpSession session = request.getSession(); //設(shè)置sesssion失效時(shí)間為30秒 // session.setMaxInactiveInterval(30); //將這5個(gè)隨機(jī)字符綁定到session中 session.setAttribute("code", number); g.setColor(new Color(0,0,0)); g.setFont(new Font(null,Font.BOLD,24)); //5.設(shè)置顏色字體后,繪制字符串 g.drawString(number, 5, 25); //6.繪制8條干擾線(xiàn) for(int i=0;i<8;i++){ g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255),r.nextInt(255))); g.drawLine(r.nextInt(100), r.nextInt(30), r.nextInt(100), r.nextInt(30)); } response.setContentType("img/jpeg"); OutputStream ops = response.getOutputStream(); ImageIO.write(image,"jpeg",ops); ops.close(); } private String getNumber(int size) { String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; String number = ""; Random r = new Random(); for(int i=0;i<size;i++){ number+=str.charAt(r.nextInt(str.length())); } return number; } }
(2)登錄頁(yè)面login.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <!-- 登錄顯示的頁(yè)面 --> <% Object msg = request.getAttribute("msg"); if(msg!=null){ %> <%=msg.toString() %> <%} %> <html> <head> </head> <body> <form action="login.do" method="post"> 用戶(hù)名:<input name="uname"/></br> 密碼:<input name = "pwd" type="password"/> </br> 驗(yàn)證碼:<input name="vcode"/> <img src="code" onclick="this.src='code?'+Math.random();" class="s1" title="點(diǎn)擊更換"/><br/> <input type="submit" value="登錄"/> </form> </body> </html>
(3)展示驗(yàn)證碼的頁(yè)面validateCode.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <!-- 展示驗(yàn)證碼的頁(yè)面 --> <html> <head> <title>驗(yàn)證碼</title> <!-- 鼠標(biāo)移入圖片,變成手狀 --> <style type="text/css"> .s1{ cursor:pointer; } </style> </head> <body> <!-- 單擊時(shí),重新向code發(fā)送請(qǐng)求,并添加隨機(jī)數(shù),欺騙瀏覽器為不同的地址 --> <img src="code" onclick="this.src='code?'+Math.random();" class="s1" title="點(diǎn)擊更換"/> </body> </html>
(5)index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <!-- 登錄成功后的頁(yè)面 --> <% //小腳本:session驗(yàn)證 Object uname = session.getAttribute("uname"); if(uname == null){ //重定向到login.jsp response.sendRedirect("login.jsp"); return; } %> <html> <head> </head> <body> <h1>歡迎登錄:<%=uname.toString() %></h1> <a href="logout.do" rel="external nofollow" >退出</a> </body> </html>
總結(jié)
以上所述是小編給大家介紹的Java Web實(shí)現(xiàn)登錄頁(yè)面驗(yàn)證碼驗(yàn)證功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- 5分鐘教你使用java搞定網(wǎng)站登錄驗(yàn)證碼
- Java實(shí)現(xiàn)注冊(cè)登錄與郵箱發(fā)送賬號(hào)驗(yàn)證激活功能
- Java?自定義注解在登錄驗(yàn)證的應(yīng)用示例
- Java登錄功能實(shí)現(xiàn)token生成與驗(yàn)證
- 教你用Java驗(yàn)證服務(wù)器登錄系統(tǒng)
- Java Web制作登錄驗(yàn)證碼實(shí)現(xiàn)代碼解析
- JavaWeb簡(jiǎn)單用戶(hù)登錄注冊(cè)實(shí)例代碼(有驗(yàn)證碼)
- java圖片滑動(dòng)驗(yàn)證(登錄驗(yàn)證)原理與實(shí)現(xiàn)方法詳解
- java實(shí)現(xiàn)登錄驗(yàn)證碼
- Java基于Session登錄驗(yàn)證的實(shí)現(xiàn)示例
相關(guān)文章
java實(shí)現(xiàn)在普通類(lèi)中注入service或mapper
這篇文章主要介紹了java實(shí)現(xiàn)在普通類(lèi)中注入service或mapper的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07Java畢業(yè)設(shè)計(jì)實(shí)戰(zhàn)之在線(xiàn)網(wǎng)盤(pán)系統(tǒng)的實(shí)現(xiàn)
這是一個(gè)使用了java+JSP+Springboot+maven+mysql+ThymeLeaf+FTP開(kāi)發(fā)的在線(xiàn)網(wǎng)盤(pán)系統(tǒng),是一個(gè)畢業(yè)設(shè)計(jì)的實(shí)戰(zhàn)練習(xí),具有網(wǎng)盤(pán)該有的所有功能,感興趣的朋友快來(lái)看看吧2022-01-01關(guān)于JWT與cookie和token的區(qū)別說(shuō)明
這篇文章主要介紹了JWT與cookie和token的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10詳解JAVA使用Comparator接口實(shí)現(xiàn)自定義排序
這篇文章主要介紹了JAVA使用Comparator接口實(shí)現(xiàn)自定義排序,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Spring請(qǐng)求參數(shù)校驗(yàn)功能實(shí)例演示
這篇文章主要介紹了Spring請(qǐng)求參數(shù)校驗(yàn)功能實(shí)例演示,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05一文詳解Java如何系統(tǒng)地避免空指針問(wèn)題
新手Java開(kāi)發(fā)總是經(jīng)??罩羔槞z查,甚至某些老手也會(huì)犯這樣的問(wèn)題,所以這篇文章小編就帶大家一起來(lái)看看如何系統(tǒng)地避免空指針問(wèn)題,希望對(duì)大家有所幫助2024-01-01關(guān)于Java中String創(chuàng)建的字符串對(duì)象內(nèi)存分配測(cè)試問(wèn)題
這篇文章主要介紹了Java中String創(chuàng)建的字符串對(duì)象內(nèi)存分配測(cè)試,給大家詳細(xì)介紹了在創(chuàng)建String對(duì)象的兩種常用方法比較,通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07