一.创建数据库
1.创建youme数据库,添加ym_cate数据表.包括:
id,catename,keywords,desc,type
字段
2.配置
D:\www\youme
文件夹下的database.php
数据库文件
return [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => 'youme',
// 用户名
'username' => 'root',
// 密码
'password' => 'root',
// 端口
'hostport' => '',
// 连接dsn
'dsn' => '',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => 'ym_',
// 数据库调试模式
'debug' => true,
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
// 自动读取主库数据
'read_master' => false,
// 是否严格检查字段是否存在
'fields_strict' => true,
// 数据集返回类型
'resultset_type' => 'array',
// 自动写入时间戳字段
'auto_timestamp' => false,
// 时间字段取出后的默认时间格式
'datetime_format' => 'Y-m-d H:i:s',
// 是否需要进行SQL性能分析
'sql_explain' => false,
];
二.添加数据
1.如果你在database.php配置文件中配置了数据库前缀(prefix),那么可以直接使用 Db
类的 name
方法提交数据
Db::name('user')->insert($data);
insert 方法添加数据成功返回添加成功的条数,insert 正常情况返回 1
2.配置D:\www\youme\application\admin\controller
文件夹下的Cate.php
控制器文件.
public function add()
{
if(request()->isPost()){
$data=[
'catename'=>input('catename'),
'keywords'=>input('keywords'),
'desc'=>input('desc'),
'type'=>input('type') ? input('type'):0,
];
$db= \think\Db::name('cate')->insert($data);
if($db){
return $this->success('添加栏目成功! ','lst');
}
else{
return $this->success('添加栏目失败! ');
}
return;
}
return $this->fetch("add");
}
三.验证数据
1.构造一个验证器,对添加的数据进行验证:
ThinkPHP5.0验证使用独立的\think\Validate
类或者验证器进行验证。
2.验证规则
(1)对于一个字段可以设置多个验证规则,使用|
分割。
(2)或者采用数组方式定义多个规则(适用于你的验证规则中有|的情况)
(同一字段验证用
|
分割,不同字段用数组方式
分割)
通常情况下,我们实际在定义验证类的时候,可以通过属性的方式直接定义验证规则等信息,例如:
namespace app\index\validate;
use think\Validate;
class User extends Validate
{
protected $rule = [
'name' => 'require|max:25',
'age' => 'number|between:1,120',
'email' => 'email',
];
protected $message = [
'name.require' => '名称必须',
'name.max' => '名称最多不能超过25个字符',
'age.number' => '年龄必须是数字',
'age.between' => '年龄只能在1-120之间',
'email' => '邮箱格式错误',
];
}
3.在D:\www\youme\application\admin
文件夹下新建validate
文件夹,并在D:\www\youme\application\admin\validate
文件夹下新建Cate.php
文件.
添加如下验证规则:
<?php
namespace app\admin\validate;
use think\Validate;
class Cate extends Validate
{
protected $rule = [
'catename' => 'require|max:25|unique:cate',
];
protected $message = [
'catename.require' => '栏目名称不能为空! ',
'catename.unique' => '栏目名称不能重复! ',
];
}
3.实例化验证器类的方法:$validate = Loader::validate('User');
4.在D:\www\youme\application\admin\controller
文件夹下的Cate.php
文件中,对验证器进行实例化.
public function add()
{
if(request()->isPost()){
$data=[
'catename'=>input('catename'),
'keywords'=>input('keywords'),
'desc'=>input('desc'),
'type'=>input('type') ? input('type'):0,
];
$validate = \think\Loader::validate('Cate');
if($validate->check($data)){
$db= \think\Db::name('cate')->insert($data);
if($db){
return $this->success('添加栏目成功! ','lst');
}
else{
return $this->success('添加栏目失败! ');
}
}
else{
return $this->error($validate->getError());
}
return;
}
return $this->fetch("add");
}