# thinkphp5.0内置的验证登录的方法
## 代码使用如下:
~~~
public function reqister(Request $request){
$rule=['username'=>'require|length:6,12','email'=>'require']; //reqyure为非空的意思 length为字符串长度的意思 username email为html提交来的表单名称
$validate= new Validate($rule); //实例化Validate
$data=$request->param(); //获取输入的POST值
if(!$validate->check($data)) { //判断如果为假,输出验证失败的信息
$this->success($validate->getError(),'/index'); //验证失败后跳转到首页
}
else{
dump('验证成功'); //验证成功后
}
}
~~~

## 自定义验证规则

## 自定义的验证方法用正则表达式
~~~
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
use app\index\model\Maik;
use think\Session;
use think\Cookie;
use think\Validate;
use think\Request;
class Index extends Controller
{
public function index(){
return $this->fetch();
}
public function reqister(Request $request){
$rule=['username'=>'\w{4}','email'=>'require|email']; //自定义条件用正则方法 $rule为内置的变量不能改名
$message=['username'=>'用户名长度必须是4位',
'email.require'=>'邮箱不能为空', //自定义错误数组 //$message为内置的变量不能改名
'email.email'=>'邮箱格式不正确'
];
$validate= new Validate($rule,$message); //实例化Validate
$data=$request->param(); //获取输入的POST值
if(!$validate->check($data)) { //判断如果为假,输出验证失败的信息
$this->success($validate->getError(),'/index'); //验证失败后跳转到首页
}
else{
dump('验证成功'); //验证成功后
}
}
}
~~~
## 自定义截图:

## index.html里文件
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="reqister" method="post">
用户名: <input type="text" name="username">
邮箱: <input type="text" name="email">
<button>注册</button>
</form>
</body>
</html>
~~~
Route路由里:
```
Route::post('reqister','index/index/reqister');
```
## 内置验证规则
https://www.kancloud.cn/manual/thinkphp5/129356
- 文件作用与框架文件说明
- 助手函数
- 系统常量(常用与自定义)
- 自定义配置文件extra(文件夹)
- 自定义配置文件.Env
- 路由pathinof 方式
- 路由强制模式(主要用这个)
- 路由的请求方法几种常用
- 路由参数规则设置
- 路由分组闭包与MISS路由
- 资源路由
- 请求Request和参数过滤
- session和cookie的配置及获取
- 判断路由请求类型及Request注册方法
- 响应数据方法create
- json xml jsonp助手函数
- 改命名空间(改成自定义的)
- (controller里常用的方法)success与error重定向的使用nignx重写的配置
- _initialize构造函数
- beforeAction前置操作使用
- 空路由与多级控制器使用
- 连接数据库操作(ORM)
- 助手函数db()
- 插入数据库操作(ORM)
- 查询数据库操作(ORM)
- (链式语法)where条件查询数据库(ORM)
- (链式语法)只查询某个字段或者排除某个字段链式操作field(ORM)
- (链式语法)排序查询order(ORM)
- (链式语法)查询条数limit(ORM)
- (链式语法)查询多条重复数据只返回一个distinct方法查询(ORM)
- (链式语法)获取mysql语句fetchSql(ORM)
- (链式语法)查询改表名输出alias(ORM)
- 连表查询join() (ORM)
- 数据库事务监听(ORM)
- (改数据)更新数据库(ORM)
- (改数据)更新数据库之自增与自减(ORM)
- 链式操作语法(ORM)
- (删除数据)删除数据(ORM)
- model模型创建方法
- (增)插入数据(Model)
- (查)查询数据(Model)
- 关于类 (杂项整理)
- (查)动态查询数据(Model)
- (改)更新数据库(Model)
- (删)删除数据(Model)
- 数据表时间戳(Model)
- view视图创建与渲染模板
- view视图输出与调用
- view输出常量与Session 与Cookie值
- view输出函数以及过滤
- view视图循环输出与if判断
- view各项配置以及修改(自定义资源路径)
- view各项配置以及修改(修改模板起始符)
- view 模板引入和自定义配置
- view模板继承
- thinkphp 实战命令行生成模块控制器模型视图
- Validate登录验证使用方法
- Validate验证场景分离写法
- Validate令牌验证
- captcha验证码配置
- 图片以及文件上传
- 资源路由下URL语法拼接模板循环的ID
- view三元运算符
- POST下的PUT请求(安全方法)
- 路由重定向
- 常见问题解决
- config文件
- 模板里使用路由路径
- 原生PHP在thinkphp中拓展
- 公共函数文件
- 5.1与5.0区别
- 5.1路由区别
- 5.1中间件
- 5.1微信支付
