forecho 的独立博客

把生命浪费在美好的事物上

Yii中CLinkPager结合Bootstrap的样式分页

2013年08月09日

$this->widget(‘zii.widgets.CListView’, array( ‘dataProvider’=>$model->search(), ‘itemView’=>’_post’, ‘emptyText’=>’暂时没有数据’,
‘template’=>’{items}{pager}’, ‘pager’ => array( ‘header’=>false, ‘htmlOptions’=>array(‘class’=>’pagination’), ‘selectedPageCssClass’ => ‘active’,
‘hiddenPageCssClass’ => ‘disabled’, // ‘cssFile’=>false, // ‘maxButtonCount’=>25, // ‘selectedPageCssClass’=>’active’, // ‘hiddenPageCssClass’=>’disabled’, // ‘firstPageCssClass’=>’previous’, // ‘lastPageCssClass’=>’next’, // ‘firstPageLabel’=>’«’, // ‘lastPageLabel’=>’»’, // ‘prevPageLabel’=>’<’, // ‘nextPageLabel’=>’>’, ), ‘htmlOptions’=>array(‘class’=>’list-group’), ‘itemsTagName’=>’ol’, ‘itemsCssClass’=>’box-cell’, ‘pagerCssClass’=>’’, )); ?>

yii默认分页默认第一页是不显示首页和前一页的,加上上面的两行加亮代码就能解决这个问题。这样首页和上一页会总是显示。

Yii发邮件插件

2013年08月07日

一、Yii发邮件插件下载。 二,在配置文件/protected/config/main.php中载入组件,代码如下:

'components'=>array(
        'phpMailer'=>array(
            'class'=>'application.extensions.yiimailer.CPhpMailer',
            'host' => 'mail.myhost.com', //比如QQ的是smtp.qq.com
            'port' => 25,
            'from' => 'myname@myhost.com', //发件地址的用户名
            'fromName' => 'myname',//发件人
            'user' => 'username',//发件地址的用户名
            'pass' => 'password',//发件地址的密码
        ),
...

三、然后在控制器写入action,就可以发邮箱了,示例代码:

//发邮件
public function actionSendEmail()
{
    $mailer = Yii::app()->phpMailer->_mailer;
    $mailer->Subject = '人类已经阻止不了我发送邮件了';
    $mailer->Body = '<font color="red">hello, 我是葫芦娃</font>';
    $mailer->AddAddress('caizhenghai@gmail.com');
    //$mailer->AddAddress('xxx@gmail.com');
    $mailer->send();
}

  参考文章:http://www.yiichina.com/forum/topic/1417/ 其他yii发邮件插件以及方法:http://www.yiichina.com/forum/topic/63/

Yii 多表使用一个Model文件

2013年08月03日

表结构一样,现在需要把这些表全部都的数据都查出来,使用一个Model文件。 首先要声明三个私有变量:

private $tableName = 'fr_goods';//默认表名
private static $_models=array();
private $_md;

添加 构造函数:创建和初始化对象成员属性,代码如下:

public function __construct($scenario='search', $tableName = null)
{
    if($tableName !== null)
        $this->tableName = $tableName;
    parent::__construct($scenario);
}

把默认的function tableName() 改为如下:

public function tableName()
{
     return $this->tableName;

}

这个时候你调用的时候,输出tableName的时候,虽然成功了,但是数据还是没有变。 下面我们要改变数据元才行。   把默认生成的 function model(),改成如下代码:

public static function model($tableName = false, $className=__CLASS__)
{
    if($tableName === null) $className=null; // 这个字符串将节省内部CActiveRecord的功能
    if(!$tableName)
        return parent::model($className);

    if(isset(self::$_models[$tableName.$className]))
        return self::$_models[$tableName.$className];
    else
    {
        $model=self::$_models[$tableName.$className]=new $className(null);
        $model->tableName = $tableName;

        $model->_md=new CActiveRecordMetaData($model);
        $model->attachBehaviors($model->behaviors());

        return $model;
    }
}

最关键的是添加下面这行代码:

public function getMetaData()
{
    if($this->_md!==null)
        return $this->_md;
    else
        return $this->_md=static::model($this->tableName())->_md;
}

现在配置完成。下面我们写一个调用的小例子。 下面是Model的function search()代码:

public function search()
{
    // Warning: Please modify the following code to remove attributes that
    // should not be searched.

    $criteria=new CDbCriteria;

    $criteria->compare('id',$this->id,true);
    $criteria->compare('goods_sn',$this->goods_sn,true);
    $criteria->compare('language_ids',$this->language_ids,true);
    $criteria->compare('site_ids',$this->site_ids,true);

    return new CActiveDataProvider($this, array(
        'criteria'=>$criteria,
    ));
}

Controller文件代码如下:

public function actionAdmin()
{
    $model=new KindsGoods('search', 'es_goods');//es_goods表名
    $model->unsetAttributes();  // clear any default values
    if(isset($_GET['KindsGoods']))
        $model->attributes=$_GET['KindsGoods'];

    $this->render('admin',array(
        'model'=>$model,
    ));
}

这个时候输出的结果如果是es_goods表的数据,那就说明你成功了。   参考文章:http://stackoverflow.com/questions/16399561/yii-one-model-for-multiple-tables

Yii Ajax 表单验证

2013年07月30日

先在Views页面的表单开启这个功能:

<?php $form=$this->beginWidget('CActiveForm', array(
    'id'=>'signup-form',
    'enableAjaxValidation' => true,//开启Ajax验证
    'enableClientValidation'=>true,
    'clientOptions'=>array(
        'validateOnSubmit'=>true,
    ),
)); ?>

...

<?php $this->endWidget(); ?>

然后再对应的Controller的action中加入代码:

//注册
public function actionSignup()
{   
    $model = new LoginForm('signup');
    // 开启Ajax验证
    if(isset($_POST['ajax']) && $_POST['ajax']==='signup-form')
    {
        echo CActiveForm::validate($model);
        Yii::app()->end();
    }
    if (isset($_POST['LoginForm'])) {
        $model->attributes=$_POST['LoginForm'];
        if($model->validate()){
            if($model->signup()){ 
               $this->redirect(array('login'));
            }
        }
    }

    $this->render('signup', array('model'=>$model));
}

需要注意的是:表单的ID 名字 要跟控制器中的一样。(此处我的是signup-form ==============补充 2014年01月12日============= 如果想让 ajax 的字段唯一,只需要在 Model 文件的 Rules 方法里面加上下面这行就可以了:

array('name', 'unique'),

Yii Select下拉菜单

2013年07月30日

Yii给下拉菜单一个添加一条数据: 一、不需要默认值

<?php echo $form->dropdownlist(
                    $model,
                    'parent_id',
                    CHtml::listData(Cat::model()->findAll(), 'id', 'name'),
                    array('prompt'=>'根目录')
); ?>

‘prompt’可以换成’empty’ 结果是:

<select name="Cat[parent_id]" id="cat_parent_id">
    <option value="">根目录</option>
    <option value="1">手机</option>
    <option value="2">婚纱</option>
</select>

  二、如果自己的添加的一个Option需要给定Value的话,只能用‘empty’来实现,示例如下:

<?php echo $form->dropdownlist(
                    $model,
                    'parent_id',
                    CHtml::listData(Cat::model()->findAll(), 'id', 'name'),
                    array('empty'=>array('10'=>'根目录'))
); ?>

结果是:

<select name="Cat[parent_id]" id="cat_parent_id">
    <option value="10">根目录</option>
    <option value="1">手机</option>
    <option value="2">婚纱</option>
</select>

  参考资料: http://www.yiichina.com/api/CHtml#activeDropDownList-detail http://stackoverflow.com/questions/16057637/yii-dropdown-list-empty-value-as-default

PHP MySQL Yii更新数据库时 字段值自增

2013年07月30日

PHP MySQL的实现方法是:

update tablename set fieldname = fieldname*2 where ...

Yii基本上有三种实现方法: 一、用save()方法。

//登录一次加5点
$user=User::model()->findByPk(Yii::app()->user->id);
$user->reputation=$user->reputation+'5';
$user->save(); // 将更改保存到数据库

二、用saveCounters方法。(要实现自减,只需把数值改成负数即可)

$postRecord=User::model()->findByPk(Yii::app()->user->id);
$postRecord->saveCounters(array('reputation'=>5));

三、用updateCounters?这个还没有成功,报错貌似是编码问题,待解。   参考资料:http://www.yiiframework.com/wiki/282/using-counters-with-activerecord/

Yii 表添加字段后数据更新不成功

2013年07月28日

情况是这样的,我开始已经用Gii生成了Model文件了,后来又手动添加一个字段,这个字段是info,TEXT类型,不是必填项。 刚开始我是直接在已经生成的Model文件里的rules最后一行代码添加info的,添加之后的代码如下:

public function rules()
{
	// NOTE: you should only define rules for those attributes that
	// will receive user inputs.
	return array(
		array('email', 'required'),
		array('email', 'length', 'max'=>255),
		array('name', 'length', 'max'=>25),
		array('password', 'length', 'max'=>100),
		// The following rule is used by search().
		// Please remove those attributes that should not be searched.
		array('id, email, name, password, info', 'safe', 'on'=>'search'),
	);
}

后来调试了半天,数据就是添加不进去数据库,在Controller的actionUpade时打印数据$_POST[‘User’],能获取到更新后的数据,但是就是添加不了数据库。 最后Google和调试了几次,发现可能是我的info字段没有设置验证规则,虽然不是必填项。后来就试着添加了下面这行代码:

array('info','type','type'=>'string'),

感觉上面这行代码挺别扭的,但是最后结果是成功更新数据到数据库了,事实证明就是这个字段的验证有问题。 后来我又发现了这个rules的safe貌似只是针对search场景的,而我需要的更新数据。 于是代码改成下面这样的了:

public function rules()
{
	// NOTE: you should only define rules for those attributes that
	// will receive user inputs.
	return array(
		array('email', 'required'),
		array('email', 'length', 'max'=>255),
		array('name', 'length', 'max'=>25),
		array('password', 'length', 'max'=>100),
		array('info', 'safe'),
		// The following rule is used by search().
		// Please remove those attributes that should not be searched.
		array('id, email, name, password', 'safe', 'on'=>'search'),
	);
}

测试一下,果然成功了。 最后为了进一步确认一下,我去Gii又生成一个这个表的Model,只是预览一下代码,不生成。对比rules,果然就是改这里。早知道直接用这个方法了。 最后总结一下,yii的表每个字段在rules都要有个验证规则,如果没有验证规则,那就必须要写一个safe。

Ubuntu安装PHP Mongo扩展

2013年07月26日

如果你没有安装PHP的PECL,就先在终端执行下面命令:

sudo apt-get install php5-dev php5-cli php-pear

然后安装命令:

sudo pecl install mongo

找到你的php.ini配置文件,打开(下面是我系统的php.ini文件路径,你需要找到你的配置文件):

vim /etc/php5/fpm/php.ini

手动添加下面这行代码:

extension=mongo.so

重启一下PHP:

sudo service php5-fpm restart

然后查看你的info.php文件(查看PHP配置文件),如果你能搜索到“mongo”,那就说明你安装成功了。