Yii框架自定义数据库操作组件示例_php实例_脚本之家

本文实例讲述了Yii框架自定义数据库操作组件。分享给大家供大家参考,具体如下:

本文讲述了yii2高级应用之自定义组件实现全局使用图片上传功能的方法。分享给大家供大家参考,具体如下:

Yii 的数据库操作对象提供的方法确实很方便。
但是有的时候我们已经习惯了我们以前编写php的数据库操作语法,没有那么多时间去仔细看每个Yii提供的数据库操作语法,怎么办呢?
那就是一边学习,一边二次封装自己习惯的数据库操作类。
以后我们使用数据库操作对象,就用我们自己定义的组件去操作。

此例为yii2高组应用,这里只提供一个简单的事例

将我的数据库操作组件注册进配置文件web.php 中

在yii2中,在使用到上传图片时有自带的一个上传图片类,但不太好用。

array( 'components' => array( //自定义数据库操作组件 'dbOper' => array( 'class' => 'app\components\DbOper\realization\DbRealization1' ), //Yii 框架数据库连接组件 'db' => array( 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=localhost;dbname=yii', 'username' => 'root', 'password' => '123456', 'charset' => 'utf8' ); ))

其中有一种方式,把自己写的一个上传图片类文件,注册成一个组件,在全局中使用。

然后我们就可以在components 目录下定义我们的数据库操作类了。
因为,不知道怎么去获得php pdo
的原生操作对象,所以这里是对Yii数据库操作类的一个二次封装。

这里,我只作一个简单的自定义组件介绍

接口文件 DbOper.php 自定义的数据库操作类都得实现该接口

1、在backend定义一个 upload.php(注意路径: backend/components)

针对DbOper 接口的实现类 DbRealization1.phpgetQueryObj->queryAll return $result; else return array(); } /** * interface @Override */ public function fetch($sql='',$keyVal=array return array(); $result = $this->getQueryObj->queryOne return $result; else return array(); } /** * interface @Override */ public function insert($tableName='',$values=array { if return 0; $insert = $this->getYiiDbConnection; if { $keys = array_keys; return $insert->batchInsert($tableName,$keys,$values)->execute(); } return $insert->insert->execute(); } /** * interface @Override */ public function update($tableName='',$where = '',$update=array { if return 0; if return 0; return $this->getYiiDbConnection ->update($tableName,$update,$where) ->execute(); } /** * interface @Override */ public function delete($tableName='',$where='') { if return 0; return $this->getYiiDbConnection ->delete ->execute(); } /** * 获得查询操作对象 * @return * Object */ private function getQueryObj($sql='',$keyVal=array { $query = $this->getYiiDbConnection()->createCommand; if $query->bindValues; return $query; } /** * interface @Override */ public function transcation { if return false; $db = $this->getYiiDbConnection(); $outerTransaction = $db->beginTransaction(); $runClient = true; try { foreach { $db->createCommand; } $outerTransaction->commit(); }catch{ $runClient = false; $outerTransaction->rollback(); } return $runClient; } /** * interface @Override */ public function getYiiDbConnection() { if { $this->db = Yii::$app->db; } return $this->db; }}
//图片上传处理类//upload.php事例代码namespace backend\components;class Upload{ public function test(){ $a = '你好'; return $a; }}

注意:我的自定义数据库操作类 依赖 Yii::$app->db 这个组件,
也就是框架自带的数据库连接组件

2、backend/config/main.php 注册刚写的自定义组件

然后我们就可以通过 Yii::$app->dbOper 去操作数据库了。

'components' => [ 'imgload' => [ 'class' => 'backend\components\Upload' ],]

public function actionArticlelist(){ $cc = Yii::$app->imgload->test;exit;}

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

那么,一个完整的图片上传组件这里就不写了。

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

这里只写了一个使用自定义组件的方法!

1、自定义组件,便于全局使用。backend/config/main.php

'components' => [ 'user' => [ 'identityClass' => 'common\models\AgMerch', 'enableAutoLogin' => true, ], //自定义图片上传类 'imgload' => [ 'class' => 'agent\components\Upload' ],]

2、自定义图片上传类 backend/components/Upload.php

namespace agent\components;use yii;use yii\base\Object;use yii\web\UploadedFile;class Upload extends Object{ /** * [UploadPhoto description] * @param [type] $model [实例化模型] * @param [type] $path [图片存储路径] * @param [type] $originName [图片源名称] * @param boolean $isthumb [是否要缩略图] */ public function UploadPhoto($model,$path,$originName,$isthumb=false){ $root = $_SERVER['DOCUMENT_ROOT'].'/'.$path; //返回一个实例化对象 $files = UploadedFile::getInstance; $folder = date."/"; $pre = rand; if($files && ($files->type == "image/jpeg" || $files->type == "image/pjpeg" || $files->type == "image/png" || $files->type == "image/x-png" || $files->type == "image/gif")) { $newName = $pre.'.'.$files->getExtension(); }else{ die; } if($files->size > 2000000){ die; } if(!is_dir { if(!mkdir($root.$folder, 0777, true)){ die; }else{ // chmod; } } //echo $root.$folder.$newName;exit; if($files->saveAs($root.$folder.$newName)) { if{ $this->thumbphoto($files,$path.$folder.$newName,$path.$folder.'thumb'.$newName); return $path.$folder.$newName.'#'.$path.$folder.'thumb'.$newName; }else{ return $path.$folder.$newName; } } }}

use backend\components\Upload;public function actionArtadd(){ $model = new Article(); if ($model->load(Yii::$app->request->post { //cover为表中的字段名 $img = Yii::$app->imgload->UploadPhoto($model,'uploads/article/','cover'); $model->cover = $img;//存入表中 if{ Yii::$app->getSession()->setFlash; return $this->redirect; }else{ Yii::$app->getSession()->setFlash; @unlink; return $this->redirect; } } //代码略}

field($model, 'cover', [ 'options'=>['class'=>''], 'inputOptions' => ['class' => 'form-control'],])->fileInput; ?>

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

发表评论

电子邮件地址不会被公开。 必填项已用*标注