java - 点击图片进行验证码的切换案例的实现.

CodeServlte.java    - -    绘制验证码图片和随机号码.

@WebServlet("/code")
public class CodeServlet extends HttpServlet {

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

		// 使用java图形界面技术绘制一张图片

		int charNum = 4;
		int width = 20 * 4;
		int height = 28;

		// 1. 创建一张内存图片
		BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

		// 2.获得绘图对象
		Graphics graphics = bufferedImage.getGraphics();

		// 3、绘制背景颜色
		graphics.setColor(Color.YELLOW);
		graphics.fillRect(0, 0, width, height);

		// 4、绘制图片边框
		graphics.setColor(Color.GRAY);
		graphics.drawRect(0, 0, width - 1, height - 1);

		// 5、输出验证码内容
		graphics.setColor(Color.RED);
		graphics.setFont(new Font("宋体", Font.BOLD, 22));
		
		// 随机输出4个字符
		String s = "ABCDEFGHGKLMNPQRSTUVWXYZ23456789";
		Random random = new Random();
		
		// session中要用到
		String msg = "";
		
		int x = 5;
		for (int i = 0; i < charNum; i++) {
			int index = random.nextInt(32);
			String content = String.valueOf(s.charAt(index));
			
			msg += content;
			graphics.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255)));
			graphics.drawString(content, x, 22);
			x += 20;
		}

		// 6、绘制干扰线
		graphics.setColor(Color.GRAY);
		for (int i = 0; i < 5; i++) {
			int x1 = random.nextInt(width);
			int x2 = random.nextInt(width);

			int y1 = random.nextInt(height);
			int y2 = random.nextInt(height);
			graphics.drawLine(x1, y1, x2, y2);
		}

		// 释放资源
		graphics.dispose();

		// 图片输出 ImageIO 装裱
		ImageIO.write(bufferedImage, "jpg", response.getOutputStream());

	}

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

}

登录页面: login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div>
        <form action="#" method="post">
            用名名:<input type="text" name="username" placeholder="请输入用户名"><br/>
            密码尔:<input type="password" class="form-control" name="password" placeholder="请输入密码"><br/>
            验证码:<input type="text" class="form-control" placeholder="请输入验证码">
            <img id="img" src="http://localhost/code"/><br />
            <input type="submit" value="登录" />
        </form>
    </div>

    <script type="text/javascript">
        // 通过id获取属性值.
        var img = document.getElementById("img");
        // 当图片被点击的时候 , 进行图片的切换.
        img.onclick = function () {
            // 设置src属性为验证码路径.
            // 因为路径一样 , 所以设置一个参数变得不一样.
            img.src = "http://localhost/code?sss="+new Date().getTime();
        }
    </script>

</body>
</html>
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,要实现点击图片切换验证码,可以按照以下步骤进行操作: 1. 创建一个包含多个验证码图片的集合。可以使用ArrayList或者数组来存储这些图片。 2. 在用户点击图片时,通过事件监听器获取用户点击图片索引。 3. 根据用户点击图片索引,获取对应的验证码图片。 4. 将获取到的验证码图片显示在需要切换验证码的位置上。 以下是一个简单的示例代码: ```java import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; import java.util.ArrayList; import javax.swing.ImageIcon; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; public class CaptchaImageSwitcher { private ArrayList<ImageIcon> captchaImages; private int currentImageIndex; private JLabel captchaLabel; public CaptchaImageSwitcher() { captchaImages = new ArrayList<>(); // 加载验证码图片到captchaImages集合中 captchaImages.add(new ImageIcon("captcha1.jpg")); captchaImages.add(new ImageIcon("captcha2.jpg")); captchaImages.add(new ImageIcon("captcha3.jpg")); currentImageIndex = 0; JFrame frame = new JFrame("Captcha Image Switcher"); JPanel panel = new JPanel(); captchaLabel = new JLabel(captchaImages.get(currentImageIndex)); captchaLabel.addMouseListener(new MouseAdapter() { @Override public void mouseClicked(MouseEvent e) { // 切换到下一张验证码图片 currentImageIndex = (currentImageIndex + 1) % captchaImages.size(); captchaLabel.setIcon(captchaImages.get(currentImageIndex)); } }); panel.add(captchaLabel); frame.add(panel); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.pack(); frame.setVisible(true); } public static void main(String[] args) { new CaptchaImageSwitcher(); } } ``` 请注意,这只是一个简单的示例,你需要根据你的具体需求进行修改和适配。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值