`

图形验证码

阅读更多
这是java代码!
如若使用tomcat容器启动项目则需要加上这句代码,java的图片处理包需要图形环境,否则会报这个错server(X11 window server using ':0.0' )。而通过java -Djava.awt.headless=true 这个参数的指定就可以避免java 2d去找图形环境
System.setProperty("java.awt.headless", "true");
@RequestMapping("/getImage")
public String getImage(){
return "user/code";
}

@RequestMapping("/checkCode")
public void checkImage(HttpServletRequest request, HttpServletResponse response, Model model) throws Exception{
Map<String,Object> returnMap = new HashMap<String,Object>();
if(smsDubboService.isTest()){
returnMap.put("result", "1");
returnMap.put("msg", "成功");
SystemUtil.mapToJson(returnMap,response);
return;
}

String imgCode = (String) request.getParameter("imgCode");
String sessionCode = (String) super.getSession().getAttribute("code");

log.info("【图片验证码验证》输入值:】" + imgCode +",Session里存储的值:" + sessionCode);

if(StringUtils.isBlank(imgCode) || StringUtils.isBlank(sessionCode)){
returnMap.put("result", "0");
returnMap.put("msg", "验证码错误");
SystemUtil.mapToJson(returnMap,response);
return;
}

imgCode = imgCode.toLowerCase();

if(imgCode.equals(sessionCode.toLowerCase())){
returnMap.put("result", "1");
returnMap.put("msg", "成功");
SystemUtil.mapToJson(returnMap,response);
return;
}else{
returnMap.put("result", "0");
returnMap.put("msg", "验证码错误");
SystemUtil.mapToJson(returnMap,response);
return;
}

}
codejsp代码;
<%@ page contentType="image/jpeg" import="java.awt.*,java.util.*,java.awt.image.*,javax.imageio.*" pageEncoding="UTF-8" %>
<%!
Color getRandColor(int fc,int bc){//给定范围获得随机颜色
  Random random = new Random();
  if(fc>255) fc=255;
  if(bc>255) bc=255;
  int r=fc+random.nextInt(bc-fc);
  int g=fc+random.nextInt(bc-fc);
  int b=fc+random.nextInt(bc-fc);
  return new Color(r,g,b);
  }
%>
<%
//设置页面不缓存
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);

// 在内存中创建图象
int width=104, height=34;
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

// 获取图形上下文
Graphics g = image.getGraphics();

//生成随机类
Random random = new Random();

// 设定背景色
g.setColor(new Color(241,244,245));
g.drawRect(0, 0, width, height);
g.setColor(new Color(241,244,245));
g.fillRect(0, 0, width, height);
//设定字体


// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到


// 取随机产生的认证码(4位数字)

g.setFont(new Font("微软雅黑",Font.BOLD,20));
String codeList = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890";

StringBuffer sRand= new StringBuffer("");


for (int i=0;i<4;i++){
  int a=random.nextInt(codeList.length()-1);
  String rand=codeList.substring(a,a+1);
  sRand.append(rand);
  // 将认证码显示到图象中
  g.setColor(new Color(80,201,64));//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
  //g.translate(random.nextInt(3), random.nextInt(3));
  g.drawString(rand,23*i+6,26);
}

// 将认证码存入SESSION
session.removeAttribute("code");
session.setAttribute("code",sRand.toString());
// 图象生效
g.dispose();

// 输出图象到页面
ImageIO.write(image, "JPEG", response.getOutputStream());
out.clear();
out = pageContext.pushBody();


%>

js代码;
//点击获取新图片
function getImage(obj){
$(obj).attr("src","../verifyCode/getImage.do?" + Math.random());
}

//验证图片验证码吗
function checkCode(login_img_code){
var code_img = true;
$.ajax({
type: "post",
url: "../verifyCode/checkCode.do",
async : false,
data: {imgCode:login_img_code},
dataType: "text",
success: function(data){
var resultData = eval("(" + data + ")");
if(resultData.result == "0"){
code_img = false;
}else{
code_img = true;
}
},
error: function(){
}
});

return code_img;
}


分享到:
评论

相关推荐

    beego框架图形验证码实现

    【beego框架图形验证码实现】是使用Go语言开发的一个高效且功能丰富的图形验证码库,它为Web应用提供了安全的验证码生成服务。这个库的核心目的是为了防止自动化程序(如机器人)进行非法操作,如批量注册、恶意登录...

    图形验证码成功之后实现用户登录功能.zip

    在IT行业中,图形验证码是一种广泛应用于网络安全的重要技术,它的主要目的是防止自动化的恶意软件或机器人进行非法操作,如批量注册、频繁登录等。本项目"图形验证码成功之后实现用户登录功能.zip"着重于构建一个...

    JavaScript图形验证码的实现

    JavaScript验证码的简单实现,有简单的随机数字,也有较复杂的图形验证码, 这种图形验证码很高效简洁,使用爬虫是有较大难度的爬取网站信息的。 而且这种图形验证码的应用场景非常广,可用在登录注册等等需要上传...

    图形验证码生成合集

    在IT领域,图形验证码(CAPTCHA)是一种广泛用于防止恶意自动化程序(如机器人或爬虫)的工具。它要求用户输入图像中显示的一串字符或完成一个简单的逻辑问题,以此来验证用户是真实的人而非机器。这个压缩包文件...

    vue插件——使用canvas生成图形验证码

    在IT行业中,图形验证码是一种广泛应用于网站以防止恶意自动化脚本(如机器人)进行操作的安全机制。Vue.js作为一款流行的前端框架,它允许开发者构建高效、可复用的组件。而将canvas技术与Vue.js结合,可以创建动态...

    图形验证码识别测试工具

    【图形验证码识别测试工具】是一种专门用于自动化处理图形验证码的技术工具。在互联网安全领域,图形验证码被广泛应用于网站登录、注册、评论等场景,目的是为了防止恶意机器人或爬虫自动执行任务,保护用户账户安全...

    ASP图形验证码代码ASP图形验证码代码

    ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码

    ASP图形验证码代码

    ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码...

    java生成随机加减法的图形验证码

    在IT领域,尤其是在网络安全和网页开发中,图形验证码(Captcha)是一种常用的技术,用于防止自动化的机器人程序或恶意攻击者进行非法操作。本话题主要关注如何使用Java生成包含随机加减法问题的图形验证码。这种...

    jsp图形验证码源码

    本篇文章将详细解析基于JSP实现的图形验证码源码,帮助开发者理解和应用这种安全功能。 首先,我们需要了解JSP(JavaServer Pages)是Java的一种服务器端脚本语言,它允许开发者在HTML页面中嵌入Java代码,以动态...

    js图形验证码,只要简单的复制粘贴 3步

    ### 图形验证码实现详解:基于JS与JSP的三步法 #### 一、引言 在当前互联网安全体系中,图形验证码作为一种简单而有效的防止自动化攻击的方式,被广泛应用于登录、注册等环节,以确保操作由真实的人类用户执行而非...

    java代码中图形验证码的源代码

    ### Java代码中图形验证码的实现 #### 知识点概览 本文将深入解析一个Java图形验证码的实现案例。此案例包含了一个名为`RandCodeImage`的类,它继承自`HttpServlet`类,并实现了图形验证码的生成逻辑。通过本案例的...

    vue+uniapp实现图形验证码功能-插件(附源码)

    vue+uniapp实现图形验证码功能-插件(附源码) 在登录系统时,除了密码登录,还需要提供验证码登录。 涉及验证码,为了安全,一般会加入图形验证码,然后再发短信验证码。 一般是前端请求,通过服务后台生成图形码流...

    【JavaScript源代码】在Ant Design Pro登录功能中集成图形验证码组件的方法步骤.docx

    在默认的登录页面中,可能并未包含图形验证码的实现,因此我们需要自定义组件来实现这一功能。 1. 创建图形验证码表单控件`CaptchaInput.tsx`: 在这个文件中,我们将编写一个React组件,用于生成和验证图形验证码...

    图形验证码(servlet实现)

    在IT领域,图形验证码(CAPTCHA)是一种广泛用于防止恶意自动化程序(如机器人或爬虫)的工具。它要求用户在提交表单之前输入显示在图像中的扭曲文本,以此来验证用户是人类而不是机器。本篇文章将深入探讨如何使用...

    asp.net生成图形验证码

    在ASP.NET中,生成图形验证码是一项常见的安全功能,用于防止自动化程序(如机器人)进行恶意操作,例如批量注册、频繁登录尝试等。图形验证码通常由一串随机字符组成,显示在一个图片上,用户需要在输入框中正确...

    Android生成图形验证码

    在Android平台上,生成图形验证码(CAPTCHA)是提高应用程序安全性的关键步骤,特别是在用户登录或注册过程中。图形验证码的主要目的是防止自动化的机器人程序或者恶意攻击者进行非法操作,如批量注册、恶意登录等。...

    四种图形验证码(含汉字ASP三种,PHP一种)

    1. ASP图形验证码: - ASP验证码通常使用服务器端脚本语言来生成随机的字符串或图像,然后将其显示在客户端。这里包含的三种ASP验证码可能包括不同的算法和技术,用于生成不同类型的图形,如扭曲文字、数字混合、...

    ios--图形验证码

    在iOS开发中,图形验证码(Captcha)是一种重要的安全机制,用于防止自动化程序或机器人进行恶意操作,如防止批量注册、频繁登录等。本项目提供了一种自定义的本地实现方式,无需依赖外部库,方便集成到你的iOS应用...

Global site tag (gtag.js) - Google Analytics