前端图形验证码小结

概述: 四位的图形验证码,由阿拉伯数字及大小写字母组成

前端代码:

js文件:
$(function () {

    //验证码的点击刷新
    $("#imgCode").click(function () {
        this.src = basePath + "/loan/jcaptcha/captcha?time=" + Date.now();
    });

});
html文件
<div class="login-yzm">
		     <div id="showCaptcha" class="yzm-box" style="display:block;">
			 	<input id="captcha" type="text" class="yzm" placeholder="点击右侧图片可刷新"/>
			 	<img th:src="@{/loan/jcaptcha/captcha}" id="imgCode" style="cursor:pointer;border:0; display:inline;vertical-align:middle;"/>
		     </div>
		     <ul><li id="showId" style="color:red;font-size:12px;width:222px;margin-top:10px;margin-bottom:10px;line-height:18px;"></li></ul>
		     </div>

效果简述:进入登录页面的时候,会自动生成一个图形验证码(HTML代码实现).点击图形验证码,会进行刷新(JS代码实现,主要是加上了一个时间戳,让src访问的资源进行变化,可以再次访问后台加载静态资源).

后端:

 //图形验证码
    private static final int WIDTH = 120;
    /**
     * 图片高度: 50px
     */
    private static final int HEIGHT = 50;
    /**
     * 处理图片验证码方法
     *
     * @param request
     * @param response
     */
    @RequestMapping(value="/jcaptcha/captcha")
    public void handleCaptchaRequest(HttpServletRequest request, HttpServletResponse response) {

        //生成 4 位随机验证码
        String captcha = this.getRandomCode(4);
        //将生成的验证码放入Session作用域中,等待与前端输入的数据进行验证
        request.getSession().setAttribute("verificationCode",captcha);
        try {
            //创建字节数组输出流
            ByteArrayOutputStream jpegOutputStream = new ByteArrayOutputStream();
            //创建图片缓存对象,BufferedImage.TYPE_INT_RGB : 表示一个图像,该图像具有整数像素的 8 位 RGB 颜色
            BufferedImage bufferedImage = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
            //获取图片的画布
            Graphics graphics = bufferedImage.getGraphics();
            //设置画布背景色
            graphics.setColor(Color.GREEN);
            //设置画布填充区域
            graphics.fillRect(0, 0, WIDTH, HEIGHT);
            //边框区域
            graphics.drawRect(1, 1, WIDTH - 2, HEIGHT - 2);
            //设置字体颜色
            graphics.setColor(Color.BLACK);
            //设置字体样式
            graphics.setFont(new Font("微软雅黑", Font.ITALIC, 32));
            //填充数据
            graphics.drawString(captcha, 10, 38);
            //将生成的验证码存放到 session 中
            request.getSession().setAttribute(Constants.KAPTCHA_SESSION_KEY, captcha);
            ImageIO.write(bufferedImage, "jpeg", jpegOutputStream);
            byte[] captchaChallengeAsJpeg = jpegOutputStream.toByteArray();
            //将验证码输出到页面
            response.setHeader("Cache-Control", "no-store");
            response.setHeader("Pragma", "no-cache");
            response.setDateHeader("Expires", 0L);
            response.setContentType("image/jpeg");
            ServletOutputStream respOs = response.getOutputStream();
            respOs.write(captchaChallengeAsJpeg);
            respOs.flush();
            respOs.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * 生成 0-9 , a-z,A-Z 的随机字符串
     * @param count
     * @return
     */
    private String getRandomCode(int count) {
        String[] array =
                {"A","B","C","D","E","F","G","H","I","J","K","L","M","N",
                        "O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b",
                        "c","d","e","f","g","h","i","j","k","l","m","n","o","p",
                        "q","r","s","t","u","v","w","x","y","z","0","1","2","3",
                        "4","5","6","7","8","9"};
        StringBuilder result = new StringBuilder();
        for (int i = 0; i < count; i++) {
            //生成一个下标 0-61 之间一个整数
            Random random = new Random();
            int index = random.nextInt(62);
            //从 array 数组中获取该下标字符放到 result 中
            result.append(array[index]);
        }
        return result.toString();
    }
@RequestMapping("/checkLogin.do")
    @ResponseBody
    public BaseResult checkLogin(String phone,String md5Password,String verificationCode,HttpSession session){
		//从Session中获取验证码和参数接收到的验证码进行比对
		//验证码不通过直接返回错误信息:"验证码错误"
		//验证码通过,再验证账号密码,通过则登录,不通过则返回"账号或密码错误"
        String verificationCodeSession = (String) session.getAttribute("verificationCode");
        if(verificationCode.equalsIgnoreCase(verificationCodeSession)){
            User user = userService.checkLogin(phone,md5Password);
            Double availableMoney = null;
            if(user != null){
                availableMoney = userService.getUserAvaliableMoneyByUid(user.getId());
                session.setAttribute(Constant.LOGIN_USER,user);
                session.setAttribute("availableMoney",availableMoney);
                return BaseResult.success();
            }
            return BaseResult.error("账号或密码错误");
        }
        return BaseResult.error("验证码错误");
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值