天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

使用JQuery和s3captche實現(xiàn)一個水果名字的驗證

先看個圖片:

1.介紹:

 s3captcha是一個非常有用的可以讓圖片順序顯示的一個JQuery插件。它是通過php實現(xiàn)的。但是我發(fā)現(xiàn)很容易把它轉(zhuǎn)化為ASP.NET和C#的代碼。 我做了一個config的配置文件可以在文件中配置圖片的源和名字等。

 然后介紹一下s3captcha的實現(xiàn)原理,

上圖所示是它的實現(xiàn)模式。
1.它隨即生成圖片的index;
2.把一系列隨機數(shù)據(jù)賦給圖片的index.
3.可以從圖片列表中選擇一個隨機的index.
4.讓圖片隨機的顯示為一個radio box.
它使用JQuery實現(xiàn)的radio box到圖片List的轉(zhuǎn)換。
2.代碼:
首先是把圖片的index數(shù)組順序打亂,重新輸出:
復(fù)制代碼 代碼如下:
public static List<int> shuffle(List<int> input)
{
List<int> output = new List<int>();
Random rnd = new Random();

int FIndex;
while (input.Count > 0)
{
FIndex = rnd.Next(0, input.Count);
output.Add(input[FIndex]);
input.RemoveAt(FIndex);
}

input.Clear();
input = null;
rnd = null;

return output;
}

使用xml來作為s3captche的配置文件:
復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8" ?>
<s3capcha>
<icons>
<name>apple,cherry,lemon,pear,strawberry</name>
<title>Apple,Cherry,Lemon,Pear,Strawberry</title>
<width>33</width>
<height>33</height>
<ext>jpg</ext>
<folder>fruit</folder>
</icons>
<message>Verify that you are a human not robot, please choose {0}</message>
</s3capcha>

GetHtmlCode的代碼:
復(fù)制代碼 代碼如下:
public static string GetHtmlCodes(string PathTo, out int SessionValue)
{
bool HasValue = false;
if (string.IsNullOrEmpty(Message))
HasValue = LoadConfig();
else
HasValue = true;

if (HasValue)
{
Random Rnd = new Random();
int RandomIndex = Rnd.Next(0,IconNames.Length);

List<int> values = new List<int>();
for(int i = 0; i < IconNames.Length;i++)
values.Add(i);
values = shuffle(values);

string WriteThis = "<div class=/"s3capcha/"><p>" +
string.Format(Message, "<strong>" + IconTitles[values[RandomIndex]] +
"</strong>") + "</p>";

int[] RandomValues = new int[IconNames.Length];
for (int i = 0; i < IconNames.Length; i++)
{
RandomValues[i] = Rnd.Next();
WriteThis += string.Format(RowTemplate,
IconTitles[values[i]], RandomValues[i],
PathTo + "/icons/" + Folder + "/" +
IconNames[values[i]] + "." + Extention,
Width, Height);
}
WriteThis += "<div style="/" style="/""clear:left/"></div></div>";
SessionValue = RandomValues[RandomIndex];
return WriteThis;
}
else
{
SessionValue = -1;
return "Invalid data, config file not found";
}
}

3.使用ajax方法來實現(xiàn)驗證信息的判斷彈出框:
s3capcha.ashx 用來實現(xiàn)當向服務(wù)器請求時,返回html:
復(fù)制代碼 代碼如下:
public void ProcessRequest (HttpContext context) {
context.Response.ContentType = "text/html";

int USession;
context.Response.Write(s3capcha.GetHtmlCodes("../../s3capcha", out USession));
context.Session[s3capcha.s3name] = USession;

context.Response.End();
}

verify.ashx文件?來實現(xiàn)驗證功能:
復(fù)制代碼 代碼如下:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";

if (s3capcha.Verify(context.Session[s3capcha.s3name],
context.Request.Form[s3capcha.s3name]))
context.Response.Write("Success");
else
context.Response.Write("Fail");

context.Response.End();
}

JQuery實現(xiàn)的ajax代碼:
復(fù)制代碼 代碼如下:
//Javascript codes
$(document).ready(function() {
getCapcha();
$("form").bind('submit', function() {
$.ajax({
url: 'verify.ashx',
type: 'POST',
data: { 's3capcha': $("input[name=s3capcha]:checked").val() },
cache: false,
success: function(data) {
alert(data);
getCapcha();
}
});
return false;
});
});

JavaScript技術(shù)使用JQuery和s3captche實現(xiàn)一個水果名字的驗證,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产蜜臀AV在线一区视频 | 灌饱娇嫩H将军公主最新章节 | 中国成人在线视频 | 国产午夜三区视频在线 | 肉多的小说腐小说 | 国产亚洲人成在线视频 | 99久久国产露脸精品国产麻豆 | 欧美精品专区免费观看 | 亚洲永久精品ww47 | 国产精品99久久久精品无码 | J午夜精品久久久久久毛片 jzz大全18 | 超碰人人草在线视频 | 久99视频精品免费观看福利 | 91欧洲在线视精品在亚洲 | 国产精品乱码一区二区三 | 亚洲444777KKK在线观看 | 亚洲成 人a影院青久在线观看 | 久久视频精品3线视频在线观看 | 中文字幕天堂久久精品 | 性插图动态图无遮挡 | 国产色精品VR一区二区 | 精品国产乱码久久久久久乱码 | 夜色视频社区 | 小sao货水好多真紧h的视频 | 天天久久狠狠色综合 | 嗯呐啊唔高H兽交 | 日本欧美高清一区二区视频 | 大香交伊人 | 国产午夜人做人免费视频中文 | 2018高清国产一区二区三区 | 午夜免费国产体验区免费的 | 毛片在线全部免费观看 | 精品久久久久亚洲 | 午夜一区欧美二区高清三区 | 给我免费播放片bd国语 | 乱码国产丰满人妻WWW | 韩日美无码精品无码 | 伊人久久大香线蕉综合电影 | 一区二区三区国产亚洲网站 | 亚洲狠狠97婷婷综合久久久久 | 乌克兰10一12x video |