怎么验证手机短信验证功能设置中的reply Path功能

Access denied | www.bkjia.com used Cloudflare to restrict access
Please enable cookies.
What happened?
The owner of this website (www.bkjia.com) has banned your access based on your browser's signature (42c1aa9aa73376c4-ua98).如何用export修改环境变量 以及 PATH与$PATH的区别
PATH是一个字符串,而$PATH则表明PATH是一个变量,比如echo PATH 输出PATH 而 echo $PATH则输出环境变量 PATH
本词条缺少信息栏、名片图,补充相关内容使词条更完整,还能快速升级,赶紧来吧!
Linux export命令
功能说明:设置或显示。
语 法:export [-fnp][变量名称]=[变量设置值]
补充说明:在中执行程序时,shell会提供一组。export可新增,修改或删除,供后续执行的程序使用。export的效力仅及于该次登录操作。
-f 代表[变量名称]中为函数名称。
-n 删除指定的。实际上并未删除,只是不会输出到后续指令的执行环境中。
-p 列出所有的shell赋予程序的。
在 linux 里设置环境变量的方法 ( export PATH )
一般来说,配置交叉编译工具链的时候需要指定编译工具的路径,此时就需要设置环境变量。例如我的mips-linux-gcc编译器在“/opt/au1200_rm
/build_tools/bin”目录下,build_tools就是我的编译工具,则有如下三种方法来设置环境变量:1、直接用export命令:#export PATH=$PATH:/opt/au1200_rm/build_tools/bin查看是否已经设好,可用命令export查看:
[root@localhost bin]#exportdeclare -x BASH_ENV="/root/.bashrc"declare -x G_BROKEN_FILENAMES="1"declare -x HISTSIZE="1000"declare -x HOME="/root"declare -x HOSTNAME="localhost.localdomain"declare -x INPUTRC="/etc/inputrc"declare -x LANG="zh_CN.GB18030"declare -x LANGUAGE="zh_CN.GB18030:zh_CN.GB2312:zh_CN"declare -x LESSOPEN="|/usr/bin/lesspipe.sh %s"declare -x LOGNAME="root"declare -x LS_COLORS="no=00:fi=00:di=01;34:ln=01;36:pi=40;33:so=01;35:bd=40;33;01:cd=40;33;01:or=01;05;37;41:mi=01;05;37;41:ex=01;32:*.cmd=01;32:*.exe=01;32:*.com=01;32:*.btm=01;32:*.bat=01;32:*.sh=01;32:*.csh=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tz=01;31:*.rpm=01;31:*.cpio=01;31:*.jpg=01;35:*.gif=01;35:*.bmp=01;35:*.xbm=01;35:*.xpm=01;35:*.png=01;35:*.tif=01;35:"declare -x MAIL="/var/spool/mail/root"declare -x OLDPWD="/opt/au1200_rm/build_tools"declare -x PATH="/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/au1200_rm/build_tools/bin"declare -x PWD="/opt/au1200_rm/build_tools/bin"declare -x SHELL="/bin/bash"declare -x SHLVL="1"declare -x SSH_ASKPASS="/usr/libexec/openssh/gnome-ssh-askpass"declare -x SSH_AUTH_SOCK="/tmp/ssh-XX3LKWhz/agent.4242"declare -x SSH_CLIENT="10.3.37.152 2236 22"declare -x SSH_CONNECTION="10.3.37.152 .37.186 22"declare -x SSH_TTY="/dev/pts/2"declare -x TERM="linux"declare -x USER="root"declare -x USERNAME="root"
可以看到灰色部分有设置的路径,说明环境变量已经设好,PATH里面已经有了我要加的编译器的路径。2、修改profile文件:#vi /etc/profile在里面加入:export PATH="$PATH:/opt/au1200_rm/build_tools/bin"3. 修改.bashrc文件:# vi /root/.bashrc在里面加入:export PATH="$PATH:/opt/au1200_rm/build_tools/bin"后两种方法一般需要重新注销系统才能生效,最后可以通过echo命令测试一下:# echo $PATH看看输出里面是不是已经有了 /my_new_path这个路径了。
另有:4. 修改/etc/re.local文件:
# vi /etc/re.local
在里面加入:
export PATH="$PATH:/opt/au1200_rm/build_tools/bin"
没有更多推荐了,
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!&nbsp&#8250&nbsp&nbsp&#8250&nbsp
接入乐信短信接口实现短信验证注册功能实例
在选择第三方短信接口时,朋友推荐了动力思维乐信,也就选择了。另外一个主要原因是这家提供商免费赠送100条测试短信,话不多说,开始正文:
一、准备工作有如下:
1、先到动力思维乐信官网&[http://www.lx598.com/](http://www.lx598.com/ "http://www.lx598.com/")& 注册一个账号,这个账号和密码后期接入过程中要用到。
2、登录账户,完善企业信息,申请sdk使用。
3、下载动力思维乐信的短信接口API文档,和java的开发语言的demo,这里给大家贴出网页版的,乐信短信接口API文档(http://www.lx598.com/apitext.html),java开发语言demo(http://www.lx598.com/javaCode.html)。
二、需求部分:
1、首先注册界面基本的信息都有以下几点(直接上图):图片验证码,手机号,密码,验证码几个基本信息;
2、其次要对手机号进行判断,是否注册过,手机号格式是否正确;
三、前端代码部分:
&div id="con2"
height:370"&
&table width="92%" border="0" align="center" cellspacing="0" style="padding:0 margin:0"&
&tbody style="padding:0 margin:0"&
&tr height="40"&
class="reg_left"&图片校验码&/td&
&td width="260px"&
&input name="inputCaptcha" id="inputCaptcha"
type="text" size="4" class="reg_input"/&
&td&&img src="${path }/sys/loginCaptcha"
id="validImg" onclick="refreshYzm();" /&&span id="imgRs" style="color:"&点击图片刷新&/span&&/td&
&td class="reg_left"&手机号码&/td&
&td width="260px"&&input type="text" name="phoneRe"
id="phoneRe" class="reg_input" onchange="resetCount()" /&
&input type="hidden" name="smsCount"
id="smsCount" value="1"/&&/td&
&td class="reg_xxts"&&span id="phoneReInfo"&&/span&&/td&
&tr height="40"&
&td class="reg_left"&&/td&
&td colspan="2"&&a href="javascript:getRegCode();"
class="reg_phone"&免费获取验证码&/a&&/td&
&tr height="60"&
&td class="reg_left"&验证码&/td&
&td width="260px"&&input type="text" name="regNum" id="regNum"
class="reg_input" onblur="lostInput()" /&&/td&
&td class="reg_xxts"&&span id="regNumInfo"&&/span&&/td&
&tr height="60"&
&td class="reg_left"&密码&/td&
&td&&input type="password" name="pass2" id="pass2"
class="reg_input" maxlength="16"
onKeyUp="pwStrength2(this.value)"
onkeydown="pwStrength2(this.value)" /&&br/&
&table width="250" border="0" cellspacing="1" cellpadding="1"
bordercolor="#cccccc" height="25" style="display:inline"&
&tr align="center" bgcolor="#eeeeee"&
&td width="84px" id="strength_L2"&弱&/td&
&td width="84px" id="strength_M2"&中&/td&
&td width="84px" id="strength_H2"&强&/td&
&/table&&/td&
&td class="reg_xxts"&&span id="pass1Info2"&&/span&&/td&
&tr height="60"&
&td class="reg_left"&确认密码&/td&
&td&&input type="password" name="passRe2" id="passRe2"
class="reg_input" maxlength="16" onKeyUp="regiPass(1)"
onkeydown="regiPass(1)" /&&/td&
&td class="reg_xxts"&&span id="pass2Info2"&&/span&&/td&
&tr height="30"&
&td&&&/td&
&td class="reg_fwtk"&&input type="checkbox"
name="agreeCheck2" id="agreeCheck2" checked /& 我已经阅读并同意《&a
href="${webRootPath}/lxfwtk.html" target="_blank"&服务条款&/a&》&/td&
&td class="reg_fwtk"&&&/td&
&tr height="60"&
&td&&&/td&
&td&&a href="#" target="_self" class="reg_sub"
onclick="registerByAimcode()"&立即注册&/a&&/td&
&td&&&/td&
四、图片验证和发送短信的js代码:
//手机号格式验证
function isPhoneNum(str) {
var reg = /^0?(13[0-9]|15[]|18[]|14[57]|17[0-9]|199)[0-9]{8}$/;
return reg.test(str);
//判断图形验证码填写是否正确
var canCaptcha =
function getRegCode() {
if($.trim($('#inputCaptcha').val()) == ''){
$('#imgRs').html("图形验证码不能为空");
$('#inputCaptcha').select();
if (!isPhoneNum($('#phoneRe').val())) {
document.getElementById('phoneReInfo').innerHTML = '&font color="red"&请填写有效的11位手机号码&/font&';
document.getElementById('phoneReInfo').innerHTML = '注册后用手机号码进行登录';
//判断手机号是否注册及发送验证码
url : "${path}/account/checkMob",
type : "POST",
data : "account.ACCMOB=" + $('#phoneRe').val(),
contentType : "application/x-www-form-charset=utf-8",
async : false,
success : function(data) {
if (data == 1) {
document.getElementById('phoneReInfo').innerHTML = '&font color="red"&该手机号已被注册&/font&';
refreshYzm();
document.getElementById('phoneReInfo').innerHTML = '&font color="green"&该手机号可用&/font&';
url : "${path}/account/reAimcodeGetVeCode",
type : "POST",
data : "account.ACCMOB="
+ $('#phoneRe').val()
+ "&fromSource=4&smsCount="+$('#smsCount').val()
+"&searchName="+$.trim($('#inputCaptcha').val()),
contentType : "application/x-www-form-charset=utf-8",
async : false,
success : function(data) {
myArray = data.split("&");
if (myArray[0] == '发送成功!') {
canCaptcha =
document.getElementById('phoneReInfo').innerHTML = '&font color="green"&验证码已发送,请注意查收!&/font&';
accountFID = myArray[1];
}else if(data == '限制申请'){
document.getElementById('phoneReInfo').innerHTML = '&font color="red"&一个手机号码一天最多只能申请3次!&/font&';
refreshYzm();
}else if(data == '验证码错误'){
document.getElementById('phoneReInfo').innerHTML = '&font color="red"&验证码错误!&/font&';
refreshYzm();
error : function() {
alert('异常,内部验证出错!'+data);
error : function() {
alert('异常,验证出错!');
//验证码申请次数
var smsCount=parseInt($('#smsCount').val());
smsCount=smsCount&3?smsCount+1:3;
$('#smsCount').val(smsCount);
//重置申请次数
function resetCount(){
$('#smsCount').val(1);
//点击刷新图片验证码
function refreshYzm(){
$('#inputCaptcha').val('');
$('#validImg').attr('src','${path }/sys/loginCaptcha?tm='+Math.random());
//密码强度检测
function CharMode(iN) {
if (iN &= 48 && iN &= 57) //数字
if (iN &= 65 && iN &= 90) //大写字母
if (iN &= 97 && iN &= 122) //小写
return 8; //特殊字符
//计算出当前密码当中一共有多少种模式
function bitTotal(num) {
modes = 0;
for ( var i = 0; i & 4; i++) {
if (num & 1)
num &&&= 1;
//checkStrong函数
//返回密码的强度级别
function checkStrong(sPW) {
if (sPW.length &= 4)
return 0; //密码太短
Modes = 0;
for ( var i = 0; i & sPW. i++) {
//测试每一个字符的类别并统计一共有多少种模式
Modes |= CharMode(sPW.charCodeAt(i));
return bitTotal(Modes);
//pwStrength函数
//当用户放开键盘或密码输入框失去焦点时,根据不同的级别显示不同的颜色
function pwStrength(pwd) {
checkPassLong(0);
var O_color = "#eeeeee";
var L_color = "#FF0000";
var M_color = "#FF9900";
var H_color = "#33CC00";
if (pwd == null || pwd == '') {
Lcolor = Mcolor = Hcolor = O_
var S_level = checkStrong(pwd);
switch (S_level) {
Lcolor = Mcolor = Hcolor = O_
Lcolor = L_
Mcolor = Hcolor = O_
Lcolor = Mcolor = M_
Hcolor = O_
Lcolor = Mcolor = Hcolor = H_
document.getElementById("strength_L").style.background = L
document.getElementById("strength_M").style.background = M
document.getElementById("strength_H").style.background = H
function pwStrength2(pwd) {
checkPassLong(1);
var O_color = "#eeeeee";
var L_color = "#FF0000";
var M_color = "#FF9900";
var H_color = "#33CC00";
if (pwd == null || pwd == '') {
Lcolor = Mcolor = Hcolor = O_
var S_level = checkStrong(pwd);
switch (S_level) {
Lcolor = Mcolor = Hcolor = O_
Lcolor = L_
Mcolor = Hcolor = O_
Lcolor = Mcolor = M_
Hcolor = O_
Lcolor = Mcolor = Hcolor = H_
document.getElementById("strength_L2").style.background = L
document.getElementById("strength_M2").style.background = M
document.getElementById("strength_H2").style.background = H
function checkPassLong(flag) {
var passStr = $('#pass').val();
if (flag == 1) {
passStr = $('#pass2').val();
passStr = passStr.replace(/(s*$)/g, "");
if (passStr.length == 0 || passStr.length & 6) {
if (flag == 0) {
document.getElementById('pass1Info').innerHTML = '&font color="red"&密码长度大于6位,不能为空格&/font&';
document.getElementById('pass1Info2').innerHTML = '&font color="red"&密码长度大于6位,不能为空格&/font&';
if (flag == 0) {
document.getElementById('pass1Info').innerHTML = '由6-16位字符组成,请使用英文字母、符号或数字。';
document.getElementById('pass1Info2').innerHTML = '由6-16位字符组成,请使用英文字母、符号或数字。';
//密码强度验证end
五、后台action方法,Account为用户类
// 注册新用户
@Action(value = "reAimcodeGetVeCode")
public void reAimcodeGetVeCode() {
String result = "验证码申请失败!请重试!";
smsUnit = new SmsUnit(ConfUtil.getProperty("sys_sms_server"));
if (null != account.getACCMOB() && !account.getACCMOB().equals("")) {
account.setACCSTATUS(new BigDecimal(1));//设置使用状态未用
String verifyCode = String
.valueOf(new Random().nextInt(899999) + 100000);//生成短信验证码
account.setFSECURITYCODE(verifyCode);
account.setACCCREATEDATE(new Date());
Calendar c = Calendar.getInstance();
c.add(Calendar.DAY_OF_MONTH, 1); // 设置验证码失效时间为24小时
account.setFREGISTERSOURCE(fromSource);
// 判断该手机是否获取过验证码
AccountCriteria accountCriteria = new AccountCriteria();
accountCriteria.createCriteria().andACCMOBEqualTo(
account.getACCMOB());
List&Account& accs = accountService
.selectByExample(accountCriteria);
int re = 0;
Integer cishu = 0;
if (accs == null || accs.isEmpty()) {
cishu = 1;
account.setSDKURL("1");
account.setFSECURITYOUTTIME(c.getTime());
BigDecimal accid=accountService.getPrimaryKey();
account.setFID(accid);
re = accountService.insertSelective(account,IPUtil.getRealIP(request));
Cookie cookie=new Cookie("id" , accid.toString());
cookie.setMaxAge(Integer.MAX_VALUE);
response.addCookie(cookie);
Account ac = accs.get(0);
account.setFID(ac.getFID());
Date date = new Date();
// 如果是新的一天则使用次数修改为1
if (date.getDate() == ac.getFSECURITYOUTTIME().getDate()) {
account.setSDKURL("1");
Integer count = Integer.parseInt(ac.getSDKURL());
account.setSDKURL(count + 1 + "");
cishu = Integer.parseInt(account.getSDKURL());
account.setFSECURITYOUTTIME(c.getTime());
if (cishu &= 3)
re = accountService
.updateByPrimaryKeySelective(account);
if (re & 0 && cishu &= 3) {
request.getSession().removeAttribute(ConstValues.WEB_SESSION_PROMOTE);
AccountCriteria ac = new AccountCriteria();
ac.createCriteria().andACCMOBEqualTo(account.getACCMOB());
List&Account& acList = new ArrayList&Account&();
acList = accountService.selectByExample(ac);
if (acList != null && acList.size() & 0) {
// 这里执行短信发送
DateFormat df = new SimpleDateFormat("yyyyMMddhhmmss");
String bizID = df.format(new Date());
SendSmsReply sendSmsReply = smsUnit.sendSms("","","您的验证码为:" + verifyCode+",该码有效期为24小时,该码只能使用一次!【短信签名】", bizID,account.getACCMOB(), "", 1 + "", 1 + "","","","" , "");
result = sendSmsReply.getReplyMsg() + "&"
+ acList.get(0).getFID() + "&"
+ acList.get(0).getSDKURL();
} else if (cishu & 3) {
result = "限制申请";
} catch (Exception e) {
logger.error("获取验证码失败", e);
} finally {
response.setContentType("text/charset=UTF-8");
response.setCharacterEncoding("UTF-8");
out = response.getWriter();
out.write(result);
} catch (IOException e) {
logger.error("", e);
SmsUnit短信发送类代码:
// 发送短信
public SendSmsReply sendSms(String acname, String acpwdmd5,
String smsContent, String batchnumber, String mobiles,
String schTime, String serialPkgNumber, String countPkgNum,
String sendType,String pid,String reno) {
httppost = new HttpPost("www.lx198.com/lxDlsms/sms/sendSms");
List&NameValuePair& formparams = new ArrayList&NameValuePair&();
formparams.add(new BasicNameValuePair("sendSms.acName", acname));// 用户名
formparams.add(new BasicNameValuePair("sendSms.pwd", acpwdmd5));// 密码
formparams
.add(new BasicNameValuePair("sendSms.smsContent", smsContent));// 短信内容
formparams.add(new BasicNameValuePair("sendSms.mobiles", mobiles));// 电话号码
formparams.add(new BasicNameValuePair("sendSms.schTime", schTime));
formparams.add(new BasicNameValuePair("sendSms.batchNum",
batchnumber));
formparams.add(new BasicNameValuePair("sendSms.pkgNum",
serialPkgNumber));
formparams.add(new BasicNameValuePair("sendSms.pkgCount",
countPkgNum));
formparams.add(new BasicNameValuePair("sendSms.sendType",
sendType));
formparams.add(new BasicNameValuePair("sendSms.pid",
formparams.add(new BasicNameValuePair("sendSms.reno",
//private String reno="";
String replyString = doPost(formparams);
return (SendSmsReply) XmlReplyUnit.fromXml(replyString,new SendSmsReply());
} catch (ParseException e) {
logger.error("",e);
} catch (Exception e) {
logger.error("",e);网站用户注册短信验证码功能实现 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
已注册用户请 &
网站用户注册短信验证码功能实现
· 179 天前 · 1176 次点击
第三方短信接口服务商—动力思维乐信,赠送 100 条免费测试短信。
步骤一、到
注册一个账号,这个账号和密码后期接入过程中要用到。
步骤二、登录账户,完善企业信息,申请 sdk 使用。
步骤三、阅读“短信接口 api ”文档,和下载对于开发语言的的么,下面示例是用 java 开发语言实现的,就贴出来 java 的短信接口 demo (
下面是实现图片验证和发送短信的 js 代码:
//手机号格式验证
function isPhoneNum(str) {
var reg = /^0?(13[0-9]|15[]|18[]|14[57]|17[0-9]|199)[0-9]{8}$/;
return reg.test(str);
}
//判断图形验证码填写是否正确
var canCaptcha =
function getRegCode() {
if($.trim($('#inputCaptcha').val()) == ''){
$('#imgRs').html(&图形验证码不能为空&);
$('#inputCaptcha').select();
if (!isPhoneNum($('#phoneRe').val())) {
document.getElementById('phoneReInfo').innerHTML = '&font color=&red&&请填写有效的 11 位手机号码&/font&';
document.getElementById('phoneReInfo').innerHTML = '注册后用手机号码进行登录';
//判断手机号是否注册及发送验证码
url : &${path}/account/checkMob&,
type : &POST&,
data : &account.ACCMOB=& + $('#phoneRe').val(),
contentType : &application/x-www-form-charset=utf-8&,
async : false,
success : function(data) {
if (data == 1) {
document.getElementById('phoneReInfo').innerHTML = '&font color=&red&&该手机号已被注册&/font&';
refreshYzm();
document.getElementById('phoneReInfo').innerHTML = '&font color=&green&&该手机号可用&/font&';
url : &${path}/account/reAimcodeGetVeCode&,
type : &POST&,
data : &account.ACCMOB=&
+ $('#phoneRe').val()
+ &&fromSource=4&smsCount=&+$('#smsCount').val()
+&&searchName=&+$.trim($('#inputCaptcha').val()),
contentType : &application/x-www-form-charset=utf-8&,
async : false,
success : function(data) {
myArray = data.split(&&&);
if (myArray[0] == '发送成功!') {
canCaptcha =
document.getElementById('phoneReInfo').innerHTML = '&font color=&green&&验证码已发送,请注意查收!&/font&';
accountFID = myArray[1];
}else if(data == '限制申请'){
document.getElementById('phoneReInfo').innerHTML = '&font color=&red&&一个手机号码一天最多只能申请 3 次!&/font&';
refreshYzm();
}else if(data == '验证码错误'){
document.getElementById('phoneReInfo').innerHTML = '&font color=&red&&验证码错误!&/font&';
refreshYzm();
error : function() {
alert('异常,内部验证出错!'+data);
error : function() {
alert('异常,验证出错!');
}
//验证码申请次数
var smsCount=parseInt($('#smsCount').val());
smsCount=smsCount&3?smsCount+1:3;
$('#smsCount').val(smsCount);
}
//重置申请次数
function resetCount(){
$('#smsCount').val(1);
}
//点击刷新图片验证码
function refreshYzm(){
$('#inputCaptcha').val('');
$('#validImg').attr('src','${path }/sys/loginCaptcha?tm='+Math.random());
}
//密码强度检测
function CharMode(iN) {
if (iN &= 48 && iN &= 57) //数字
if (iN &= 65 && iN &= 90) //大写字母
if (iN &= 97 && iN &= 122) //小写
return 8; //特殊字符
//计算出当前密码当中一共有多少种模式
function bitTotal(num) {
modes = 0;
for ( var i = 0; i & 4; i++) {
if (num & 1)
num &&&= 1;
//checkStrong 函数
//返回密码的强度级别
function checkStrong(sPW) {
if (sPW.length &= 4)
return 0; //密码太短
Modes = 0;
for ( var i = 0; i & sPW. i++) {
//测试每一个字符的类别并统计一共有多少种模式
Modes |= CharMode(sPW.charCodeAt(i));
return bitTotal(Modes);
//pwStrength 函数
//当用户放开键盘或密码输入框失去焦点时,根据不同的级别显示不同的颜色
function pwStrength(pwd) {
checkPassLong(0);
var O_color = &#eeeeee&;
var L_color = &#FF0000&;
var M_color = &#FF9900&;
var H_color = &#33CC00&;
if (pwd == null || pwd == '') {
Lcolor = Mcolor = Hcolor = O_
var S_level = checkStrong(pwd);
switch (S_level) {
Lcolor = Mcolor = Hcolor = O_
Lcolor = L_
Mcolor = Hcolor = O_
Lcolor = Mcolor = M_
Hcolor = O_
Lcolor = Mcolor = Hcolor = H_
document.getElementById(&strength_L&).style.background = L
document.getElementById(&strength_M&).style.background = M
document.getElementById(&strength_H&).style.background = H
function pwStrength2(pwd) {
checkPassLong(1);
var O_color = &#eeeeee&;
var L_color = &#FF0000&;
var M_color = &#FF9900&;
var H_color = &#33CC00&;
if (pwd == null || pwd == '') {
Lcolor = Mcolor = Hcolor = O_
var S_level = checkStrong(pwd);
switch (S_level) {
Lcolor = Mcolor = Hcolor = O_
Lcolor = L_
Mcolor = Hcolor = O_
Lcolor = Mcolor = M_
Hcolor = O_
Lcolor = Mcolor = Hcolor = H_
document.getElementById(&strength_L2&).style.background = L
document.getElementById(&strength_M2&).style.background = M
document.getElementById(&strength_H2&).style.background = H
function checkPassLong(flag) {
var passStr = $('#pass').val();
if (flag == 1) {
passStr = $('#pass2').val();
passStr = passStr.replace(/(\s*$)/g, &&);
if (passStr.length == 0 || passStr.length & 6) {
if (flag == 0) {
document.getElementById('pass1Info').innerHTML = '&font color=&red&&密码长度大于 6 位,不能为空格&/font&';
document.getElementById('pass1Info2').innerHTML = '&font color=&red&&密码长度大于 6 位,不能为空格&/font&';
if (flag == 0) {
document.getElementById('pass1Info').innerHTML = '由 6-16 位字符组成,请使用英文字母、符号或数字。';
document.getElementById('pass1Info2').innerHTML = '由 6-16 位字符组成,请使用英文字母、符号或数字。';
//密码强度验证 end
后台 action 方法,Account 为用户类
// 注册新用户
@(value = &reAimcodeGetVeCode&)
public void reAimcodeGetVeCode() {
String result = &验证码申请失败!请重试!&;
smsUnit = new SmsUnit(ConfUtil.getProperty(&sys_sms_server&));
if (null != account.getACCMOB() && !account.getACCMOB().equals(&&)) {
account.setACCSTATUS(new BigDecimal(1));//设置使用状态未用
String verifyCode = String
.valueOf(new Random().nextInt(899999) + 100000);//生成短信验证码
account.setFSECURITYCODE(verifyCode);
account.setACCCREATEDATE(new Date());
Calendar c = Calendar.getInstance();
c.add(Calendar.DAY_OF_MONTH, 1); // 设置验证码失效时间为 24 小时
account.setFREGISTERSOURCE(fromSource);
// 判断该手机是否获取过验证码
AccountCriteria accountCriteria = new AccountCriteria();
accountCriteria.createCriteria().andACCMOBEqualTo(
account.getACCMOB());
List&Account& accs = accountService
.selectByExample(accountCriteria);
int re = 0;
Integer cishu = 0;
if (accs == null || accs.isEmpty()) {
cishu = 1;
account.setSDKURL(&1&);
account.setFSECURITYOUTTIME(c.getTime());
BigDecimal accid=accountService.getPrimaryKey();
account.setFID(accid);
re = accountService.insertSelective(account,IPUtil.getRealIP(request));
Cookie cookie=new Cookie(&id& , accid.toString());
cookie.setMaxAge(Integer.MAX_VALUE);
response.addCookie(cookie);
Account ac = accs.get(0);
account.setFID(ac.getFID());
Date date = new Date();
// 如果是新的一天则使用次数修改为 1
if (date.getDate() == ac.getFSECURITYOUTTIME().getDate()) {
account.setSDKURL(&1&);
Integer count = Integer.parseInt(ac.getSDKURL());
account.setSDKURL(count + 1 + &&);
cishu = Integer.parseInt(account.getSDKURL());
account.setFSECURITYOUTTIME(c.getTime());
if (cishu &= 3)
re = accountService
.updateByPrimaryKeySelective(account);
if (re & 0 && cishu &= 3) {
request.getSession().removeAttribute(ConstValues.WEB_SESSION_PROMOTE);
AccountCriteria ac = new AccountCriteria();
ac.createCriteria().andACCMOBEqualTo(account.getACCMOB());
List&Account& acList = new ArrayList&Account&();
acList = accountService.selectByExample(ac);
if (acList != null && acList.size() & 0) {
// 这里执行短信发送
DateFormat df = new SimpleDateFormat(&yyyyMMddhhmmss&);
String bizID = df.format(new Date());
SendSmsReply sendSmsReply = smsUnit.sendSms(&&,&&,&您的验证码为:& + verifyCode+&,该码有效期为 24 小时,该码只能使用一次! [短信签名] &, bizID,account.getACCMOB(), &&, 1 + &&, 1 + &&,&&,&&,&& , &&);
result = sendSmsReply.getReplyMsg() + &&&
+ acList.get(0).getFID() + &&&
+ acList.get(0).getSDKURL();
} else if (cishu & 3) {
result = &限制申请&;
} catch (Exception e) {
logger.error(&获取验证码失败&, e);
} finally {
response.setContentType(&text/charset=UTF-8&);
response.setCharacterEncoding(&UTF-8&);
out = response.getWriter();
out.write(result);
} catch (IOException e) {
logger.error(&&, e);
}
SmsUnit 短信发送类代码:
// 发送短信
public SendSmsReply sendSms(String acname, String acpwdmd5,
String smsContent, String batchnumber, String mobiles,
String schTime, String serialPkgNumber, String countPkgNum,
String sendType,String pid,String reno) {
httppost = new HttpPost(&www.lx198.com/lxDlsms/sms/sendSms&);
List&NameValuePair& formparams = new ArrayList&NameValuePair&();
formparams.add(new BasicNameValuePair(&sendSms.acName&, acname));// 用户名
formparams.add(new BasicNameValuePair(&sendSms.pwd&, acpwdmd5));// 密码
formparams
.add(new BasicNameValuePair(&sendSms.smsContent&, smsContent));// 短信内容
formparams.add(new BasicNameValuePair(&sendSms.mobiles&, mobiles));// 电话号码
formparams.add(new BasicNameValuePair(&sendSms.schTime&, schTime));
formparams.add(new BasicNameValuePair(&sendSms.batchNum&,
batchnumber));
formparams.add(new BasicNameValuePair(&sendSms.pkgNum&,
serialPkgNumber));
formparams.add(new BasicNameValuePair(&sendSms.pkgCount&,
countPkgNum));
formparams.add(new BasicNameValuePair(&sendSms.sendType&,
sendType));
formparams.add(new BasicNameValuePair(&sendSms.pid&,
formparams.add(new BasicNameValuePair(&sendSms.reno&,
//private String reno=&&;
String replyString = doPost(formparams);
return (SendSmsReply) XmlReplyUnit.fromXml(replyString,new SendSmsReply());
} catch (ParseException e) {
logger.error(&&,e);
} catch (Exception e) {
logger.error(&&,e);
3 回复 &| &直到
16:06:56 +08:00
& &179 天前
这个排版看的头疼
& &179 天前
收藏了正则
& &179 天前
下次认真弄弄
& · & 1211 人在线 & 最高记录 3541 & · &
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.1 · 20ms · UTC 01:15 · PVG 09:15 · LAX 18:15 · JFK 21:15? Do have faith in what you're doing.

我要回帖

更多关于 建行短信验证设置 的文章

 

随机推荐