最近公司做项目开发中用到了验证码实现功能,将实现代码分享出来,

  前段页面实现代码:

  为了表达清晰,样式部分代码去掉了,大家根据自己的需求,自己添加样式。

  页面JS代码:触发变动验证码改变的JS

  后台 Controller处理:

  package com.njcc.pay.controller.login;

  import java.awt.Color;

  import java.awt.Font;

  import java.awt.Graphics;

  import java.awt.p_w_picpath.BufferedImage;

  import java.io.IOException;

  import java.io.OutputStream;

  import java.util.Random;

  import javax.p_w_picpathio.ImageIO;

  import javax.servlet.http.HttpServletRequest;

  import javax.servlet.http.HttpServletResponse;

  import org.apache.commons.lang3.math.NumberUtils;

  import org.apache.commons.logging.Log;

  import org.apache.commons.logging.LogFactory;

  import org.springframework.stereotype.Controller;

  import org.springframework.web.bind.annotation.RequestMapping;

  import com.alibaba.dubbo.common.utils.StringUtils;

  /**

  * 验证马 Controller

  *

  * @author Administrator

  *

  */

  @Controller

  public class ValidateCodeController {

  @SuppressWarnings("unused")

  private static final Log LOG = LogFactory.getLog(ValidateCodeController.class);

  public static final String VALIDATE_CODE = "validateCode";

  private int w = 70;

  private int h = 23;

  /**

  * @throws Exception

  * 函数功能说明 : 进入后台登陆页面.

  *

  * @参数: @return

  * @return String

  * @throws

  */

  @RequestMapping(value = "/validateCode")

  public void validateCode(HttpServletRequest request,

  HttpServletResponse response) throws Exception {

  createImage(request,response);

  }

  private void createImage(HttpServletRequest request,HttpServletResponse response) throws IOException {

  response.setHeader("Pragma", "no-cache");

  response.setHeader("Cache-Control", "no-cache");

  response.setDateHeader("Expires", 0);

  response.setContentType("p_w_picpath/jpeg");

  String width = request.getParameter("width");

  String height = request.getParameter("height");

  if (StringUtils.isNumeric(width) && StringUtils.isNumeric(height)) {

  w = NumberUtils.toInt(width);

  h = NumberUtils.toInt(height);

  }

  BufferedImage p_w_picpath = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB);

  Graphics g = p_w_picpath.getGraphics();

  /*

  * 生成背景

  */

  createBackground(g);

  /*

  * 生成字符

  */

  String s = createCharacter(g);

  request.getSession().setAttribute(VALIDATE_CODE, s);

  g.dispose();

  OutputStream out = response.getOutputStream();

  ImageIO.write(p_w_picpath, "JPEG", out);

  out.close();

  }

  /**

  * 生成颜色

  * @param fc

  * @param bc

  * @return

  */

  private Color getRandColor(int fc,int bc) {

  int f = fc;

  int b = bc;

  Random random=new Random();

  if(f>255) {

  f=255;

  }

  if(b>255) {

  b=255;

  }郑州妇科医院http://jbk.39.net/yiyuanzaixian/sysdfkyy/

  return new Color(f+random.nextInt(b-f),f+random.nextInt(b-f),f+random.nextInt(b-f));

  }

  /**

  * 生成背景

  * @param g

  */

  private void createBackground(Graphics g) {

  // 填充背景

  g.setColor(getRandColor(220,250));

  g.fillRect(0, 0, w, h);

  // 加入干扰线条

  for (int i = 0; i < 8; i++) {

  g.setColor(getRandColor(40,150));

  Random random = new Random();

  int x = random.nextInt(w);

  int y = random.nextInt(h);

  int x1 = random.nextInt(w);

  int y1 = random.nextInt(h);

  g.drawLine(x, y, x1, y1);

  }

  }

  /**

  * 生成字符

  * @param g

  * @return

  */

  private String createCharacter(Graphics g) {

  char[] codeSeq = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J',

  'K', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',

  'X', 'Y', 'Z', '2', '3', '4', '5', '6', '7', '8', '9' };

  String[] fontTypes = {"Arial","Arial Black","AvantGarde Bk BT","Calibri"};

  Random random = new Random();

  StringBuilder s = new StringBuilder();

  for (int i = 0; i < 4; i++) {

  String r = String.valueOf(codeSeq[random.nextInt(codeSeq.length)]);//random.nextInt(10));

  g.setColor(new Color(50 + random.nextInt(100), 50 + random.nextInt(100), 50 + random.nextInt(100)));

  g.setFont(new Font(fontTypes[random.nextInt(fontTypes.length)],Font.BOLD,26));

  g.drawString(r, 15 * i + 5, 19 + random.nextInt(8));

  // g.drawString(r, i*w/4, h-5);

  s.append(r);

  }

  return s.toString();

  }

  }

