谁一开始就是大神?

PHP 第78页

PHP

控制器中怎么调用模型中声明的函数?[2.0]

GraceFox阅读(118)

我在模型Cate中声明了一个方法:public function showAll(){ return 'a'; },在控制器CateController中,怎么才能调用???

1、把showAll方法增加static声明,然后可以用Cate::showAll()调用
2、或者,先new,再用,既:
在上面添加use app\models\Cate;
再在控制器的方法里调用Cate::showAll();

yii2如何调用电脑摄像头webcam[2.0]

Newcrab阅读(123)

想做一个人员信息管理系统,头像让他们自己提供,可是一直没有找到yii2相关的摄像头。yii1.1.x的倒有几个。比如yii-jpegcam,比如yiigems的photobooth。哪位有好的建议没?先谢谢啦。

最终选择这个 http://www.yiichina.com/topic/5960

这里

这好像需要html5,找不到yii1的可以自己写个嘛,做不成扩展,页面引入后直接调用也行啊。
http://www.gbtags.com/gb/share/93.htm

批量插入的时候,事务不起作用.[2.0]

AibyJames阅读(120)

public function actionImport()
{
    try {
        $columns_keys = [];
        $columns = Yii::$app->db->getTableSchema('_crm_product')->columns;
        foreach ($columns as $column) {
            $columns_keys[$column->comment] = $column->name;
        }
        unset($columns);
        
        // web 目录下
        $pFilename = trim(Yii::$app->request->get('filename'), '/');
        // 先用 Reader_Excel2007 读取
        $PHPReader = new \PHPExcel_Reader_Excel2007();
        // 当前的 Reader_Excel2007 可以阅读该文件吗?
        if (! $PHPReader->canRead($pFilename)) {
            // 再用 Excel5 读取
            $PHPReader = new \PHPExcel_Reader_Excel5();
            // 当前的 Reader_Excel5 可以阅读该文件吗?
            if (! $PHPReader->canRead($pFilename)) {
                return $this->error('无法读取该文件');
            }
        }
        // 载入 xls,xlsx 文件
        $PHPExcel = $PHPReader->load($pFilename);
        // 获得活动表
        $objActiveSheet = $PHPExcel->getActiveSheet();
        // 行迭代器
        $rows = [];
        foreach ($objActiveSheet->getRowIterator() as $row) {
            // 单元格迭代器
            $cellIterator = $row->getCellIterator();
            // 将迭代器设置为只循环存在的单元格, false=不存在
            $cellIterator->setIterateOnlyExistingCells(false);
            foreach ($cellIterator as $key => $cell) {
                if ($row->getRowIndex() == 1) {
                    $columns[] = $columns_keys[$cell->getValue()];
                } else {
                    $rows[$row->getRowIndex()][] = trim($cell->getValue(), '\' ="/');
                }
            }
        }
    } catch (ErrorException $e) {
        return $this->error('错误号:' . $e->getCode() . '<br>错误行:' . $e->getLine() . '<br>错误信息:' . $e->getMessage());
    }
    // 在主服务器连接上开始事务
    $db = Yii::$app->db;
    $transaction = $db->beginTransaction();
    try {
        $queryBuilder = $db->queryBuilder;
        $chunk_rows = array_chunk($rows, 5000);
        $count = 0;
        foreach ($chunk_rows as $chunk_row) {
            $sql = $queryBuilder->batchInsert('_crm_product', $columns, $chunk_row);
            $count += $db->createCommand($sql)->execute();
        }
        $message = '成功导入 <code>' . $count . '</code> 条记录';
        // 提交记录
        $transaction->commit();
        return $this->ok($message);
    } catch (Exception $e) {
        // 记录回滚
        $transaction->rollBack();
        return $this->error('错误号:' . $e->getCode() . '<br>错误信息:' . $e->getMessage());
    }
}

检查是否使用了innodb存储引擎

關於attributes的問題[2.0]

Harryslim阅读(121)

這邊是我 models 的 code

namespace app\models;

use Yii;
use app\models\Api;

class Order_api extends Api
{
    public $account_id;
    public $create_date;
    public $auth_code;

    public function rules()
    {
        return [
            [['account_id','auth_code'], 'required']
        ];
    }

    public function check_params($standard ,$data)
    {
        return parent::check_params($standard ,$data);
    }
}

這邊是 controller 的 code

