servlet实现验证码

servlet生成验证码

package com.dr;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;

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 YZM extends HttpServlet {


public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

this.doPost(request, response);
}

public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

response.setContentType("image/jpeg;chrset=utf-8");
//PrintWriter out = response.getWriter();
BufferedImage bi = new BufferedImage(100, 25,BufferedImage.TYPE_INT_ARGB );//????
Graphics gg = bi.getGraphics();//????
gg.setColor(Color.cyan);//????
gg.fill3DRect(0, 0, 500, 500, true);//????
gg.setFont(new Font("????", 0, 26));//????//????
gg.setColor(Color.BLACK); //????
String ss="";
Dr d = new Dr();
ss= d.drow();
Date da = new Date();
SimpleDateFormat s = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") ;
String dd=s.format(da);
gg.drawString(ss, 20, 22);//????
ImageIO.write(bi, "jpeg", response.getOutputStream());
}

}

java dr产生随机数

package com.dr;

public class Dr {

public String drow(){
String s = "";
String shu ="1234567890poiuytrewqasdf<wbr>ghjklmnbvcxzQWERTYUIOPLK<wbr>JHGFDSAZXCVBNM";<br> for (int i = 0; i &lt; 4; i++) {<br> s=s+(shu.charAt(((int) (Math.random()*62))));<br> }</wbr></wbr>

return s;

}
}

JSP端显示验证码

<%@ page language="java" import="java.util.*,com.dr.*"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">

<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<script type="text/javascript">
function shua(){
document.getElementByIdx_x("im").src="YZM?"+Math.random();

}

//此函数实现了调用的时候生成不同的验证码

</script>
<body bgcolor='778899'>
<center>
<%
Dr d = new Dr();
String s = d.drow();
%>
<%
if (request.getParameter("login") != null) {
out.print("登录失败,请重新登录!!");
}
%>
<form action="UserSer" method="post" name="loginForm">
用户名:
<input type="text" name="username" />
<br />
密码:
<input type="password" name="password" />
<br />
请输入验证码:
<input type="text" name="rr" size="4"/> <img src="YZM" />
<br />
<input type="submit" value="快速登录" />
</form>
<hr />
<%
if (request.getParameter("zhuce") != null) {
out.print("对不起注册失败,重新注册!");
}
%>
<form action="LoginSer" method="post">
用户名:
<input type="text" name="lusername" />
<br />
密码:
<input type="password" name="lpassword" />
<br />
确认密码
<input type="password" name="llpassword" />
<br />
请输入验证码:
<input type="text" name="lrr" size="4"/><img src="YZM" id="im"/><b οnmοuseοver="shua()">刷新</b>
<br />
<input type="submit" value="快速注册" />

</form>

</center>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现验证码功能的主要思路是在用户注册或登录时生成一个随机的验证码图片,并将验证码保存在session中。当用户提交表单时,将用户输入的验证码与session中保存的验证码进行比对,如果一致则继续执行,否则提示用户输入错误。 以下是一个使用IDEA和Servlet实现验证码功能的示例代码。 1. 首先,在web.xml中配置servletservlet-mapping: ```xml <servlet> <servlet-name>VerifyCodeServlet</servlet-name> <servlet-class>com.example.VerifyCodeServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>VerifyCodeServlet</servlet-name> <url-pattern>/verifyCode</url-pattern> </servlet-mapping> ``` 2. 创建一个名为VerifyCodeServletservlet类,实现doGet方法: ```java package com.example; 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 javax.servlet.http.HttpSession; import java.awt.*; import java.awt.image.BufferedImage; import java.io.IOException; import java.util.Random; @WebServlet("/verifyCode") public class VerifyCodeServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { int width = 100; int height = 30; //创建一个图像缓冲区 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); //获取Graphics2D Graphics2D g2 = (Graphics2D) image.getGraphics(); //设置背景色 g2.setColor(Color.WHITE); g2.fillRect(0, 0, width, height); //设置字体 g2.setFont(new Font("宋体", Font.BOLD, 20)); //生成随机字符 String verifyCode = generateVerifyCode(); //将验证码保存在session中 HttpSession session = request.getSession(); session.setAttribute("verifyCode", verifyCode); //绘制验证码 Random random = new Random(); for (int i = 0; i < verifyCode.length(); i++) { g2.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255))); g2.drawString(String.valueOf(verifyCode.charAt(i)), i * 20 + 10, 20); } //加入干扰线 for (int i = 0; i < 5; i++) { g2.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255))); g2.drawLine(random.nextInt(width), random.nextInt(height), random.nextInt(width), random.nextInt(height)); } //输出图像到页面 response.setContentType("image/jpeg"); ImageIO.write(image, "jpeg", response.getOutputStream()); } /** * 生成随机验证码 * * @return */ private String generateVerifyCode() { String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; StringBuilder sb = new StringBuilder(); Random random = new Random(); for (int i = 0; i < 4; i++) { sb.append(chars.charAt(random.nextInt(chars.length()))); } return sb.toString(); } } ``` 3. 在用户注册或登录页面中添加验证码图片和输入框: ```html <form action="login" method="post"> <div> <label for="username">用户名:</label> <input type="text" name="username" id="username"> </div> <div> <label for="password">密码:</label> <input type="password" name="password" id="password"> </div> <div> <label for="verifyCode">验证码:</label> <input type="text" name="verifyCode" id="verifyCode"> <img src="verifyCode" alt="验证码"> </div> <div> <input type="submit" value="登录"> </div> </form> ``` 4. 在用户登录或注册时验证验证码是否正确: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取用户输入的验证码 String verifyCode = request.getParameter("verifyCode"); //获取session中保存的验证码 HttpSession session = request.getSession(); String sessionVerifyCode = (String) session.getAttribute("verifyCode"); //比对验证码 if (verifyCode.equalsIgnoreCase(sessionVerifyCode)) { //验证码正确,继续执行 } else { //验证码错误,提示用户 } } ``` 以上就是用IDEA和Servlet实现验证码功能的示例代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值