thinkphp验证器
验证器类:$validate=new \think\Validate($rule,$message,$field); 注意:开启表单令牌后需要验证它哦
独立验证:
//独立验证
$rule=[
'name' => 'require|max:25',
'email' => 'email'
]
$msg=[
'name.require' => '名称必须',
'name.max' => '名称最多不能超过25个字符',
'email' => '邮箱格式错误',
];
$field = [
'name' => '名称',
'email' => '邮箱',
];
$validate = new Validate($rule,$msg,$field);
$data = [
'name' => 'thinkphp',
'email' => 'thinkphp@qq.com'
];
if (!$validate->check($data)) {
dump($validate->getError());
}
make、rule、extend、setTypeMsg、message、scene、hasscene、batcch、check、getError
验证器:定义在模块下的validate文件夹内;
注意:Call to undefined function mb_strlen() :开启:extension=php_mbstring.dll; 还不行就就看看这extension_dir = "ext";还不行就绝对路径
前台页面
<form action="{:url('addFormData')}" method="post">
<input type="text" name="name" value="thinkphp">
<input type="text" name="email" value="thinkphp@qq.com">
<input type="text" name="zip" value="888888">
<input type="text" name="age" value="20">
<input type="text" name="status" value="2">
{:token('__token__', 'sha1')}
<input type="submit" value="提交">
</form>
控制器:
<?php
namespace app\index\controller;
use think\Controller;
class Test extends Controller{ public function index()
{ return $this->fetch('index@/Test/index');
} public function addFormData(\think\Request $request)
{ $name=$request->post('name');
$email=$request->post('email');
$zip=$request->post('zip');
$age=$request->post('age');
$status=$request->post('status');
$token=$request->post('__token__'); $data = [
'name'=>$name,
'email'=>$email,
'zip'=>$zip,
'age'=>$age,
'status'=>$status,
'__token__'=>$token
]; $validate = \think\Loader::validate('test');//or $validate = validate('test');
//实例化后还可以动态添加规则 他将合并到Test验证rule属性里
$validate->rule([
'zip' => '/^\d{6}$/',
'status'=> 'number|between:0,2'
]);
//实例化后还可以动态添加错误信息 他将合并到Test验证$message属性里
$validate->message([
'zip'=>'邮编格式不正确',
'status.between'=>'状态超出取值范围',
'status.number'=>'状态数据类型错误',
]);
//实例化后可以动态添加自定义的验证字段描述
$validate->addField([
'zip'=>'邮编',
'status'=>'状态',
]); if(!$validate->check($data)){
dump($validate->getError());
}
}
}
验证器:
<?php
namespace app\index\validate; use think\Validate; class Test extends Validate
{
//定义验证规则 |和数组都可以
protected $rule = [
'name' => 'require|max:25',
'email' => 'email',
'age' => ['number','between'=>'1,120'],
'__token__'=>'token'
]; //定义错误信息
protected $message = [
'name.require' => '名称必须',
'name.max' => '名称最多不能超过25个字符',
'age.number' => '年龄必须是数字',
'age.between' => '年龄只能在1-120之间',
'email' => '邮箱格式错误',
];
//定义验证字段描述
protected $field=[
'name' => '名称',
'age' => '年龄',
'email' => '邮箱',
]; //定义场景(后面根数组是重新定义规则)
protected $scene = [
'edit' => ['name','email','age'=>'require|number|between:1,120'],
]; /**
* 自定义动态添加验证字段描述
*/
public function addField($name,$field='')
{
if (is_array($name)) {
$this->field = array_merge($this->field, $name);
} else {
$this->field[$name] = $field;
}
return $this;
} }
THINKPHP 防止重复提交表单 自己动手制作表单令牌token
function.php
//创建TOKEN
function creatToken() {
$code = chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE));
session('TOKEN', authcode($code));
} //判断TOKEN
function checkToken($token) {
if ($token == session('TOKEN')) {
session('TOKEN', NULL);
return TRUE;
} else {
return FALSE;
}
} /* 加密TOKEN */
function authcode($str) {
$key = "ANDIAMON";
$str = substr(md5($str), 8, 10);
return md5($key . $str);
}
html form
<form action="{:U()}" method="post" class="form-horizontal">
<input type="hidden" name="TOKEN" value="{:session('TOKEN')}">
...
</form>
1.在页面展示前调用creatToken()方法生成token。
2.在相应控制器POST请求中 使用 checkToken() 进行判断是否重复提交。
if(IS_POST){
//防止重复提交 如果重复提交跳转至相关页面
if (!checkToken($_POST['TOKEN'])) {
$this->redirect('index/index');
return;
}
//下面相关业务代码
}else{
//创建token
creatToken();
$this->display();
}
thinkphp验证器的更多相关文章
- ThinkPHP验证器验证规则编码要点
首先验证器要继承框架的think\Validate类. 1.验证规则是一个父类的rule属性,是一个数组. 2.数组的键名是验证字段标识,值是验证规则.多个验证规则要用|分隔,不能有空格,否则可能会验 ...
- m_Orchestrate learning system---十三、thinkphp的验证器支持多语言么
m_Orchestrate learning system---十三.thinkphp的验证器支持多语言么 一.总结 一句话总结:支持,不仅验证器支持,其它的插件应该都支持 不仅thinkphp支持多 ...
- 9、 Struts2验证(声明式验证、自定义验证器)
1. 什么是Struts2 验证器 一个健壮的 web 应用程序必须确保用户输入是合法.有效的. Struts2 的输入验证 基于 XWork Validation Framework 的声明式验证: ...
- linux上使用google身份验证器(简版)
系统:centos6.6 下载google身份验证包google-authenticator-master(其实只是一个.zip文件,在windwos下解压,然后传进linux) #cd /data/ ...
- vue-validator(vue验证器)
官方文档:http://vuejs.github.io/vue-validator/zh-cn/index.html github项目地址:https://github.com/vuejs/vue-v ...
- 原生JS 表单提交验证器
转载:http://www.cnblogs.com/sicd/p/4613628.html 一.前言 最近在开发一个新项目,需要做登陆等一系列的表单提交页面.在经过“缜密”的讨论后,我们决定 不用外部 ...
- yii框架中验证器声明一组内置验证器可以使用短名称引用
1.内置验证器的短名称分别有: boolean: yii\validators\BooleanValidator captcha: yii\captcha\CaptchaValidator compa ...
- 通过Google身份验证器加强Linux帐户安全
下载Google的身份验证模块: # wget https://google-authenticator.googlecode.com/files/libpam-google-authenticato ...
- 谷歌身份验证器加强Linux帐户安全
下载 Google的身份验证模块 # wget https://google-authenticator.googlecode.com/files/libpam-google-authenticato ...
随机推荐
- Codeforces 671D Roads in Yusland [树形DP,线段树合并]
洛谷 Codeforces 这是一个非正解,被正解暴踩,但它还是过了. 思路 首先很容易想到DP. 设\(dp_{x,i}\)表示\(x\)子树全部被覆盖,而且向上恰好延伸到\(dep=i\)的位置, ...
- 相关子查询和嵌套子查询 [SQL Server]
SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提,假设Books表如下: 类编号 图书名 出版社 价格-------------- ...
- Confluence 6 白名单允许进入和禁用
允许进入 启用 CORS 请求,将会从特定的 URL 来源中允许进入(Allow Incoming).URL 格式必须匹配格式 scheme://host[:port],结尾是没有反斜杠的(:port ...
- Confluence 6 修改日志文件的目标位置
在 log4j 中,一个输出被定义为 'appender'.希望修改 log 文件的目标,你需要停止 Confluence 然后修改设置 log4j.properties 日志配置文件的 'Logg ...
- Confluence 6 home 修改 Home 目录的位置
当 Confluence 第一次启动的时候,Confluence 将会读取 confluence-init.properties 文件并从这个文件中确定如何去查找 Home 目录. 希望修改 home ...
- Confluence 6 配置自动备份
希望配置 Confluence 备份: 进入 > 基本配置(General Configuration) > 备份管理(Backup administration). 选择 编辑(Edi ...
- Git- 命令及使用
关于Git相关介绍这里就不介绍了,可转<Git- 简介>或者查看官网信息.这篇整理一下git相关的命令. 1) 远程仓库相关命令 克隆下载仓库:$ git clone git://gi ...
- 手机端rem 用法
!function(n){ var e=n.document, t=e.documentElement, i=720, d=i/100, o="orientationchange" ...
- Python之函数(自定义函数,内置函数,装饰器,迭代器,生成器)
Python之函数(自定义函数,内置函数,装饰器,迭代器,生成器) 1.初始函数 2.函数嵌套及作用域 3.装饰器 4.迭代器和生成器 6.内置函数 7.递归函数 8.匿名函数
- 伪Ap接入点
1.创建一个伪造的Ap接入点,必须购买一个无线网卡的设备,接受功率在300Mbps ,低于这个传输速率的值,效果很差,都达到用户可以连接验证的效果.其芯片必须支持kali linux 内核系统. 2. ...