随机生成图片验证码

springboot + jq 随机生成图片验证码 

效果如下

 

1.前端 html

<img id="random_pic" onclick="getVerify(this);" src="">

2.前端 js 

$(function(){
     //首次获取验证码
     $("#random_pic").attr("src","/util/getVerify.html?"+Math.random());
});

function getVerify(obj){
     //点击获取验证码
     obj.src = "/util/getVerify.html?"+Math.random();
}

3.后台 生成随机验证码图片

1)图片名是picName, 保存在session里, 供校验使用

2)图片本身是img, 写入输出流, 给前端显示 (图片保存在内存中)

package com.prj.utils;

import com.prj.commons.Constants;
import lombok.extern.slf4j.Slf4j;

import javax.imageio.ImageIO;
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;

/**
 * Created by Alwen
 * 2018/11/13 15:02
 */
@Slf4j
//生成随机验证码
public class RandomPic {

    private static Random random = new Random();
    private static int width = 120;
    private static int height = 50;
    private static String str = "abcdefghjkmnpqrstuvwxyz23456789";    //允许在图片内显示的字符

    private static int randomNum(int min, int max) {
        int num = 0;
        num = random.nextInt(max - min) + min;
        return num;
    }

    //设置颜色
    private static Color setColor(int min, int max) {
        int r = min + random.nextInt(max - min);
        int g = min + random.nextInt(max - min);
        int b = min + random.nextInt(max - min);
        return new Color(r, g, b);
    }

    public static void getPic(HttpServletRequest request,
                              HttpServletResponse response) throws IOException {
        //在内存中创建图片
        BufferedImage img = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        //在图片上画一个矩形当背景
        Graphics g = img.getGraphics();
        g.setColor(setColor(150, 230));
        g.fillRect(0, 0, width, height);

        //生成的字符串
        String picName = "";
        for (int i = 0; i < 4; i++) {
            g.setColor(setColor(30, 140));
            g.setFont(new Font("黑体", Font.PLAIN, 40));
            char c = str.charAt(randomNum(0, str.length()));
            g.drawString(String.valueOf(c), 10 + i * 30, randomNum(height - 30, height));
            picName += c;
        }

        //画随机线
        for (int i = 0; i < 25; i++) {
            g.setColor(setColor(50, 180));
            g.drawLine(randomNum(0, width), randomNum(0, height), randomNum(0, width), randomNum(0, height));
        }

        //把内存中创建的图像输出到文件中
//        File file = new File("C:/Users/AlwenZwei/Desktop/mk_file/vcode.png");
//        ImageIO.write(img, "png", file);

        //把图片创建在内存中
        ImageIO.write(img, "JPEG", response.getOutputStream());
        log.info("图片: " + picName);
        HttpSession session = request.getSession();
        session.setAttribute(Constants.RANDOM_PIC, picName);
    }
}

4.前端getVerify调用方法, 获取随机图片

@RequestMapping("/getVerify.html")
    public void getVerify(HttpServletRequest request, HttpServletResponse response) {
        //设置相应信息
        response.setContentType("image/jpeg");
        response.setHeader("Pragma", "No-cache");
        response.setHeader("Cache-Control", "no-cache");
        response.setDateHeader("Expire", 0);
        try {
            //输出图片
            RandomPic.getPic(request, response);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

至此, 图片已经输出到img标签, 图片的内容保存在session中, 通过ajax可以进行校验

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
随机生成6位图片验证码. /// <summary> /// PicHandler1 的摘要说明 /// </summary> public class PicHandler1 : IHttpHandler, IRequiresSessionState { private string mCheckNo = string.Empty; protected ImgBuilder _ImgBuilder = new ImgBuilder(); protected VryImgGen _ImgBuilderNew = new VryImgGen(); private string _text = string.Empty; private string _font = "宋体"; private int _fontSize = 8; private int _padding = 2; public void ProcessRequest(HttpContext context) { mCheckNo = DisCheckNo(); context.Session["CheckCode"] = mCheckNo; this._ImgBuilder.FontSize = this._fontSize; this._ImgBuilder.Padding = this._padding; if (!string.IsNullOrEmpty(this._font)) { this._ImgBuilder.Fonts = new string[] { this._font }; } this._ImgBuilderNew.ChaosWight = 40; this._ImgBuilderNew.FontSize = 25; this._ImgBuilderNew.Padding = 3; System.Drawing.Bitmap image = this._ImgBuilderNew.CreateImage(mCheckNo); System.IO.MemoryStream ms = new System.IO.MemoryStream(); image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); context.Response.ClearContent(); context.Response.ContentType = "image/Jpeg"; context.Response.BinaryWrite(ms.ToArray()); context.Session["CheckCode"] = mCheckNo.ToString(); //如果没有实现IRequiresSessionState,则这里会出错,也无法生成图片 context.Response.End(); } //验证码生成 protected string DisCheckNo() { string hash = HashCode.GetNext(); string CheckNo = string.Empty; Random rd = new Random(DateTime.Now.Millisecond); for (int i = 0; i < 6; i++) { CheckNo += hash.Substring(rd.Next(1, hash.Length - 1), 1); } CheckNo = CheckNo.Replace("0", rd.Next(1, 9).ToString()); CheckNo = CheckNo.Replace("o", rd.Next(1, 9).ToString());

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值