用Yii框架实现AR类自动记录日志

  1. 定义一个新的AR类MyActiveRecord并继承CActiveRecord类,然后定义日志处理事件RecordLog:
public function RecordLog($objEvent) { 
      //记录日志操作,需要在各个类中各自实现
	}

2. 在类初始化的时候为记录日志事件附加一个事件处理程序,即绑定日志记录事件:

public function init() {
       //绑定日记记录事件
	$this->attachEventHandler(‘onRecordLog‘, array($this, ‘RecordLog‘));
	parent::init();
	}

3. 增加日志记录事件,即在绑定的日志记录事件中触发日志记录事件:

public function onRecordLog($objEvent) {
        $this->raiseEvent(‘onRecordLog‘, $objEvent);
	}

4. 增加记录变更的方法内(insert,update...)调用记录日志的事件,即重写基类的insert,update等方法,在记录更新成功后调用记录日志的事件,完成日志的记录:

public function addLogData($bFlush = false) {
	if($bFlush && $this->hasEventHandler(‘onRecordLog‘)) {
	    $this->onRecordLog(new CEvent($this));
         }
	$this->aLogs = array();
	$this->nLogCount = 0;
	$this->nListId = null;
	$this->sListType = ‘‘;
	$this->nLogUser = null;
	$this->sLogDesc = ‘‘;
	}

重写insert方法:

public function insert($attributes = null) {
	$bIsSuccess = parent::insert($attributes);
	$this->addLogData($bIsSuccess);
	return $bIsSuccess;
	}

这样,其他model类在继承MyActiveRecord类后重写其RecordLog方法后,在更新对应model记录的时候,AR类就会自动记录信息变更的日志,从而保存下日志数据,以便其他程序对日志进行分析利用。

MyRecordRecord类的完整实现:

abstract class MyActiveRecord extends CActiveRecord {
       public function init() {
		//绑定日记记录事件
		$this->attachEventHandler(‘onRecordLog‘, array($this, ‘RecordLog‘));
		parent::init();
	}

	public function insert($attributes = null) {
		$bIsSuccess = parent::insert($attributes);
		$this->addLogData($bIsSuccess);
		return $bIsSuccess;
	}

	public function update($attributes = null) {
		$bIsSuccess = parent::update($attributes);
		$this->flushLogData($bIsSuccess);
		return $bIsSuccess;
	}

	public function flushLogData($bFlush = false) {
		if($bFlush && $this->hasEventHandler(‘onRecordLog‘)) {
			$this->onAddRecordLog(new CEvent($this));
		}
	}

	public function onRecordLog($objEvent) {
		$this->raiseEvent(‘onRecordLog‘, $objEvent);
	}

	public function RecordLog($objEvent) { 
		//记录日志操作,需要在各个类中各自实现
	}
}

用Yii框架实现AR类自动记录日志

时间: 2024-10-11 00:53:02

用Yii框架实现AR类自动记录日志的相关文章

yii框架AR详解

yii框架AR详解 虽 然Yii DAO可以处理事实上任何数据库相关的任务,但很可能我们会花费90%的时间用来编写一些通用的SQL语句来执行CRUD操作(创建,读取,更新和删除). 同时我们也很难维护这些PHP和SQL语句混合的代码,要解决这些问题,我们可以使用Active Record.    Active Record(AR)是一种流行的对象关系映射(ORM)技术.每个AR类代表一个数据表(或视图),其字段作为AR类的属性,一个AR实例代表在表中的 一行.常见的CRUD操作被作为AR类的方法

YII框架分析笔记4:ar模型和db

YII中实现两种类型的模型,分别是表单模型和活动记录.在持久化数据方面,YII只实现了活动记录,对于复杂的数据关系可以用框架提供的DAO来自己写model,对应集成doctrine这样的ORM还没有仔细研究过. ar模型 框架中的model是CModel子类,CModel主要是一些验证与错误处理,并实现迭代器和数组访问接口,活动记录模型CActiveRecord是AR模型的基类. 每个AR类代表一个单独的数据表,一个AR实例则代表那个表中的一行.AR是一种对象关系映射(ORM)的设计模式,它负责

Yii框架分析(二)——CComponent类剖析

Yii是基于组件(component-based)的web框架,CComponent类是所有组件的基类. CComponent类为子类提供了基于属性(property).事件(event).行为(behavior)编程接口. 1.组件的属性(property) Ccomponent类并没有提供属性的变量存储,需要由子类来提供两个方法来实现.子类的getPropertyName()方法提供$component->PropertyName的取值操作数据,子类的setPropertyName($val

Yii 框架里数据库操作详解-[增加、查询、更新、删除的方法 'AR模式']

public function getMinLimit () {        $sql = "...";        $result = yii::app()->db->createCommand($sql);        $query = $result->queryAll();         return array (                $query [0] ['max'],         );    } $connection=Yii::

yii框架之gii创建数据表对应的model类

一.首先是在数据库中建立工程需要的表: 二.然后,配置对应文件: 在工程目录下yiiProject\protected\config\main.php.在50行定义了db应用组件,下面后一段注释掉了的mysql的链接配置项,我们将未注释的db注释掉,然后打开mysql链接代码并填写相关信息即可完成mysql链接配置项. 即,把下面代码         'db'=>array(             'connectionString' => 'sqlite:'.dirname(__FILE_

YII框架源码分析(百度PHP大牛创作-原版-无广告无水印)

                        YII 框架源码分析             百度联盟事业部--黄银锋   目 录 1. 引言 3 1.1.Yii 简介 3 1.2.本文内容与结构 3 2.组件化与模块化 4 2.1.框架加载和运行流程 4 2.2.YiiBase 静态类 5 2.3.组件 6 2.4.模块 9 2.5 .App 应用   10 2.6 .WebApp 应用   11 3.系统组件 13 3.1.日志路由组件  13 3.2.Url 管理组件  15 3.3.异常

YII框架分析笔记1:YII执行流程

yii整体执行流程直观,具体由以下步骤: 1.程序入口文件index.php加载yii框架引导程序(bootstrap)文件yii.php,加载配置文件以及其他自定义配置. 2.yii.php中Yii类继承了YiiBase,主要封装框架的一些通用方法,比如自动加载.创建组件.核心类路径映射.记录日志以及调试等,YiiBase.php中注册自动加载方法.另外Yii类预留可以自定义一些方法作为扩展. 3.回到index.php,Yii::createWebApplication($config),创

yii框架数据库操作数据访问对象(DAO)简单总结

Yii提供了强大的数据库编程支持.Yii数据访问对象(DAO)建立在PHP的数据对象(PDO)extension上,使得在一个单一的统一的接口可以访问不同的数据库管理系统(DBMS).使用Yii的DAO开发的应用程序可以很容易地切换使用不同的数据库管理系统,而不需要修改数据访问代码.Yii 的Active Record( AR ),实现了被广泛采用的对象关系映射(ORM)办法,进一步简化数据库编程.按照约定,一个类代表一个表,一个实例代表一行数据.Yii AR消除了大部分用于处理CRUD(创建,

使用Yii框架中遇到的三个问题

以下由我们在信易网络公司开发项目的时候终结出的一些经验 1.main.php文件中欲引入全局变量的问题 还原一下此问题:在Yii框架中,main.php一般会作为整个应用的配置文件,保存Application的各种参数,直接return数组.在使用的过程中,因为main.php文件一定会被Yii提前加载,所以将一些全局性的操作也放在了此文件,加载一些类操作啥的没有什么问题,当有一次加了一个全局变量,并且在其它地方使用global获取全局变量时,发现无论我如何努力都得到的是NULL.各种尝试后,终