[验证码实现] Captcha 验证码类,一个很个性的验证码类 (转载)
/// <summary>
/// 类说明:条码生成类
/// 编 码 人:苏飞
/// 联系方式:361983679
/// 更新网站:[url=http://www.sufeinet.com/thread-655-1-1.html]http://www.sufeinet.com/thread-655-1-1.html[/url]
/// </summary>
using System;
using System.Drawing; public static class Captcha
{
private static double[] addVector(double[] a, double[] b)
{
return new double[] { a[] + b[], a[] + b[], a[] + b[] };
} private static double[] scalarProduct(double[] vector, double scalar)
{
return new double[] { vector[] * scalar, vector[] * scalar, vector[] * scalar };
} private static double dotProduct(double[] a, double[] b)
{
return a[] * b[] + a[] * b[] + a[] * b[];
} private static double norm(double[] vector)
{
return Math.Sqrt(dotProduct(vector, vector));
} private static double[] normalize(double[] vector)
{
return scalarProduct(vector, 1.0 / norm(vector));
} private static double[] crossProduct(double[] a, double[] b)
{
return new double[]
{
(a[] * b[] - a[] * b[]),
(a[] * b[] - a[] * b[]),
(a[] * b[] - a[] * b[])
};
} private static double[] vectorProductIndexed(double[] v, double[] m, int i)
{
return new double[]
{
v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[],
v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[],
v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[]+ v[i + ] * m[],
v[i + ] * m[] + v[i + ] * m[] + v[i + ] * m[]+ v[i + ] * m[]
};
} private static double[] vectorProduct(double[] v, double[] m)
{
return vectorProductIndexed(v, m, );
} private static double[] matrixProduct(double[] a, double[] b)
{
double[] o1 = vectorProductIndexed(a, b, );
double[] o2 = vectorProductIndexed(a, b, );
double[] o3 = vectorProductIndexed(a, b, );
double[] o4 = vectorProductIndexed(a, b, ); return new double[]
{
o1[], o1[], o1[], o1[],
o2[], o2[], o2[], o2[],
o3[], o3[], o3[], o3[],
o4[], o4[], o4[], o4[]
};
} private static double[] cameraTransform(double[] C, double[] A)
{
double[] w = normalize(addVector(C, scalarProduct(A, -)));
double[] y = new double[] { , , };
double[] u = normalize(crossProduct(y, w));
double[] v = crossProduct(w, u);
double[] t = scalarProduct(C, -); return new double[]
{
u[], v[], w[], ,
u[], v[], w[], ,
u[], v[], w[], ,
dotProduct(u, t), dotProduct(v, t), dotProduct(w, t),
};
} private static double[] viewingTransform(double fov, double n, double f)
{
fov *= (Math.PI / );
double cot = 1.0 / Math.Tan(fov / );
return new double[] { cot, , , , , cot, , , , , (f + n) / (f - n), -, , , * f * n / (f - n), };
} public static Image Generate(string captchaText)
{
int fontsize = ;
Font font = new Font("Arial", fontsize); SizeF sizeF;
using (Graphics g = Graphics.FromImage(new Bitmap(, )))
{
sizeF = g.MeasureString(captchaText, font, , StringFormat.GenericDefault);
} int image2d_x = (int)sizeF.Width;
int image2d_y = (int)(fontsize * 1.3); Bitmap image2d = new Bitmap(image2d_x, image2d_y);
Color black = Color.Black;
Color white = Color.White; using (Graphics g = Graphics.FromImage(image2d))
{
g.Clear(black);
g.DrawString(captchaText, font, Brushes.White, , );
} Random rnd = new Random();
double[] T = cameraTransform(new double[] { rnd.Next(-, ), -, rnd.Next(, ) }, new double[] { , , });
T = matrixProduct(T, viewingTransform(, , )); double[][] coord = new double[image2d_x * image2d_y][]; int count = ;
for (int y = ; y < image2d_y; y += )
{
for (int x = ; x < image2d_x; x++)
{
int xc = x - image2d_x / ;
int zc = y - image2d_y / ;
double yc = -(double)(image2d.GetPixel(x, y).ToArgb() & 0xff) / * ;
double[] xyz = new double[] { xc, yc, zc, };
xyz = vectorProduct(xyz, T);
coord[count] = xyz;
count++;
}
} int image3d_x = ;
int image3d_y = image3d_x * / ;
Bitmap image3d = new Bitmap(image3d_x, image3d_y);
Color fgcolor = Color.White;
Color bgcolor = Color.Black;
using (Graphics g = Graphics.FromImage(image3d))
{
g.Clear(bgcolor);
count = ;
double scale = 1.75 - (double)image2d_x / ;
for (int y = ; y < image2d_y; y += )
{
for (int x = ; x < image2d_x; x++)
{
if (x > )
{
double x0 = coord[count - ][] * scale + image3d_x / ;
double y0 = coord[count - ][] * scale + image3d_y / ;
double x1 = coord[count][] * scale + image3d_x / ;
double y1 = coord[count][] * scale + image3d_y / ;
g.DrawLine(new Pen(fgcolor), (float)x0, (float)y0, (float)x1, (float)y1);
}
count++;
}
}
}
return image3d;
}
}
[验证码实现] Captcha 验证码类,一个很个性的验证码类 (转载)的更多相关文章
- Confluence 6 配置验证码(Captcha)来防止垃圾
如果你的 Confluence 站点是对公众开放的(允许匿名用户使用,添加评论,创建页面等),你可能会发现你的站点会被自动创建很多垃圾页面,评论或者其他垃圾内容. 你可以配置让 Confluence ...
- 一个漂亮的php验证码类
一个漂亮的php验证码类(分享) 作者: 字体:[增加 减小] 类型:转载 下面小编就为大家分享一个漂亮的php验证码类.需要的朋友可以过来参考下 直接上代码: 复制代码 代码如下: //验证 ...
- Python&selenium&tesseract自动化测试随机码、验证码(Captcha)的OCR识别解决方案参考
在自动化测试或者安全渗透测试中,Captcha验证码的问题经常困扰我们,还好现在OCR和AI逐渐发展起来,在这块解决上越来越支撑到位. 我推荐的几种方式,一种是对于简单的验证码,用开源的一些OCR图片 ...
- DVWA-全等级验证码Insecure CAPTCHA
DVWA简介 DVWA(Damn Vulnerable Web Application)是一个用来进行安全脆弱性鉴定的PHP/MySQL Web应用,旨在为安全专业人员测试自己的专业技能和工具提供合法 ...
- 用Java制作一个简单的图片验证码
//Java实现简单验证码功能 package project; import java.awt.Color; import java.awt.Font;import java.awt.Graphic ...
- PHP入门培训教程 一个漂亮的PHP验证码
如何写一个漂亮的PHP验证码?兄弟连PHP培训 小编分享一段代码给大家: <?php class Imagecode{ private $width ; private $height; pri ...
- 接口 ThreadMXBean 一个很好用的线程管理接口类 可以参考 jdk 帮助文档
概述 软件包 类 使用 树 已过时 索引 帮助 JavaTM Platform Standard Ed. 6 上一个类 下一个类 框架 无框架 所有类 摘要: 嵌套 ...
- Makefile经典教程(一个很棒很清晰的讲解)【转】
转自:https://blog.csdn.net/seven_amber/article/details/70216216 该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神 ...
- 【Android】java生成炫酷验证码,不区分大小写。登陆,发送手机验证码,防止注册机,android开发
作者:程序员小冰,CSDN博客:http://blog.csdn.net/qq_21376985 QQ986945193 微博:http://weibo.com/mcxiaobing 首先给大家看一下 ...
随机推荐
- WebView 和Animation冲突
当有WebView时,可能会出现 动画没有执行过程. 解决方法: child.setLayerType(View.LAYER_TYPE_HARDWARE, null); child.setAnimat ...
- Flash正则例子
var jack:String = "zhuhai"; var arr:Array = ["23", "4", "67" ...
- poj magic number
Problem H Time Limit : 4000/2000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Sub ...
- Oracle体系结构图
1 oracle数据库主要有数据文件database和数据库实例instance组成.用户通过用户进程链接到server process.在数据库启动的时候,需要依赖于参数文件parameter fi ...
- Android学习笔记(十一)BroadcastReceiver动态注册、注销示例
在上一篇博文中简单介绍了一下BroadcastReceiver的相关知识点,本篇举一个在代码中动态的注册.注销BroadcastReceiver的栗子. 1.首先创建一个MyReceiver并继承Br ...
- leecode 回文字符串加强版
Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ...
- ReadingNotes@02-12-2013
ReadingNotes@02-12-2013 */--> pre { background-color: #2f4f4f;line-height: 1.6; FONT: 10.5pt Cons ...
- Test2014-3-1 魅力值比较
魅力值比较 [问题描述] 大学生恋爱的问题造成了数量众多的异地恋,有许多J大的女生早早被Q大男生追走,这导致了J大男生的强烈不满.就在吐血高调地向一位J大美女展开攻势的之后,J大男生终于爆发了. 为了 ...
- Linux常用命令及vim的使用、vim常用插件(推荐)
看了3篇文章,很好 vim中的区域拷贝 剪切,粘贴: 正常模式,移动光标到剪切的区域开始处,按v,进入可视模式,然后选择区域.按x键,剪切.到指定位置按p粘贴. 撤销按u 恢复按ctrl-r 简明 ...
- hdoj 1698 Just a Hook【线段树区间修改】
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...