分享
 
 
 

ASP.NET(c#)语音验证码制作(附源代码)

王朝学院·作者佚名  2009-11-28
窄屏简体版  字體: |||超大  

最近发现语音验证码越来越流行,比如有次在注册gmail邮箱看到过,还有msn页面也有语音验证码,还有国外一些网站等。

花时间研究了下,语音验证码主要跟一般验证码的区别就在于如何让验证码播放。本文语音验证码原理:从服务器生成验证码,

并保存到cookie中(getcode.aspx.cs),当点收听验证码的时候,调用javascirpt操作(这里使用jquery)cookie读取验证码,

然后把验证码传到codevoice.aspx页,然后按顺序把验证码合成生成一个mp3文件,最后把这个文件传入flash中播放,

你将收听的声音为:“当前验证码是5678请输入”。这个原理也是大部分网站使用的语音验证码原理类似。

源码下载:下载 (请使用VS2008 SP1或VS2010打开)

页面上放置验证码图片页面代码

view plaincopy to clipboardprint?

<form id="form1" runat="server">

<div>

<input type="text" name="txtCode" id="txtCode" maxlength="8" />

<img onclick="this.src='getcode.aspx';" src="getcode.aspx" mce_src="getcode.aspx" align="absmiddle" style="cursor: pointer" mce_style="cursor: pointer" alt="看不清楚,换一张" title="看不清楚,换一张" />

<img id="imgRead" src="image/maintb.gif" mce_src="image/maintb.gif" align="absmiddle" style="cursor: pointer" mce_style="cursor: pointer" alt="收听验证码" title="收听验证码" onclick="playvoice('player');" />

<span id="player"></span>

</div>

</form>

<form id="form1" runat="server">

<div>

<input type="text" name="txtCode" id="txtCode" maxlength="8" />

<img onclick="this.src='getcode.aspx';" src="getcode.aspx" mce_src="getcode.aspx" align="absmiddle" style="cursor: pointer" mce_style="cursor: pointer" alt="看不清楚,换一张" title="看不清楚,换一张" />

<img id="imgRead" src="image/maintb.gif" mce_src="image/maintb.gif" align="absmiddle" style="cursor: pointer" mce_style="cursor: pointer" alt="收听验证码" title="收听验证码" onclick="playvoice('player');" />

<span id="player"></span>

</div>

</form>

点收听验证码时调用的js函数如下:

view plaincopy to clipboardprint?

function playvoice(id) {

var voiceid = document.getElementById(id);

var voicecode = $.cookie('ValidateCode');

voiceid.innerHTML = "<embed id='sound_play' name='sound_play' src="sound_play.swf?" + (new Date().getTime()) + "" mce_src="sound_play.swf?" + (new Date().getTime()) + ""

FlashVars='isPlay=1&url=codevoice.aspx&code=" + voicecode + "' width='0' height='0' allowScriptAccess='always'

ype='application/x-shockwave-flash' pluginspage='http://www.macromedia.com/go/getflashplayer' /></embed>";

}

function playvoice(id) {

var voiceid = document.getElementById(id);

var voicecode = $.cookie('ValidateCode');

voiceid.innerHTML = "<embed id='sound_play' name='sound_play' src="sound_play.swf?" + (new Date().getTime()) + "" mce_src="sound_play.swf?" + (new Date().getTime()) + ""

FlashVars='isPlay=1&url=codevoice.aspx&code=" + voicecode + "' width='0' height='0' allowScriptAccess='always'

type='application/x-shockwave-flash' pluginspage='http://www.macromedia.com/go/getflashplayer' /></embed>";

}

其中$.cookie('ValidateCode')是读取cookie验证码,这里使用了一个jquery操作cookie插件

生成mp3页面代码如下:

//读取验证码生成mp3,这里包括头部begin.mp3和尾部end.mp3

view plaincopy to clipboardprint?

Response.ContentType = "audio/mpeg";

Response.WriteFile("sound/begin.mp3");

string checkCode = HttpContext.Current.Request.QueryString["code"].ToString();// string checkCode ="8888";

if (checkCode.Length > 0)

for (int i = 0; i < checkCode.Length; i++)

{

Response.WriteFile("sound/"+checkCode[i] + ".mp3");

}

Response.WriteFile("sound/end.mp3");

Response.ContentType = "audio/mpeg";

Response.WriteFile("sound/begin.mp3");

string checkCode = HttpContext.Current.Request.QueryString["code"].ToString();// string checkCode ="8888";

if (checkCode.Length > 0)

for (int i = 0; i < checkCode.Length; i++)

{

Response.WriteFile("sound/"+checkCode[i] + ".mp3");

}

Response.WriteFile("sound/end.mp3");

【本文作者分别在cnblogs,csdn,http://www.ajaxcn.net同步发布,转载请保留此说明】

flash播放代码主要在第一帧关键帧右击动作,插入以下代码根据传入的播放数字mp3地址

view plaincopy to clipboardprint?

var mysound = new Sound();

var mysong = url;

var isPlay = 1;

var intnum:Number = setInterval(playSong, 500);

function playSong() {

if (isPlay == 1) {

mysound.loadSound(mysong+"?code="+code, true);

mysound.start();

clearInterval(intnum);

isPlay = 0;

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有