欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java Web實(shí)現(xiàn)登錄頁面驗(yàn)證碼驗(yàn)證功能

 更新時間:2019年12月24日 09:23:35   作者:郭乾亮1998.  
這篇文章主要介紹了Java Web登錄頁面驗(yàn)證碼驗(yàn)證功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下

一、驗(yàn)證碼

驗(yàn)證碼本質(zhì)上是一張圖片,圖片內(nèi)容會隨著程序的運(yùn)行而隨機(jī)生成

驗(yàn)證碼的作用:防止應(yīng)用惡意發(fā)送數(shù)據(jù),一定程度上避免了惡意程序?qū)W(wǎng)站的攻擊。
驗(yàn)證碼本質(zhì)上是一張圖片,圖片內(nèi)容的準(zhǔn)確解析不容易用程序來實(shí)現(xiàn)。
驗(yàn)證碼的繪制:繪制驗(yàn)證碼圖片不僅僅需要隨機(jī)生成要繪制的內(nèi)容,同時要配合Java中與繪圖有關(guān)的一套API來完成。

二、效果演示

驗(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超時時間為10秒
// session.setMaxInactiveInterval(10);
 // 獲得請求路徑
 String uri = request.getRequestURI();
 // 拆分路徑,只保留login.do中的login
 String action = uri.substring(uri.lastIndexOf("/") + 1,uri.lastIndexOf("."));
 // 判斷請求路徑是否為登錄
 if (action.equals("login")) {
 String uname = request.getParameter("uname");
 String pwd = request.getParameter("pwd");
 //獲得用戶提交的驗(yàn)證碼字符
 String vcode = request.getParameter("vcode");
 //獲得session中存儲的最新驗(yàn)證碼字符
 String code = session.getAttribute("code").toString();
 if (code.equals(vcode) &&uname.equals("123") && pwd.equals("123") ) {
 // 將登錄的用戶綁定到session
 session.setAttribute("uname", uname);
 // 重定向到index.jsp
// response.sendRedirect("index.jsp");
 //如果禁用了Cookie,使用URL重寫
 response.sendRedirect(response.encodeRedirectURL("index.jsp"));
 } else {
 // 登錄失敗,就轉(zhuǎn)發(fā)到login.jsp
 request.setAttribute("msg", "輸入有誤,請重新登錄!");
 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.獲取圖片畫筆
 Graphics g = image.getGraphics();
 Random r = new Random();
 //2.設(shè)置畫筆顏色
 g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
 //3.繪制矩形的背景
 g.fillRect(0, 0, 100, 30);
 //4.調(diào)用自定義的方法,獲取長度為5的字母數(shù)字組合的字符串
 String number = getNumber(5);
 //獲得session
 HttpSession session = request.getSession();
 //設(shè)置sesssion失效時間為30秒
// session.setMaxInactiveInterval(30);
 //將這5個隨機(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條干擾線
 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)登錄頁面login.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!-- 登錄顯示的頁面 -->
<%
 Object msg = request.getAttribute("msg");
 if(msg!=null){
 %>
 <%=msg.toString() %>
 <%} %>
<html>
 <head>
 
 </head>
 
 <body>
 <form action="login.do" method="post">
 用戶名:<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)證碼的頁面validateCode.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!-- 展示驗(yàn)證碼的頁面 -->
<html>
 <head>
 <title>驗(yàn)證碼</title>
 <!-- 鼠標(biāo)移入圖片,變成手狀 -->
 <style type="text/css">
 .s1{
 cursor:pointer;
 }
 </style>
 </head>
 <body>
 <!-- 單擊時,重新向code發(fā)送請求,并添加隨機(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"%>
<!-- 登錄成功后的頁面 -->
<%
 //小腳本: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àn)證碼驗(yàn)證功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • java實(shí)現(xiàn)在普通類中注入service或mapper

    java實(shí)現(xiàn)在普通類中注入service或mapper

    這篇文章主要介紹了java實(shí)現(xiàn)在普通類中注入service或mapper的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java畢業(yè)設(shè)計實(shí)戰(zhàn)之在線網(wǎng)盤系統(tǒng)的實(shí)現(xiàn)

    Java畢業(yè)設(shè)計實(shí)戰(zhàn)之在線網(wǎng)盤系統(tǒng)的實(shí)現(xiàn)

    這是一個使用了java+JSP+Springboot+maven+mysql+ThymeLeaf+FTP開發(fā)的在線網(wǎng)盤系統(tǒng),是一個畢業(yè)設(shè)計的實(shí)戰(zhàn)練習(xí),具有網(wǎng)盤該有的所有功能,感興趣的朋友快來看看吧
    2022-01-01
  • 關(guān)于JWT與cookie和token的區(qū)別說明

    關(guān)于JWT與cookie和token的區(qū)別說明

    這篇文章主要介紹了JWT與cookie和token的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 詳解JAVA使用Comparator接口實(shí)現(xiàn)自定義排序

    詳解JAVA使用Comparator接口實(shí)現(xiàn)自定義排序

    這篇文章主要介紹了JAVA使用Comparator接口實(shí)現(xiàn)自定義排序,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Spring請求參數(shù)校驗(yàn)功能實(shí)例演示

    Spring請求參數(shù)校驗(yàn)功能實(shí)例演示

    這篇文章主要介紹了Spring請求參數(shù)校驗(yàn)功能實(shí)例演示,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • 一文詳解Java如何系統(tǒng)地避免空指針問題

    一文詳解Java如何系統(tǒng)地避免空指針問題

    新手Java開發(fā)總是經(jīng)??罩羔槞z查,甚至某些老手也會犯這樣的問題,所以這篇文章小編就帶大家一起來看看如何系統(tǒng)地避免空指針問題,希望對大家有所幫助
    2024-01-01
  • 關(guān)于Java中String創(chuàng)建的字符串對象內(nèi)存分配測試問題

    關(guān)于Java中String創(chuàng)建的字符串對象內(nèi)存分配測試問題

    這篇文章主要介紹了Java中String創(chuàng)建的字符串對象內(nèi)存分配測試,給大家詳細(xì)介紹了在創(chuàng)建String對象的兩種常用方法比較,通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-07-07
  • Java中Map和Set的常見用法舉例

    Java中Map和Set的常見用法舉例

    Map和Set是一種專門用來進(jìn)行搜索的容器或者數(shù)據(jù)結(jié)構(gòu),其具體效率與具體的實(shí)例化子類有關(guān),下面這篇文章主要給大家介紹了關(guān)于Java中Map和Set的常見用法,需要的朋友可以參考下
    2024-04-04
  • Java的MyBatis框架中XML映射緩存的使用教程

    Java的MyBatis框架中XML映射緩存的使用教程

    MyBatis程序在做好XML映射后能夠有緩存的功能,這樣映射過SQL語句的配置以后就可以拿過來直接用了,這里我們來一起總結(jié)一下Java的MyBatis框架中XML映射緩存的使用教程
    2016-06-06
  • 詳解Java如何實(shí)現(xiàn)自定義注解

    詳解Java如何實(shí)現(xiàn)自定義注解

    注解(Annotation),也叫元數(shù)據(jù)。一種代碼級別的說明。它是JDK1.5及以后版本引入的一個特性,與類、接口、枚舉是在同一個層次。本文將通過示例詳解Java如何實(shí)現(xiàn)自定義注解,需要的可以參考一下
    2022-06-06

最新評論