Cakephp表单通过ajax将上传文件传递到控制器
我有一个使用cakephp form builder创建的表单,该表单有两个文件上载字段,如下所示:Cakephp表单通过ajax将上传文件传递到控制器,php,jquery,ajax,cakephp,Php,Jquery,Ajax,Cakephp,我有一个使用cakephp form builder创建的表单,该表单有两个文件上载字段,如下所示: <?php echo $this->Form->create('application', array('type' => 'file', 'url' => array('app' => true, 'controller' => 'jobs', 'action' => 'save_new_application'), 'id' => 'cr
<?php echo $this->Form->create('application', array('type' => 'file', 'url' => array('app' => true, 'controller' => 'jobs', 'action' => 'save_new_application'), 'id' => 'create-application-form'));
echo '<p>'.$this->Form->input('cv', array('type' => 'file', 'label' => "Upload CV (Required)", 'required' => true)).'</p>';
echo '<p>'.$this->Form->input('cover-letter', array('type' => 'file', 'label' => "Upload Cover Letter (optional)")).'</p>';
echo $this->Form->input('campaignid', array('type' => 'hidden', 'class' => 'form-control sendid', 'label' => false, 'value' => $campaignid));
echo $this->Form->input('profileid', array('type' => 'hidden', 'class' => 'form-control sendid', 'label' => false, 'value' => $profileid));
echo $this->Form->submit('Apply', array('class' => 'form-control')); ?>
<?php echo $this->Form->end(); ?>
我需要在ajax调用中更改什么才能将实际文件数据传递给控制器,以便将文件保存在服务器上?您必须发送
New FormData()
对象才能使用ajax发送文件
更新代码
$('#create-application-form').off().on('submit', function(e){
e.preventDefault();
var formdatas = new FormData($('#create-application-form')[0]);
$.ajax({
url: '/app/jobs/save_new_application/',
dataType: 'json',
method: 'post',
data: formdatas,
contentType: false,
processData: false
})
.done(function(response) {
//show result
if (response.status == 'OK') {
} else if (response.status == 'FAIL') {
} else {
//show default message
}
})
.fail(function(jqXHR) {
if (jqXHR.status == 403) {
window.location = '/';
} else {
console.log(jqXHR);
}
});
});
这给了我:UncaughtTypeError:非法调用我已经更新了我的ajax调用,请检查它并让我知道。。。也可以在控制器中尝试打印(美元文件);死亡它传递文件数据,但不包括您需要使用print\r($\u POST)的数据的隐藏字段;因此,基本上数据将来自print\r($\u POST);和file data print_r($_FILES)@ZacPowell for cakephp您可以使用
$this->data
获取用户数据可能的重复项
$('#create-application-form').off().on('submit', function(e){
e.preventDefault();
var formdatas = new FormData($('#create-application-form')[0]);
$.ajax({
url: '/app/jobs/save_new_application/',
dataType: 'json',
method: 'post',
data: formdatas,
contentType: false,
processData: false
})
.done(function(response) {
//show result
if (response.status == 'OK') {
} else if (response.status == 'FAIL') {
} else {
//show default message
}
})
.fail(function(jqXHR) {
if (jqXHR.status == 403) {
window.location = '/';
} else {
console.log(jqXHR);
}
});
});