public function actionTest()
    {	
    	$app_order = [
    		'account_id' => '1',
    		'create_date' => '2',
    		'auth_code' => '3'
    	];
    	$a = new \app\models\Order_api;
    	$a->attributes = $app_order;   <====== 這邊為什麼我把 models 的 public rules() 整個function 移除
    	//$a->account_id = '1';     
    	$a->attributes;    
        var_dump($a);                  <====== 這邊印出來的卻是 每個成員變數都是 NULL
    }

有查看 yii\base\Models attributes() 內部的寫法 他也指示用 ReflectionClass 反映有哪些 public name 而已

想請教 $a->attributes = $app_order; 當我的 models 有 public rules(){ … } 的時候
var_dump($a); 的成員變數是有被賦予值得,但我移除 public rules(){ … }之後成員變數卻都是 NULL
想知道他流程是怎麼跑的為什麼只有 NULL 而沒有值 !!

剛剛沒有看 _set && _get 現在知道怎麼設定了~~~ 希望也可以分享您知道的流程給我參考

$a->attributes = $app_order; 实际调用的是 $a->setAttributes($app_order);
而调用setAttributes方法赋值时, 默认只加载safaAttributes;
所谓的safeAttributes, 指的就是 : 在rules中有声明验证规则的attribute;
这就是rules移掉, 赋值后全是null的原因
所以 : 在rules里面把需要的属性都声明到, 即便是safe也可以.

YII2中的rules规则如何使用[2.0]

Wendybubble阅读(123)

现在我有一个搜索表单,其中有两个属性分别为attr1和attr2,只有当这两个属性的一个属性存在或者都存在的情况下才能执行搜索功能,请问各位大虾这个规则在model中的rules中如何写呢?

我是这样实现的,感觉有些繁琐,同求简洁的解决方案
你可以看下yii2.0的验证规则啊

where条件查询怎么写[2.0]

Wendylemon阅读(132)

两个已经关联的表
表1是hasMany,表2是hasOne,并分别由字段id 与 model_id 相关联
表2内的其中5条记录的字段model_id相同,并与表1内字段id的值相同
在表2的controller条件查询应该怎么写?我想在表2的index下显示出表2内model_id值相同的记录

这个yii也有关联的事例 http://www.yiichina.com/tutorial/96
如果是用ActiveRecord手册有说
如果你要一条sql来查就用
用这个类\yii\db\Query() 手册(类手册)有说
或者写原生sql
\yii::$app->db->createCommand($sql)->queryAll();
这问题有点莫名其妙的。
要查询表2的数据你直接查就好了。。要model_id一样 你条件直接model_id=多少,你传进去就好了。。。
要所有根据表1的id分组,你直接查表1,然后用你的hasMany就好了。每个hasMany查出来的就是model_id相同的一类了。
没看明白想说啥!

findbyusername义[2.0]

HaHfans阅读(110)

在登录的时候,使用这个静态方法,但是提示未定义

Yii::$app->user->login(static::findByUsername($this->username))

请问是因为我继承的不对吗?还是什么问题

这个方法是要自己写的~
下面是模版中的方法:
如果你使用数据库,可以用User::findOne(['username'=>$username])

Yii2微信请求配置的URL只能在index.php中取得数据,不分发到所的控制器[2.0]

Jasonelephant阅读(139)

Yii2 微信请求填写的URL的时候,我在入口文件(index.php),可以获取发送来的数据,并可以在log中查看到数据。但是发现没有分发到URL所指的控制器方法中。我在控制器方法里面获取不到数据,log也没有数据,请高手帮下忙,看下怎么回事

遇到这种情况,是因为 Yii2 的防止 csrf 攻击,你则不能多次提交相同的表单。如果你希望当前可以多次重复提交,可以在当前提交的表单 controller 中添加
我遇到的情况和你一模一样,捣鼓了一天才弄出来,你试试吧
可以直接在控制器中获取数据。你在腾讯的“微信公众平台”管理页面的“开发者中心”“配置项”指定url、token的地方,url那里填你的完整路由就好了。
可以在index.php上获取数据,那么在控制器中也是可以获取的,这个是全局的。
如你所说,获取不到,
原因可能是你访问url有问题,是不是没有访问到你的控制器里面动作。
可以看下生成的log。
index.php 后 写人session里,全局调用, 如果写不进去就是字符编码问题,或者解析json有问题.

YII2.0数据库无主键,无法保存数据[2.0]

JadeLion阅读(116)

数据字段中,没有主键字段,(因为不需要),在插入数据的时候,会提示数据无主键,请问rules需要怎么设置才可以不验证主键

Note that an array should be returned even for a table with single primary key.
上面一句是注释, 要求返回数组格式;
另外一个小小建议, 最好还是保留一个主键, 即使不需要;

登录

找回密码

注册