yii ajax传值,Yii使用Ajax上传文件 - 传递数据数组(formData)

2023-05-16

我一直抨击这一段时间,并且似乎一次性推进小步骤。我需要为用户提供一种通过Ajax上传文件的方式。我已经看到需要使用formData才能传递文件本身。使用这两个问题作为参考: Uploading file in Yii using ajax Yii ajax file uploadYii使用Ajax上传文件 - 传递数据数组(formData)

我有我的视图下面的代码页:

$form=$this->beginWidget('CActiveForm', array(

'id'=>'post-form',

'htmlOptions' => array('enctype' => 'multipart/form-data'),

));

echo '

' . $form->fileField($upload, 'image') . '
';

echo $form->error($upload, 'image');

echo CHtml::button("(+)",array('title'=>"Topic",'onclick'=>'js:upload_file(this);'));

$this->endWidget(); ?>

function upload_file(){

var fd = new FormData();

var e = document.getElementById("UploadedFiles_image");

fd.append("UploadedFiles[image]", $(e)[0].files[0]);

$.ajax({

url: 'UploadInstallPhoto',

type: 'POST',

cache: false,

data: fd,

datatype: 'json',

processData: false,

contentType: false,

success: function (data) {

},

error: function() {

alert("ERROR in upload");

}

});

}

我在控制器下面的代码:

if(Yii::app()->request->isAjaxRequest)

{

$upload = new UploadedFiles;

$upload->attributes = $_POST['UploadedFiles'];

$file = CUploadedFile::getInstance($upload,'image');

$pi = pathinfo($file);

$upload->name = $pi['filename'];

$upload->ext = $pi['extension'];

$upload->acc_id = $id;

$upload->type_id = 1;

$upload->date_uploaded = date('Y-m-d');

if($upload->save())

{

$file->saveAs(Yii::app()->params['uploadFiles'] . $upload->id . '.' . $pi['extension']);

Yii::app()->user->setFlash('success',Yii::t('flash','flash.accounts.successful_upload'));

}

}

有了上面的代码,我现在可以做ajax文件提交和这个我按预期工作。我现在遇到的问题是该文件被放置到一个文件夹中,并创建数据库中的条目。在数据库中,我引用个人帐户,以便可以在该用户的帐户上看到该文件。

我需要能够做的是通过一组数据与AJAX POST即

data: {file: fd, id: id}

然而,当我改变行使用数组没有数据公布。请有人建议一个可能的修补程序或我可以传递多个值,包括文件值。

+0

您可以将更多的附加到formData对象,但不能真正改变它,因此它是另一个对象的一部分。 –

2014-12-01 16:33:20

+0

@adeneo你是完全正确的。我已经能够根据需要附加带有id的fd变量。感谢您的评论,现在一切正常! –

2014-12-02 08:30:02

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

yii ajax传值,Yii使用Ajax上传文件 - 传递数据数组(formData) 的相关文章

随机推荐