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

后端生成图形验证码,并进行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.*
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用JavaBase64编码器将验证码转换为Base64编码字符串,然后将其作为JSON响应发送到前端。在前端,可以使用JavaScript的atob()函数将Base64编码字符串解码,并将其显示在图像元素中。 以下是一个示例代码片段,用于将Java中生成的验证码编码Base64字符串并将其发送到前端: ```java @RestController public class CaptchaController { @Autowired private CaptchaService captchaService; @PostMapping("/captcha") public ResponseEntity<Map<String, String>> generateCaptcha() { BufferedImage image = captchaService.generateCaptcha(); ByteArrayOutputStream baos = new ByteArrayOutputStream(); try { ImageIO.write(image, "png", baos); } catch (IOException e) { e.printStackTrace(); } byte[] bytes = baos.toByteArray(); String base64 = Base64.getEncoder().encodeToString(bytes); Map<String, String> response = new HashMap<>(); response.put("captcha", base64); return ResponseEntity.ok(response); } } ``` 在前端,可以使用以下代码Base64编码字符串解码并将其显示在图像元素中: ```javascript fetch('/captcha', { method: 'POST' }) .then(response => response.json()) .then(data => { const captchaImg = document.createElement('img'); captchaImg.src = 'data:image/png;base64,' + data.captcha; document.body.appendChild(captchaImg); }); ``` 在这个示例中,我们从后端获取Base64编码验证码,并将其设置为图像元素的源。由于图像元素需要一个URL作为源,我们需要使用"data" URL格式,并在Base64编码字符串之前添加"data:image/png;base64,"前缀。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值