Yii2 Basic在创建内容时上载多个图像
我试图上传多个图像时,我创建了一个职位,但只有一个图像存储在数据库中,在服务器上所有的图像保存,但在我的表中只有第一个图像保存,但不是所有,所以我创建了上传功能Yii2 Basic在创建内容时上载多个图像,yii2,yii2-basic-app,Yii2,Yii2 Basic App,我试图上传多个图像时,我创建了一个职位,但只有一个图像存储在数据库中,在服务器上所有的图像保存,但在我的表中只有第一个图像保存,但不是所有,所以我创建了上传功能 // Function to upload images public function CreateGallery($model_Post, $model_Gallery) { $model_Post->Post_id = md5(microtime()); $model_Post->User_id = Y
// Function to upload images
public function CreateGallery($model_Post, $model_Gallery)
{
$model_Post->Post_id = md5(microtime());
$model_Post->User_id = Yii::$app->user->id;
$GLRID = md5(uniqid());
// file
$GFolder = 'upload/images/'. $model_Post->Post_id .'/' ;
mkdir ($GFolder, 0777, true);
if ( $model_Post->save() ){
$model_Gallery->GalleryFile = UploadedFile::getInstances($model_Gallery, 'GalleryFile');
$ly_GalName = uniqid();
foreach ($model_Gallery->GalleryFile as $GalleryImage) {
++$ly_GalName;
$model_Gallery->Gallery_id = ++$GLRID;
$model_Gallery->User_id = $model_Post->User_id;
$model_Gallery->Post_id = $model_Post->Post_id;
$GalleryImage->saveAs($GFolder . $GalName . '.' . $GalleryImage->extension);
$model_Gallery->Gallery_image = $GFolder . $GalName . '.' . $GalleryImage->extension;
}
$model_Gallery->save(false);
}
}
在我的控制器中,我添加了我创建的函数
public function actionCreate()
{
$model_Post = new Post();
$model_Gallery = new Gallery;
$actions_UploadImages = new ActionsUploadImages();
if ($model->load(Yii::$app->request->post()) ) {
$actions_UploadImages->CreateGallery($model_Post, $model_Gallery)
return $this->redirect(['view', 'id' => $model_Post->Post_id]);
} else {
return $this->render('create', [
'model_Post' => $model_Post,
'model_Gallery' => $model_Gallery,
]);
}
}
我的视图/创建我的代码是
<?php $form = ActiveForm::begin(['options' => ['enctype' => 'multipart/form-data']]); ?>
<?= $form->field($model_Post, 'Post_title')->textInput(['maxlength' => true]) ?>
<?= $form->field($model_Gallery, 'GalleryFile[]')->fileInput(['multiple' => true, 'accept' => 'image/*']) ?>
<?= $form->field($model_Post, 'Post_text')->textarea(['rows' => 2]) ?>
<?= $form->field($model_Post, 'Permission_id')->dropdownList($model_Permission->PermissionList()) ?>
<div class="form-group">
<?= Html::submitButton($model_Post->isNewRecord ? 'Create' : 'Update', ['class' => $model_Post->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
</div>
<?php ActiveForm::end(); ?>
我尝试将gallery\u id更改为AUTO\u INCREMENT,但仍然存在相同的问题,我尝试删除if($model\u Post->save()),但从数据库中得到错误。就像现在一样,它在服务器上保存所有图像,但在表中只保存一个图像
////画廊模型:
<?php
namespace app\models;
use Yii;
/**
* This is the model class for table "gallery".
*
* @property string $Gallery_id
* @property string $Gallery_image
* @property string $Post_id
* @property string $User_id
*
* @property Post $post
* @property Userlogin $user
*/
class Gallery extends \yii\db\ActiveRecord
{
public $GalleryFile;
/**
* @inheritdoc
*/
public static function tableName()
{
return 'gallery';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
[['Gallery_id', 'Post_id', 'User_id'], 'required'],
[['Gallery_id'], 'string', 'max' => 200],
[['Gallery_image'], 'string', 'max' => 350],
[['Post_id', 'User_id'], 'string', 'max' => 300],
[['GalleryFile'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg, jpeg, gif', 'maxFiles' => 5],
[['Post_id'], 'exist', 'skipOnError' => true, 'targetClass' => Post::className(), 'targetAttribute' => ['Post_id' => 'Post_id']],
[['User_id'], 'exist', 'skipOnError' => true, 'targetClass' => Userlogin::className(), 'targetAttribute' => ['User_id' => 'User_id']],
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'Gallery_id' => 'Gallery ID',
'Gallery_image' => 'Gallery Image',
'Post_id' => 'Post ID',
'User_id' => 'User ID',
];
}
/**
* @return \yii\db\ActiveQuery
*/
public function getPost()
{
return $this->hasOne(Post::className(), ['Post_id' => 'Post_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getUser()
{
return $this->hasOne(Userlogin::className(), ['User_id' => 'User_id']);
}
/**
* @inheritdoc
* @return \app\queries\GalleryQuery the active query used by this AR class.
*/
public static function find()
{
return new \app\queries\GalleryQuery(get_called_class());
}
}
您需要为每个对象编写一个新模型,如下所示
功能
- 在中为每个对象创建新的模型对象
- 设置
$model\u Gallery->保存(false)代码>在foreach内部
//用于上传图像的函数
public function CreateGallery($model_Post, $model_Gallery)
{
$model_Post->Post_id = md5(microtime());
$model_Post->User_id = Yii::$app->user->id;
$GLRID = md5(uniqid());
// file
$GFolder = 'upload/images/' . $model_Post->Post_id . '/';
mkdir($GFolder, 0777, true);
if ($model_Post->save()) {
$model_Gallery->GalleryFile = UploadedFile::getInstances($model_Gallery, 'GalleryFile');
$ly_GalName = uniqid();
foreach ($model_Gallery->GalleryFile as $GalleryImage) {
$model_GalleryImage = new Gallery;
++$ly_GalName;
$model_GalleryImage->Gallery_id = ++$GLRID;
$model_GalleryImage->User_id = $model_Post->User_id;
$model_GalleryImage->Post_id = $model_Post->Post_id;
$GalleryImage->saveAs($GFolder . $GalName . '.' . $GalleryImage->extension);
$model_GalleryImage->Gallery_image = $GFolder . $GalName . '.' . $GalleryImage->extension;
$model_GalleryImage->save(false); //here , remove 'false' to work validations
}
}
}
控制器
当操作加载数据时,不应该是这样吗
if ($model_Gallery->load(Yii::$app->request->post()) and $model_Post->load(Yii::$app->request->post())) {
//the rest of the code
}
请注意,我们使用save(false)跳过模型内部的验证,作为用户输入数据。。。使用用户输入
您所要做的就是使用foreach循环迭代$\u FILES对象,并每次创建新模型。要验证代码管理标志,跳过验证不是问题的解决方案。在插入/保存图像之前,您需要验证每个图像,否则不支持的文件也将被允许上载。我知道,但他是这样写的,我更喜欢保存()whitout False我确实尝试了这个解决方案,但仍然不起作用没有将所有图像保存在数据库上,但它将它们全部保存在服务器上,但不保存在表上我做了一些更改,在循环中创建了模型,并且可能更改了数据加载中的控制器@Byndit正在制作$model_GalleryImage=new Gallery;并将其从控制器中移除。你是天才。它打印了什么错误请添加它显示的eaxct异常或模型错误它显示的错误:完整性约束冲突:1452无法添加或更新子行:外键约束失败添加你的库模型我添加了我的模型“你所要做的就是迭代$\u文件”,我不知道如何做。但这个解决方案是有效的。