我想安排在yii中运行console命令。 我编写了PHP脚本并在web-app中尝试过 - 效果很好。 然而,当我把它作为console command时,cron发送以下消息:
PHP Error[2]: include(User.php): failed to open stream: No such file or directory
in file /home/srv50213/htdocs/framework/YiiBase.php at line 427
#0 /home/srv50213/htdocs/framework/YiiBase.php(427): autoload()
#1 unknown(0): autoload()
#2 /home/srv50213/htdocs/doc/protected/commands/ReportMailerCommand.php(20): spl_autoload_call()
#3 unknown(0): ReportMailerCommand->actionIndex2()
#4 /home/srv50213/htdocs/framework/console/CConsoleCommand.php(172): ReflectionMethod->invokeArgs()
#5 /home/srv50213/htdocs/framework/console/CConsoleCommandRunner.php(71): ReportMailerCommand->run()
#6 /home/srv50213/htdocs/framework/console/CConsoleApplication.php(92): CConsoleCommandRunner->run()
#7 /home/srv50213/htdocs/framework/base/CApplication.php(180): CConsoleApplication->processRequest()
#8 /home/srv50213/htdocs/framework/yiic.php(33): CConsoleApplication->run()
#9 /home/srv50213/htdocs/doc/protected/yiic.php(8): require_once()
似乎autoload()无法正常运行。 对于控制台app $ config,我使用config / console.php,其中我插入了数据库设置(来自main.php和用户设置)。
'components'=>array(
'db'=>array(
// настройки для конфигурации
'connectionString' =>
'mysql:host=localhost;dbname=xxx',
'emulatePrepare' => true,
'schemaCachingDuration' => 3600,
'username' => 'xxx',
'password' => 'xxx',
'charset' => 'utf8',
'tablePrefix' => 'yiiapp_',
'class' => 'CDbConnection'
),
'user'=>array(
'class' => 'WebUser',
//'class' => 'application.components.User',
// enable cookie-based authentication
'allowAutoLogin'=>true,
),
)
脚本是smth。像这样:
public function actionIndex2($args)
{
$users = User::model()->findAllByPk( array(177) );
foreach($users as $user)
{
$query = "SELECT e.id, e.Subject
FROM `yiiapp_doc_events` AS e
LEFT JOIN `yiiapp_doc_event_users` AS u ON e.id = u.eventId
WHERE e.StatusId NOT IN (5,7)
AND u.userId = {$user->id}
GROUP BY e.id";
$queryResult = Yii::app()->db->createCommand($query)->queryAll();
if ($queryResult)
{
foreach($queryResult as $res)
{
$i++;
$link = Yii::app()->createAbsoluteUrl('docEvents/update', array('id'=>$res['id']));
$table .= "<tr><td> {$i} </td><td> <a href='{$link}'>{$res['id']}</a> </td><td> <a href='{$link}'>{$res['Subject']}</a> </td></tr>";
}
//echo $table . '</table>';
$content= " $table . '</table>';
mail($user->email, "Report (". $i . ')', $content, 'Content-type: text/html');
}
}
}
怎么了,怎么解决?
正如 chris 所建议的那样,我在config数组中添加了import参数。
现在这个问题已经消失了。然而,由于我呼吁Yii::app()->createAbsoluteUrl()
,另一件事令Undefined index: SERVER_NAME
感到沮丧:
PHP Error[8]: Undefined index: SERVER_NAME
in file /home/srv50213/htdocs/framework/web/CHttpRequest.php at line 317
#0 /home/srv50213/htdocs/framework/base/CApplication.php(560): CHttpRequest->getHostInfo()
#1 /home/srv50213/htdocs/doc/protected/commands/ReportMailerCommand.php(39): CConsoleApplication->createAbsoluteUrl()
...
解决方案是什么?
在控制台命令中搜索createAbsoluteUrl后,我找到了有用的线程1和2。
第一个给出了这个补救措施 - 在config / console.php中添加以下内容:
'components' => array(
'request' => array(
'hostInfo' => 'https://domainname.com',
'baseUrl' => '',
'scriptUrl' => '',
),
...
)
第二种方式类似:
'components' => array(
'urlManager' => array(
'baseUrl' => 'https://domain.com'
)
)
答案 0 :(得分:3)
您是否正确定义了导入?我认为它不是控制台配置中的默认值。 把这样的东西放进去吧:
'import' => array(
'application.models.*',
),
修改:更新:
您无法在控制台应用程序中使用createUrl()
功能。就像你找到的那样,它使用$_SERVER['SERVER_NAME']
,它没有设置,因为控制台应用程序总是在没有服务器的情况下运行,直接由php cli运行。