Yii2 KCFinder:如何将图像上传到“Common”或“Frontend”目录

时间:2015-08-25 11:36:33

标签: ckeditor yii2 kcfinder

我遇到了一个问题。我使用CKEditor来创建HTML编辑器,并使用KCFinder在HTML编辑器中上传和插入图像。我的问题是,我无法显示我通过KCFinder在我的FrontEnd网站上传的图像

我的代码(在后端/视图/ _form中)

 <?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use backend\modules\CKEditor;
use iutbay\yii2kcfinder\KCFinder;

$kcfOptions = array_merge(KCFinder::$kcfDefaultOptions, [
    //'uploadURL' => Yii::getAlias('@web').'/upload',
    'uploadURL' => Yii::getAlias('@common').'/upload',
    'access' => [
        'files' => [
            'upload' => true,
            'delete' => true,
            'copy' => true,
            'move' => true,
            'rename' => true,
        ],
        'dirs' => [
            'create' => true,
            'delete' => true,
            'rename' => true,
        ],
    ],
]);

// Set kcfinder session options
Yii::$app->session->set('KCFINDER', $kcfOptions);
?>

<div class="emails-form">
    <?php yii\widgets\Pjax::begin(['id' => 'new_email']) ?>
    <?php $form = ActiveForm::begin(['options' => ['enctype'=>'multipart/form-data' ]]); ?>
    <?= $form->field($model, 'receiver_name')->textInput(['maxlength' => 200]) ?>
    <?= $form->field($model, 'receiver_email')->textInput(['maxlength' => 200]) ?>
    <?= $form->field($model, 'subject')->textInput(['maxlength' => 200]) ?>
    <?//= $form->field($model, 'content')->textarea(['maxlength' => 200]) ?>
    <?= $form->field($model, 'content')->widget(CKEditor::className(), [
        'options' => ['rows' => 6],
        'preset' => 'full'
        //'preset' => 'basic'
    ])
    ?>
    <?= $form->field($model, 'attachment')->fileInput(['maxlength' => 200]) ?>

    <div class="form-group">
        <?= Html::submitButton($model->isNewRecord ? Yii::t('app', 'Create') : Yii::t('app', 'Update'), ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
    </div>
    <?php ActiveForm::end(); ?>
    <?php yii\widgets\Pjax::end() ?>
</div>

现在我的代码可以正常工作但图像将上传到“后端/网络/上传”如何通过KCFinder将图像上传到“前端/网络/上传”? 或者是否有任何针对此案的建议解决方案?我需要使用CKEditor + KCFinder创建新闻表单,然后我可以在前端网站中显示内容。 非常感谢你的帮助。

2 个答案:

答案 0 :(得分:0)

看看Yii2提供了我们使用的前端/后端。我建议暂时忘记它在后端。
 你可以做的是设置param,它将进入后端/ web / updloads并仅在db中保存文件名,我指的是上传文件夹后的文件名/路径。 像这样:

这将是你的bakcend:backend.example.com/uploads/   上传后的数据库中的文件名和文件名:file.jpg,profile / firstuser.png。

当您能够从前端访问它时,只需将您的上传文件夹从后端复制到前端。

我知道这不是写解决方案,但它对我有用。我认为这会对我有所帮助。

这是我的第一个答案,请问我是否不清楚:)

谢谢

答案 1 :(得分:0)

最后,我找到了解决方案。我使用命令创建了链接:

cd /path/to/project/frontend/web
ln -s ../../backend/web/upload upload

之后,我编辑了 httpd-vhosts.conf 以允许“Options + FollowSymlinks”

<VirtualHost *:80>
    ServerName example.com
    DocumentRoot "/path/to/project/frontend/web"
    Options +FollowSymlinks
    ...
</VirtualHost>

不要忘记“重启”apache服务。 :)

参考网站 - &gt; http://www.yiiframework.com/wiki/799/yii2-app-advanced-on-single-domain-apache-nginx/