ThinkPHP 自动创建数据、自动验证、自动完成详细例子介绍(十九)

原文:ThinkPHP 自动创建数据、自动验证、自动完成详细例子介绍(十九)

1:自动创建数据

//$name=$_POST['name'];
//$password=$_POST['password'];  ---这个注册页面传过来的POST值
      下面用了自动穿件create方法就可以不用这个,会行动绑定
$user =M('User');
$User->create();   //会将传过来的$_POST数据对应到数据库的字段
$user->add();   //就可以直接写入

2:自动验证(只需要在Model类里面定义$_validate属性)

使用步骤(注册验证User表)

一:创建User表自定义的Mode  --->Home\Lib\Model\UserModel.class.php
<?php
//注意:code username password....都是你表单里面的name值,要对应
//表单里面字段名字定义的
class UserModel extends Model{
protected $_validate=array(
array('code','require','验证码必须填写!'),
array('code','checkCode','验证码错误!',0,'callback',1),  //使用回调函数checkCode
array('username','require','用户必须填写!'),
array('username','','用户已经存在',0,'unique',1),
array('username','/^\w{6,}$/','用户名必须6个字母以上',0,'regex',1),
array('repassword','password','确认密码不正确',0,'confirm'), 
);

protected function
checkCode($code){
if(md5($code)!=$_SESSION['code']){
return false;
}else{
return true;
}
}
}
?>

//控制请值对应的注册方法
<?php
class RegisterAction extends Action{
public function doReg(){

$user=D('User');  //大D方法是会先去找你自定义的Mode,(使用上面创建的UserModel.class.php类)
                //如果有有自定义的用自定义的,否则用原始的  D等同M   M!=D
 
if(!$user->create()){//会自动去验证  返回一个布尔类型,成功则自动创建数据
$this->error($user->getError());//获取具体错误信息
}
$lastId=$user->add();
if($lastId){
$this->redirect('Index/index');
}else{
$this->error('用户注册失败');
}

}
}
?>

3:自动完成(做留言的例子)
步骤:
一:创建Message表自定义的Mode  --->Home\Lib\Model\MessageModel.class.php
<?php
class MessageModel extends RelationModel{
protected $_auto=array(
array('time','time',1,'function'),
array('uid','getId',1,'callback')

);
protected function
getId(){
return $_SESSION['id'];
}
}
?>
        二:控制器中
<?php
class MessageAction extends Action{
public function doLiuyan(){
$message=D('Message');
//$message->time=time();
//$message->uid=$_SESSION['id'];   这2个值将在自定义MessageModel中自动填充完成

$message->add(); //返回值是新增的id号
}
}
?>

时间: 2024-10-26 07:03:05

ThinkPHP 自动创建数据、自动验证、自动完成详细例子介绍(十九)的相关文章

sqlserver2005自动创建数据表和自动添加某个字段索引_mssql2005

创建数据表的SQL语句如下: string tatlename = "T_useruid";//定义一个变量.用于自动创建数据表的名称,当前表名为:T_useruid string sql = "CREATE TABLE [dbo].[" + tatlename + "]([Cid] [int] IDENTITY(1,1) NOT NULL,[Uid] [nchar](32) COLLATE Chinese_PRC_CI_AS NULL,CONSTRAIN

设备文件自动创建 权限

问题描述 设备文件自动创建 权限 使用device_create()自动创建设备文件的时候 生成出来的设备文件 权限只有root用户可以 使用,请问该怎么修改? 请大神赐教,不胜感激!! 解决方案 自动创建设备文件自动创建设备文件自动创建设备文件

ThinkPHP中的create方法与自动令牌验证实例教程_php实例

本文实例形式展示了ThinkPHP中的create方法与自动令牌验证的实现方法,具体步骤如下: 一.数据表结构 user表结构如下: id username password 二.view模板部分 \aoli\Home\Tpl\default\User\create.html页面如下: <form action="__URL__/addit" method="post"> <input type="text" name=&quo

ThinkPHP 3.1快速入门:自动验证

自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证. 验证规则 数据验证可以进行http://www.aliyun.com/zixun/aggregation/18278.html">数据类型.业务规则.安全判断等方面的验证操作.数据验证有两种方式:静态方式:在模型类里面通过$_validate属性定义验证规则.动态方式:使用模型类的validate方法动态创建自动验证规则.无论是什么方式,验证规则的定义是统一的规则,定义格式为

为ROS创建的资源自动挂载数据盘

为ROS创建的资源自动挂载数据盘 通过ROS可以方便创建,管理资源.例如自动挂载数据盘,如果是通过阿里云的官方镜像,使用ROS创建ECS资源,UserData可以很容易的帮你完成这一步,详细内容可以参考这篇文章:但是如果你使用自己制作的镜像,而且自己制作的镜像不支持UserData功能怎么办呢,这篇文章帮你解决你的问题. 要完成自有镜像自动挂载数据盘,只需要三步: 1.制作镜像前,把下面的这个脚本拷贝到你将要制作镜像的ECS机器上,例如:/usr/local/bin/mount_disks下面.

【C/C++学院】0814-引用高级、引用高级增加/auto自动变量自动根据类型创建数据/Bool/Enum/newdelete全局/大数据乘法与结构体/函数模板与auto/宽字符本地化/inline

引用高级.引用高级增加 #include<iostream> #include<stdlib.h> // int a[10] // int (&ra)[10] // int a[2][5] // int (&ra)[2][5] void main1() { int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; int(&ra)[10](a);//引用就是给原来的变量有一个别名同一个地址 int i = 0; for (

ThinkPHP 3.1快速入门:自动完成

自动完成是ThinkPHP提供用来完成数据http://www.aliyun.com/zixun/aggregation/18860.html">自动处理和过滤的方法,使用create方法创建数据对象的时候会自动完成数据处理.因此,在ThinkPHP使用create方法来创建数据对象是更加安全的方式,而不是直接通过add或者save方法实现数据写入. 规则定义 自动完成通常用来完成默认字段写入,安全字段过滤以及业务逻辑的自动处理等,和自动验证的定义方式类似,自动完成的定义也支持静态定义和动

如何识别真实和自动创建的索引?

创建|索引 问:我发现sysindexes索引表中的很多条目并不是我自己创建的.听说它们并不是真正的索引,而是SQL Server查询优化器自动创建的统计.怎样才能识别哪些是真正的索引,哪些是SQL Server自动创建的统计呢? 答:按照默认设置,如果表中的某列没有索引,则SQL Server会自动为该列创建统计.然后,查询优化器评估该列中数据分布范围的统计信息,以选择一个更为有效的查询处理方案.分辨自动创建的统计很简单,在SQL Server 7.0和SQL Server 2000中,自动创

如何按时间自动创建Oracle 11g分区表

11g新特性_分区表按时间自动创建(Interval Partitioning(MONTH.YEAR)) Interval Partitioning(MONTH.YEAR) create table sales6 ( sales_id    number, sales_dt    date ) partition by range (sales_dt) interval (numtoyminterval(1,'MONTH')) ( partition p0701 values less than