Java实现Web页面前数字字母验证码实现的更多相关文章

  1. Servlet实现数字字母验证码图片(二)

    Servlet实现数字字母验证码图片(二): 生成验证码图片主要用到了一个BufferedImage类,如下:

  2. Java selenium web页面的滚动条操作

    摘录自:http://blog.csdn.net/iceryan/article/details/8162703 //移动到元素element对象的"顶端"与当前窗口的" ...

  3. java图形验证码生成工具类及web页面校验验证码

    最近做验证码,参考网上案例,发现有不少问题,特意进行了修改和完善. 验证码生成器: import javax.imageio.ImageIO; import java.awt.*; import ja ...

  4. web页面 验证码 生成

    web页面 验证码 生成 kaptcha 是一个非常实用的验证码生成工具.有了它,你可以生成各种样式的验证码,因为它是可配置的.kaptcha工作的原理是调用 com.google.code.kapt ...

  5. JAVA整合kaptcha生成验证码 (字母验证码和算术验证码)

    引入maven <!--图片验证码--> <dependency> <groupId>com.github.penggle</groupId> < ...

  6. paip.powerdesign cdm pdm文件 代码生成器 java web 页面 实现

    paip.powerdesign cdm pdm文件 代码生成器 java web 页面 实现 准备从pd cdm生成java web 页面...但是,ms无直接地生成软件.... 只好自己解析cdm ...

  7. Java用webSocket实现tomcat的日志实时输出到web页面

    原文:http://blog.csdn.net/smile326/article/details/52218264 1.场景需求 后台攻城狮和前端攻城狮一起开发时,经常受到前端攻城狮的骚扰,动不动就来 ...

  8. Java随机生成定长纯数字或数字字母混合数

    (转)Java随机生成定长纯数字或数字字母混合数 运行效果图: 具体实现代码

  9. java验证,”支持6-20个字母、数字、下划线或减号,以字母开头“这个的正则表达式怎么写?

    转自:https://yq.aliyun.com/wenzhang/show_96854 问题描述 java验证,”支持6-20个字母.数字.下划线或减号,以字母开头“这个的正则表达式怎么写? 验证” ...

随机推荐

  1. JSON --- 一种轻量级的数据交换格式

    目录 1. 语法 2. 解析与序列化 JSON.stringify( jsData[, filter, indent] ) JSON.parse( jsonData[, reduction]) JSO ...

  2. vue-router 基本知识点

    vue-router就是将组件映射到路由,然后告诉vue-router在哪里渲染它们. 默认路由出口 <router-view></router-view> 使用router- ...

  3. backface-visibility

    浏览器支持 只有 Internet Explorer 10+ 和 Firefox 支持 backface-visibility 属性. Opera 15+.Safari 和 Chrome 支持替代的 ...

  4. 更改ssh远程登录端口.sh

    #!/bin/bash #liu_dong sed -i "s/\#Port 22/Port 31961/g" /etc/ssh/sshd_config sed -i " ...

  5. Sublime Text 常用的16 个 Sublime Text 快捷键

    在我做了一次包含一些现场编码的演示后,一些观众问我是如何操作这么快.当然这里没有唯一的答案,答案是一堆简单的快捷键和大量的实践的组合.为了回应那些询问,我觉得有必要看看我每天想都不用想且使用的快捷键. ...

  6. 转:深度学习与自然语言处理之五:从RNN到LSTM

    原文地址:http://blog.csdn.net/malefactor/article/details/50436735/ 大纲如下: 1.RNN 2.LSTM 3.GRN 4.Attention ...

  7. C++实现利用(前序和中序生成二叉树)以及(二叉树的镜像)

    #include<iostream> #include<string.h> #include<stack> using namespace std; typedef ...

  8. ORA-01152: 文件 1 没有从过旧的备份中还原

    转自:http://blog.itpub.net/8520577/viewspace-1255794/ 做了一个全备 RMAN> show all; 使用目标数据库控制文件替代恢复目录db_un ...

  9. Codechef SEPT17

    Codechef SEPT17 比赛链接:https://www.codechef.com/SEPT17 CHEFSUM code给定数组 a[1..n] ,求最小的下标 i ,使得 prefixsu ...

  10. django上课笔记2-视图CBV-ORM补充-Django的自带分页-Django的自定义分页

    一.视图CBV 1.urls url(r'^login.html$', views.Login.as_view()), 2.views from django.views import View cl ...