如何实现php手机短信验证功能

如何实现php手机短信验证功能,第1张

现在网站在建设网站时为了保证用户信息的真实性,往往会选择发短信给用户手机发验证码信息,只有通过验证的用户才可以注册,这样保证了用户的联系信息资料的100%的准确性 。

第一、实现php手机短信验证功能的基本思路

1、要找到短信服务提供商,接入短信服务

2、在网站信息提交页面请求发送信息

3、服务器向短信服务提供商通信,提交发送请求

4、短信服务提供商通过运营商将信息发送到用户的手机中

二、手机号码短信验证前台页面效果实现

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" >

<html xmlns>

<head>

<title></title>

<script src="js/jquery-1.4a2.min.js" type="text/javascript"></script>

<script type="text/javascript">

/*-------------------------------------------*/

var InterValObj//timer变量,控制时间

var count = 60//间隔函数,1秒执行

var curCount//当前剩余秒数

var code = ""//验证码

var codeLength = 6//验证码长度

function sendMessage() {

curCount = count

var dealType//验证方式

tel = $(’#tel’).val()

if(tel!=’’){

//验证手机有效性

var myreg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/

if(!myreg.test($(’#tel’).val()))

{

alert(’请输入有效的手机号码!’)

return false

}

tel = $(’#tel’).val()

//产生验证码

for (var i = 0i <codeLengthi++) {

code += parseInt(Math.random() * 9).toString()

}

//设置button效果,开始计时

$("#btnSendCode").attr("disabled", "true")

$("#btnSendCode").val("请在" + curCount + "秒内输入验证码")

InterValObj = window.setInterval(SetRemainTime, 1000)//启动计时器,1秒执行一次

//向后台发送处理数据

$.ajax({

type: "POST", //用POST方式传输

dataType: "text", //数据格式:JSON

url: ’yanzhengma.php’, //目标地址(根据实际地址)

data: "&tel=" + tel + "&code=" + code,

error: function (XMLHttpRequest, textStatus, errorThrown) { },

success: function (msg){ }

})

}else{

alert(’请填写手机号码’)

}

}

//timer处理函数

function SetRemainTime() {

if (curCount == 0) {

window.clearInterval(InterValObj)//停止计时器

$("#btnSendCode").removeAttr("disabled")//启用按钮

$("#btnSendCode").val("重新发送验证码")

code = ""//清除验证码。如果不清除,过时间后,输入收到的验毕慎证码依然有效

}

else {

curCount--

$("#btnSendCode").val("请在" + curCount + "秒内输入验证码")

}

}

</script>

</head>丛带

<body>

<input name="tel" id=tel type="手郑敬text" />

<input id="btnSendCode" type="button" value="发送验证码" onclick="sendMessage()" /></p>

</body>

</html>

第三、调用短信服务器短信接口

整理的页面是yanzhengma.php(具体根据服务商提供信息)

<?php //提交短信

$post_data = array()

$post_data[’userid’] = 短信服务商提供ID

$post_data[’account’] = ’短信服务商提供用户名’

$post_data[’password’] = ’短信服务商提供密码’

// Session保存路径

$sessSavePath = dirname(__FILE__)."/../data/sessions/"

if(is_writeable($sessSavePath) &&is_readable($sessSavePath)){

session_save_path($sessSavePath)

}

session_register(’mobliecode’)

$_SESSION[’mobilecode’] = $_POST["code"]

$content=’短信验证码:’.$_POST["code"].’【短信验证】’

$post_data[’content’] = mb_convert_encoding($content,’utf-8’, ’gb2312’)//短信内容需要用urlencode编码下

$post_data[’mobile’] = $_POST["tel"]

$post_data[’sendtime’] = ’’//不定时发送,值为0,定时发送,输入格式YYYYMMDDHHmmss的日期值

$url=’http://IP:8888/sms.aspx?action=send’

$o=’’

foreach ($post_data as $k=>$v)

{

$o.="$k=".$v.’&’

}

$post_data=substr($o,0,-1)

$ch = curl_init()

curl_setopt($ch, CURLOPT_POST, 1)

curl_setopt($ch, CURLOPT_HEADER, 0)

curl_setopt($ch, CURLOPT_URL,$url)

curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data)

//curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1)//如果需要将结果直接返回到变量里,那加上这句。

$result = curl_exec($ch)

?>

第四:提交表单信息时对短信验证码验证

//手机验证码开始

session_start()

$svalitel = $_SESSION[’mobilecode’]

$vdcodetel = empty($vdcodetel) ? ’’ : strtolower(trim($vdcodetel))

if(strtolower($vdcodetel)!=$svalitel || $svalitel==’’)

{

ResetVdValue()

//echo "Pageviews=".$vdcodetel

ShowMsg("手机验证码错误!", ’-1’)

exit()

}

以前在远标做过你的应用应该是这样吧,用户输入手机号码,点击发送短信,用户收到验证码,输入对应的验证码 判旁散弊断是否正确。

需要:

申请一个短信接口,就是点击发送验证码的掘镇时候,提交到接口给该号码下发验证码。

技术方面的实现:

1、点击获取验证码

2、程序ajax post提交到短信接口

3、运族短信接口服务商 接口判断用户和口令,正确后,下发短信给该号码。

4、用户输入号码,程序判断验证码是否一致。

1、加验证码;2、加时间限制,间隔一定时间才能有效;3、数据库存储手机发送情况,如手机号,时间,IP;4、根据收亩行集数据伍耐友,判断是否刷机,禁用IP或者手机号等等,设置禁用时间5、根据实际情况腔槐,设置单天同个IP,手机号一天短信数量PHP网站短信验证码如何防止被刷


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12299308.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存