- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解ThinkPHP3.2.3验证码显示、刷新、校验由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
ThinkPHP3.2.3验证码显示、刷新、校验 ,具体如下:
显示验证码 。
首先在Home/Controller下创建一个公共控制器PublicController 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
<?php
namespace
Home\Controller;
use
Think\Controller;
use
Think\Verify;
class
PublicController
extends
Controller
{
/* 生成验证码 */
public
function
verify()
{
$config
= [
'fontSize'
=> 19,
// 验证码字体大小
'length'
=> 4,
// 验证码位数
'imageH'
=> 34
];
$Verify
=
new
Verify(
$config
);
$Verify
->entry();
}
/* 验证码校验 */
public
function
check_verify(
$code
,
$id
=
''
)
{
$verify
=
new
\Think\Verify();
$res
=
$verify
->check(
$code
,
$id
);
$this
->ajaxReturn(
$res
,
'json'
);
}
}
|
verify函数用于生成验证码,config是用来配置显示验证码的属性。该属性有哪些可配置项,可以查看Thinkphp/Library/Think/Verify.class.php文件,此处不再赘述.
check_verify函数用于校验验证码的正确性。模板post用户填写的验证码到该函数,返回$res==true验证通过false验证失败。 前台模板页建立index.html 。
1
2
3
4
5
6
|
<
div
class
=
""
>
<
label
for
=
"j_verify"
class
=
"t"
>验证码:</
label
> <
input
id
=
"j_verify"
name
=
"j_verify"
type
=
"text"
class
=
"form-control x in"
>
<
img
id
=
"verify_img"
alt
=
"点击更换"
title
=
"点击更换"
src
=
"{:U('public/verify',array())}"
class
=
"m"
>
</
div
>
|
使用Thinkphp的U方法形成生成验证码的图片.
点击刷新验证码 。
从上面产生验证码的链接我们可以看出,域名/public/verify即可产生验证码。Thinkphp的验证码生成机制是,如若我们需要产生新的验证码,在该链接后加入一个变量值即可.
我们可以考虑实现public/verify/变量值的形式URL.
1
2
3
4
5
6
7
|
$(
"#verify_img"
).click(
function
() {
var
verifyURL =
"public/verify"
;
var
time =
new
Date
().getTime();
$(
"#verify_img"
).attr({
"src"
: verifyURL +
"/"
+ time
});
});
|
利用JS获取当前时间戳加入到URL之后即可.
到此我们即可实现验证码的点击刷新功能。具体表现形式,自己随意哈.
异步校验验证码 。
大家一定见过在某些网站,我们输入验证码的时候,输入的过程中文本框后面一直显示错误,直到我们输入争取的时候会先提示验证码正确的形式。下面代码就可以实现:
1
2
3
4
5
6
7
8
9
10
11
|
$(
"#j_verify"
).keyup(
function
() {
$.post(
"public/check_verify"
, {
code : $(
"#j_verify"
).val()
},
function
(data) {
if
(data == true) {
//验证码输入正确
}
else
{
//验证码输入错误
}
});
});
|
利用onekeyup。原理就不需要多讲了吧! 。
这样我们就可以实现在提交用户名密码之前先进行一次验证码校验,之后表单提交之后再进行一次校验,提升用户体验啦! 。
还没结束:
当我们采取以上形式实现验证码两次校验的时候,肯定会出现第一次异步校验成功,但是提交表单却提示验证码错误的情况!其实原因还是出在Thinkphp的Verify.class.php上:
以下是该类初始的config配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
protected
$config
=
array
(
'seKey'
=>
'ThinkPHP.CN'
,
// 验证码加密密钥
'codeSet'
=>
'2345678abcdefhijkmnpqrstuvwxyzABCDEFGHJKLMNPQRTUVWXY'
,
// 验证码字符集合
'expire'
=> 1800,
// 验证码过期时间(s)
'useZh'
=> false,
// 使用中文验证码
'zhSet'
=>
'……此处不粘贴了,太多了!'
,
// 中文验证码字符串
'useImgBg'
=> false,
// 使用背景图片
'fontSize'
=> 25,
// 验证码字体大小(px)
'useCurve'
=> false,
// 是否画混淆曲线
'useNoise'
=> false,
// 是否添加杂点
'imageH'
=> 0,
// 验证码图片高度
'imageW'
=> 0,
// 验证码图片宽度
'length'
=> 5,
// 验证码位数
'fontttf'
=>
''
,
// 验证码字体,不设置随机获取
'bg'
=>
array
(243, 251, 254),
// 背景颜色
'reset'
=> true,
// 验证成功后是否重置
);
|
请大家注意最后一个属性reset 表示的是验证成功后是否重置验证码。相信大家都明白了吧,我们进行第一次校验通过之后,其实该验证码已经失效了,只不过因为我们采取的是异步校验,页面并没有刷新,导致了第二次申请校验的时候和系统产生的已经是不相同的了。所以如果大家喜欢这种两次校验的风格,可以考虑将reset配置为false即可.
好了,基于Thinkphp3.2.3的验证码问题今天就总结到这了。只是大概说了一下实现方法,具体内容还请大家参考TP官方手册。如有错误之处,欢迎大家指出.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://www.cnblogs.com/John727/p/4510539.html 。
最后此篇关于详解ThinkPHP3.2.3验证码显示、刷新、校验的文章就讲到这里了,如果你想了解更多关于详解ThinkPHP3.2.3验证码显示、刷新、校验的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在网上找到了这个很棒的小代码,但它似乎没有在正确删除空格后比较两个字符串?我知道一些js,但这里的任何错误都超出了我的理解范围。希望有人知道这个问题的答案。 注意:它似乎还根据 channel 的数
如何使用 requirejs 导入 recaptcha。我已经尝试了几件事,但没有任何效果。 我需要这样做,以便能够在加载后使用 reCaptcha 的渲染方法自行渲染它。 require.confi
我可以做些什么来尝试解决之前一直有效但现在在尝试访问 javascript 文件时返回 404 的重新验证码问题。 我不认为这是编码问题,因为他们今天下午就起来了。 值得一提的是,我的两个使用 re-
好的,我们在生产中实现了 Recaptcha。我们收到错误是因为它无法到达使用该服务所需的 IP 地址。我们为 IP 地址打开一个端口以到达 Google。没问题。我们这样做并显式配置该 IP 地址以
我正在使用 Robot Framework + Selenium2Library 为 Web 编写验收测试。关键是 web 包含一些我无法自动化的输入字段 (CAPTCHA),并且我无法告诉我的供应商
我正在尝试实现验证码。我正在使用 jquery (ajax) 调用验证脚本 (http://www.google.com/recaptcha/api/verify)。这将数据类型限制为 JSONP,G
我在站点中使用 scrapy 提交表单 https://www.barefootstudent.com/jobs (任何进入页面的链接等http://www.barefootstudent.com/l
我经营一个游戏网站,所以我有很多用户登录,他们可以每两分钟做一次某些事情。 我在某些地方有一个 CAPTCHA 系统,对于某些东西,它总是要求输入代码,而对于其他东西,它会每 10 分钟询问一次。 我
thinkphp中的验证码是可以直接调用的,非常方便,我们看一下 Think 文件夹下 有一个名为verify.class.php的文件 首先 我们要有一个模
我正在实现一个在注册表单上带有验证码的网站;我的第一次。我已经阅读了数十篇关于支持和反对论点以及所有各种实现的帖子。我对这一切很满意,但对我来说这是必要的邪恶。 我不明白的是为什么人们会在整个网络上的
我正在使用 Sitecore 8 update 3,目前我向 WFFM 表单添加了验证码并按下音频,但显示错误如下: [ArgumentNullException: Value cannot be n
我正在对我已经完成的网络系统部分进行一小部分升级,其中之一是确保我的 Google reCaptcha 的安全性正确。 目前,我使用此代码: //reCaptcha $Url = "https://w
我正在对我已经完成的网络系统部分进行一小部分升级,其中之一是确保我的 Google reCaptcha 的安全性正确。 目前,我使用此代码: //reCaptcha $Url = "https://w
我对制作 3D 验证码很感兴趣,我让它使用一种字体,如下所示: import string from matplotlib.font_manager import findSystemFonts im
大家。我是jquery初学者,想请教几个问题。 我正在为表单提交测试编写一个简单的数学验证码,我想每次按下“重置按钮”时生成一组新的随机数。 但是当我用谷歌搜索解决方案时,大多数人都在尝试重新加载页面
我的网站上有一个验证码,我认为样式被其他一些 css 覆盖了,正如您在下面的验证码底部看到的那样,它有点偏离.. 在 firebug 中发现 CSS 覆盖的最佳方法是什么?已经看了一段时间了,似乎无法
我在 Google Play 上有一个 PNR 查询应用程序。它工作得很好。但最近 Indian Railwys 在他们的 PNR 查询部分添加了验证码,因此我无法将正确的数据传递到服务器以获得正确的
我被指派为 joomla 中的自定义组件创建验证码验证,但我不知道如何正确地完成它。 我知道有许多可用的验证码插件,例如 recaptcha,但我需要使用公司创建的自定义验证码。 它在 session
本文实例讲述了php/JS实现的生成随机密码(验证码)功能。分享给大家供大家参考,具体如下: PHP写法: ?
我正在关注关于电话授权的 React Native firebase 文档 ( https://rnfirebase.io/docs/v5.x.x/auth/phone-auth ),并且对是否需要(
我是一名优秀的程序员,十分优秀!