后端图形验证码base64编码字符串及前端获取图形验证码base64编码字符串并解码显示图形验证码代码

本文介绍了后端利用Java生成图形验证码并进行Base64编码,通过接口传递给前端。前端接收到编码字符串后进行解码并显示图形验证码。参考了相关优快云博客文章,并提供了在线加密解密工具链接供测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

后端生成图形验证码,并进行base64编码生成字符串传至前端,由前端解码显示图形验证码,代码如下:

后端-获取图形验证码base64编码字符串接口:
	/**
     * @param response
     * @return map
     * @throws Exception 获取图形验证码接口
     */
    @RequestMapping("/getVerifyCode")
    @ResponseBody
    public Map getVerifyCode(HttpServletResponse response) throws Exception {
   
   
        Map map = new HashMap();
        //第一个参数是生成的验证码,第二个参数是生成的图片
        Object[] objs = VerifyUtil.createImage();
        //将图片输出给浏览器
        BufferedImage image = (BufferedImage) objs[1];
        String value = objs[0].toString().toLowerCase();
        String key = UUID.randomUUID().toString();
        redisUtils.set(key, value, 2, MINUTES);
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        // 使用ServletOutputStream流可直接输出图片
//        ServletOutputStream outputStream = response.getOutputStream();
        ImageIO.write(image, "png", outputStream);
        Base64 base64 = new Base64();
        String pic = new String(base64.encode(outputStream.toByteArray()));
        map.put("codeKey", key);
        map.put("codePic", pic);
        return map;
    }
后端-生成图形验证码工具类
import java.awt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值