- 浏览: 38105 次
- 性别:
文章分类
- 全部博客 (57)
- Java 面试 (1)
- html5 (12)
- FQA (1)
- 前端 (18)
- java (1)
- css (7)
- 前端,js,jquery (8)
- html (2)
- jquery,html5,html (2)
- css3 (1)
- 仅包括这些 (0)
- 前端,js,jquery 有效的实时监听input (1)
- esayui (2)
- echarts3 (0)
- from (1)
- linxu (1)
- linxu apr (1)
- jsonp (1)
- 冒泡事件 (1)
- IOS click延迟300秒,ios长按点击事件会有copy的选项 (1)
- js (1)
- vue (1)
- webpack3 (1)
- sass (1)
- node (1)
最新评论
这是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;
}
如若使用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;
}
发表评论
-
vue 倒计时
2019-07-17 17:16 0time: 59, timer: nu ... -
input 特殊处理禁止输入特殊符号或者限制输入中文
2018-06-07 14:46 0<input class="js_input ... -
调用百度的搜索引擎
2017-09-28 11:26 0<!DOCTYPE html> <html& ... -
移动端碰到的坑
2017-09-22 15:34 690不废话 直接上代码: *{ -webkit-touch- ... -
移动端网页布局注意事项及解决
2017-08-01 17:10 11721.winphone系统a、input标签被点击时产生的半透明 ... -
全选反选
2017-05-09 18:34 480<div class="js_mobile&q ... -
js 规格多选,选中显示和还可以选择的数量 多维度选择
2017-03-17 16:09 1076<body> <section class= ... -
发送验证码
2017-03-15 15:54 0<input type="button&quo ... -
common css公共
2020-05-06 11:35 354/*遮罩层*/ .shadow{ position: fixe ... -
下拉列表功能获取数据添加到select表中
2017-03-14 15:41 780<!DOCTYPE html > <html ... -
图片轮播
2017-03-09 15:56 0<!DOCTYPE html> <html ... -
功能:H5可根据输入的匹配相对应的文字下拉框
2016-08-29 15:24 594<!DOCTYPE html> <html& ... -
功能 两级联动菜单
2016-08-26 15:13 536<!DOCTYPE html> <html& ... -
功能 交替显示
2016-08-24 16:09 591<!DOCTYPE html> <html& ... -
纯CSS+CSS3右上角倾斜四十五度封页角效果
2016-08-16 17:07 4542加广告与加封页脚的代码是差不多的! 以前封页脚都是图片现在 ... -
图形笑脸 增加动画
2016-07-21 15:23 581<!DOCTYPE html> <html& ... -
小用例
2016-07-20 17:24 370<!DOCTYPE html> <html& ... -
mui框架 上拉加载 下拉刷新
2016-07-15 15:38 723<!DOCTYPE html> <html& ... -
hcharts视图报表
2016-05-03 14:48 566function queryloginUser() { ... -
图形验证码
2015-11-05 18:12 460这是java代码! 如若使用tomcat容器启动项目则需要加上 ...
相关推荐
【beego框架图形验证码实现】是使用Go语言开发的一个高效且功能丰富的图形验证码库,它为Web应用提供了安全的验证码生成服务。这个库的核心目的是为了防止自动化程序(如机器人)进行非法操作,如批量注册、恶意登录...
在IT行业中,图形验证码是一种广泛应用于网络安全的重要技术,它的主要目的是防止自动化的恶意软件或机器人进行非法操作,如批量注册、频繁登录等。本项目"图形验证码成功之后实现用户登录功能.zip"着重于构建一个...
JavaScript验证码的简单实现,有简单的随机数字,也有较复杂的图形验证码, 这种图形验证码很高效简洁,使用爬虫是有较大难度的爬取网站信息的。 而且这种图形验证码的应用场景非常广,可用在登录注册等等需要上传...
在IT领域,图形验证码(CAPTCHA)是一种广泛用于防止恶意自动化程序(如机器人或爬虫)的工具。它要求用户输入图像中显示的一串字符或完成一个简单的逻辑问题,以此来验证用户是真实的人而非机器。这个压缩包文件...
在IT领域,尤其是在网络安全和网页开发中,图形验证码(Captcha)是一种常用的技术,用于防止自动化的机器人程序或恶意攻击者进行非法操作。本话题主要关注如何使用Java生成包含随机加减法问题的图形验证码。这种...
在IT行业中,图形验证码是一种广泛应用于网站以防止恶意自动化脚本(如机器人)进行操作的安全机制。Vue.js作为一款流行的前端框架,它允许开发者构建高效、可复用的组件。而将canvas技术与Vue.js结合,可以创建动态...
【图形验证码识别测试工具】是一种专门用于自动化处理图形验证码的技术工具。在互联网安全领域,图形验证码被广泛应用于网站登录、注册、评论等场景,目的是为了防止恶意机器人或爬虫自动执行任务,保护用户账户安全...
在默认的登录页面中,可能并未包含图形验证码的实现,因此我们需要自定义组件来实现这一功能。 1. 创建图形验证码表单控件`CaptchaInput.tsx`: 在这个文件中,我们将编写一个React组件,用于生成和验证图形验证码...
ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码代码ASP图形验证码...
在Android平台上,生成图形验证码(CAPTCHA)是提高应用程序安全性的关键步骤,特别是在用户登录或注册过程中。图形验证码的主要目的是防止自动化的机器人程序或者恶意攻击者进行非法操作,如批量注册、恶意登录等。...
本篇文章将详细解析基于JSP实现的图形验证码源码,帮助开发者理解和应用这种安全功能。 首先,我们需要了解JSP(JavaServer Pages)是Java的一种服务器端脚本语言,它允许开发者在HTML页面中嵌入Java代码,以动态...
### 图形验证码实现详解:基于JS与JSP的三步法 #### 一、引言 在当前互联网安全体系中,图形验证码作为一种简单而有效的防止自动化攻击的方式,被广泛应用于登录、注册等环节,以确保操作由真实的人类用户执行而非...
### Java代码中图形验证码的实现 #### 知识点概览 本文将深入解析一个Java图形验证码的实现案例。此案例包含了一个名为`RandCodeImage`的类,它继承自`HttpServlet`类,并实现了图形验证码的生成逻辑。通过本案例的...
vue+uniapp实现图形验证码功能-插件(附源码) 在登录系统时,除了密码登录,还需要提供验证码登录。 涉及验证码,为了安全,一般会加入图形验证码,然后再发短信验证码。 一般是前端请求,通过服务后台生成图形码流...
在IT领域,图形验证码(CAPTCHA)是一种广泛用于防止恶意自动化程序(如机器人或爬虫)的工具。它要求用户在提交表单之前输入显示在图像中的扭曲文本,以此来验证用户是人类而不是机器。本篇文章将深入探讨如何使用...
在ASP.NET中,生成图形验证码是一项常见的安全功能,用于防止自动化程序(如机器人)进行恶意操作,例如批量注册、频繁登录尝试等。图形验证码通常由一串随机字符组成,显示在一个图片上,用户需要在输入框中正确...
1. ASP图形验证码: - ASP验证码通常使用服务器端脚本语言来生成随机的字符串或图像,然后将其显示在客户端。这里包含的三种ASP验证码可能包括不同的算法和技术,用于生成不同类型的图形,如扭曲文字、数字混合、...
UniGUI图形验证码demo实例程序 Delphi 10.3源代码,UniGUI版本UniGUI 1.90.1503 浏览器 地址 http://IP地址:8077/ 电脑的防火墙 要 开通 8077端口。