a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > JSP > 正文

JSP開發(fā)之生成圖片驗證碼技術(shù)的詳解

2024-09-05 00:23:23
字體:
供稿:網(wǎng)友

JSP開發(fā)之生成圖片驗證碼技術(shù)的詳解

我們在網(wǎng)頁注冊用戶時,常常會需要格根據(jù)圖片給的圖片驗證碼把驗證碼輸進去。那么我們今天就來學(xué)習(xí)這個。

簡單來說分為三步驟:

1.底層用Java實現(xiàn)生成驗證碼圖片
2.通過配置文件調(diào)用實現(xiàn)Java生成片
3.通過HTML技術(shù)把圖片顯示到網(wǎng)頁

首先是最底層Java生成圖片代碼

package cn.hncu.servlets;import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.image.BufferedImage;import java.io.FileOutputStream;import java.io.IOException;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;public class CodeImgServlet extends HttpServlet {  @Override  protected void service(HttpServletRequest req, HttpServletResponse resp)      throws ServletException, IOException {    //☆1☆--相比純java方式有變化的地方    resp.setContentType("image/jpeg");//設(shè)置http響應(yīng)頭---告訴瀏覽器我現(xiàn)在發(fā)的是這個圖片格式的數(shù)據(jù),你用相應(yīng)的方式來解析    //定義圖片的寬和高    int w=60;    int h=30;    //聲明一個RGB格式的內(nèi)存中的圖片    BufferedImage img = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB);    Graphics g = img.getGraphics();    //把背景變白色    g.setColor(Color.white);    g.fillRect(0, 0, w, h);    //設(shè)置字體    g.setFont(new Font("aa",Font.BOLD,18));    //產(chǎn)生并draw出4個隨機數(shù)字    Random r = new Random();    for(int i=0;i<4;i++){      int a = r.nextInt(10);//生成0~9之間的隨機整數(shù)      int y = 15+r.nextInt(20);//產(chǎn)生隨機的垂直位置      //產(chǎn)生隨機顏色      Color c = new Color(r.nextInt(256),r.nextInt(256),r.nextInt(256));      g.setColor(c);      g.drawString(""+a, i*15, y);    }    //畫幾條干擾線    for(int i=0;i<10;i++){      //產(chǎn)生隨機顏色      Color c = new Color(r.nextInt(256),r.nextInt(256),r.nextInt(256));      g.setColor(c);      g.drawLine(r.nextInt(60), r.nextInt(30), r.nextInt(60), r.nextInt(30));    }    g.dispose();//類似于IO中的flush(),把圖形數(shù)據(jù)刷到img中    //把內(nèi)存圖片img對象保存到一個jpg文件    ImageIO.write(img, "JPEG", resp.getOutputStream() );//☆2☆  }}

項目中的Web.xml配置文件代碼

<?xml version="1.0" encoding="UTF-8"?><web-app version="3.0"   xmlns="http://java.sun.com/xml/ns/javaee"   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <display-name></display-name>  <!-- 安全目錄中的jsp文件如果要允許外面訪問,得在web.xml進行配置,配置成一個jsp-servlet --> <servlet>  <servlet-name>ajsp</servlet-name>  <!-- 配置servlet用servlet-class, 配置jsp頁面用jsp-file標(biāo)簽 -->  <jsp-file>/WEB-INF/jsps/a.jsp</jsp-file> </servlet> <!--   <servlet>  <servlet-name>CodeImgServlet</servlet-name>  <servlet-class>cn.hncu.servlets.CodeImgServlet</servlet-class>  </servlet>  <servlet>  <servlet-name>LoginServlet</servlet-name>  <servlet-class>cn.hncu.servlets.LoginServlet</servlet-class>  </servlet>  -->   <servlet>    <servlet-name>CodeImgServlet</servlet-name>    <servlet-class>cn.hncu.servlets.CodeImgServlet</servlet-class>   </servlet>   <servlet>    <servlet-name>LoginServlet</servlet-name>    <servlet-class>cn.hncu.servlets.LoginServlet</servlet-class>   </servlet> <!-- 給servlet配置訪問路徑 --> <servlet-mapping>  <servlet-name>ajsp</servlet-name>  <url-pattern>/x/a.asp</url-pattern> </servlet-mapping> <servlet-mapping>  <servlet-name>CodeImgServlet</servlet-name>  <url-pattern>/code</url-pattern> </servlet-mapping> <servlet-mapping>  <servlet-name>LoginServlet</servlet-name>  <url-pattern>/LoginServlet</url-pattern> </servlet-mapping> <welcome-file-list>  <welcome-file>index.jsp</welcome-file> </welcome-file-list></web-app>

主頁面代碼登錄代碼

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html> <head> <script type="text/javascript">   function changeImg(){     var img = document.getElementById("codeImg");     // 當(dāng)src每次的路徑方式變化時,就會去重新請求一次后臺。     img.src="code?"+new Date().getTime();   } </script> </head> <body>  <h2>用戶注冊</h2>   <form action="LoginServlet" method="post">      姓名:<input type="text" name="name"><br/>      密碼:<input type="password" name="pwd"><br/>    <!--      驗證碼:<input type="text" name="code"/><img src="imgs/a.jpg"/><br/>     -->      驗證碼:<input type="text" name="code"/><img id="codeImg" src="code"/><a href="javascript:changeImg();" rel="external nofollow" >看不清</a><br/>     <input type="submit" value="注冊">   </form>   <br/><br/>   <hr/>   <a href="WEB-INF/jsps/a.jsp" rel="external nofollow" >WA---a.jsp</a> <br/>   <a href="/helloWebProj/x/a.asp" rel="external nofollow" >AC---a.jsp</a> <br/> </body></html>

當(dāng)頁面加載,就向TOMCAT請求服務(wù),調(diào)用前面的JAVA類,生成圖片,再通過HTML文檔,將圖片加載到頁面來。

JSP,生成,圖片驗證碼,java生成圖片驗證碼的實例

其次Web.xml配置文件還可以用來設(shè)置訪問安全目錄文件(WEB-INF)

 <servlet>     <servlet-name>ajsp</servlet-name>    <!-- 配置servlet用servlet-class, 配置jsp頁面用jsp-file標(biāo)簽 -->     <jsp-file>/WEB-INF/jsps/a.jsp</jsp-file>   </servlet>     <servlet>    <servlet-name>CodeImgServlet</servlet-name>    <servlet-class>cn.hncu.servlets.CodeImgServlet</servlet-class>   </servlet>   <servlet>    <servlet-name>LoginServlet</servlet-name>    <servlet-class>cn.hncu.servlets.LoginServlet</servlet-class>   </servlet> <!-- 給servlet配置訪問路徑 --> <servlet-mapping>  <servlet-name>ajsp</servlet-name>  <url-pattern>/x/a.asp</url-pattern> </servlet-mapping> <servlet-mapping>  <servlet-name>CodeImgServlet</servlet-name>  <url-pattern>/code</url-pattern> </servlet-mapping> <servlet-mapping>  <servlet-name>LoginServlet</servlet-name>  <url-pattern>/LoginServlet</url-pattern> </servlet-mapping>

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望通過本文能幫助到大家,謝謝大家對本站的支持!


注:相關(guān)教程知識閱讀請移步到JSP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久精品免费一区二区三区 | 一本色道久久综合狠狠躁篇怎么玩 | 欧美日韩在线视频一区二区 | 国产精品美女久久久久久久久久久 | 久久久夜夜夜 | 国产片久久 | 欧美视频免费在线 | 成人不卡视频 | 欧美电影一区二区三区 | 日日躁夜夜操 | 国产成人福利视频 | 黄色av电影在线看 | 欧美成人精品一区二区男人看 | 一区二区高清 | 色综合久久88色综合天天 | 一级做a爰 | 国产偷v国产偷∨精品视频 国产偷v国产偷v亚洲 | 91久久久久久久久久久久久 | 久久情趣视频 | 国产伦精品一区二区三区不卡视频 | 日韩精品影院 | 一级黄色录像免费观看 | 国产精品久久久久久久免费大片 | 欧美日韩成人在线视频 | 欧美精品一区二区三区在线播放 | 欧美日韩在线精品 | 国产精品久久久久久久久久久久久久 | 午夜激情视频 | 欧美喷潮久久久xxxxx | 亚洲欧美中文日韩在线v日本 | 中文字幕在线观看av | 一本大道综合伊人精品热热 | 91伊人| 国产精品一区二区吃奶在线观看 | 一道本一区二区三区 | 日本天天操 | 欧美一区二区三区四区不卡 | 伊人av超碰久久久麻豆 | 国产精品一区二区福利视频 | 在线日韩一区 | a毛片|