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

  前段页面实现代码:

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

  页面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. macbook pro 一些操作经验记录

    [一]启用root用户 (1)打开终端 (2)输入命令:sudo passwd root (3)给root设置密码 (4)然后再终端输入命令:su root 进行登陆 [二]解压eclipse压缩包, ...

  2. .NETFramework:Stream

    ylbtech-.NETFramework:Stream 1.返回顶部 1. #region 程序集 mscorlib, Version=4.0.0.0, Culture=neutral, Publi ...

  3. backface-visibility

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

  4. hdu5829 Rikka with Subset

    首先考虑本题的$O(n^2)$做法. $Part1$ 对原序列从大到小排序后,考虑每个数字对最终答案的贡献,有第x个数字对答案的贡献十分难以计算,所以考虑计算数字x是集合第K大的方案数,作为数字x对$ ...

  5. List集合与Array数组之间的互相转换

    1.数组转换成List集合 采用java中集合自带的asList()方法就可以完成转换了 String[] array = new String[] {"zhu", "w ...

  6. E20180422-hm

    tint n. 浅色; 色彩,色泽; 气息,迹象,痕迹 vt. 染色; 着色于…; 染(发) introduce vt. 介绍; 引进; 提出; 作为…的开头; variation  n. 变化,变动 ...

  7. 洛谷 - P2945 - 沙堡Sand Castle - 排序

    https://www.luogu.org/problemnew/show/P2945 好像猜一猜就觉得排序之后是最优的,懒得证明了.每个城墙向他最接近的城墙靠近,绝对是最优的.

  8. 洛谷 - P1987 - 摇钱树 - dp - 贪心

    https://www.luogu.org/problemnew/show/P1987 这道题,假如是n==k,也就是把所有的树都砍完,我就知道要贪心去做,因为树给的初始金币是固定的,每天掉金币,当然 ...

  9. 51nod 1574 排列转换(猜结论)

    分析 猜了一下结论,居然对了..........具体操作是:假设排列s是1,2,3,...,nk为排列p中最大的 没有放到正确位置的数,k的位置为posk的右边一定有一个数x<=pos(因为&l ...

  10. 51nod 1050【DP】

    思路: 就是先正常的dp一下求一个最大连续子串,然后特殊情况就是sum-最小连续子串.. 比一比谁大谁小就好了 #include <stdio.h> #include <string ...