【发布时间】:2018-07-27 02:34:37
【问题描述】:
我正在尝试使用 ajax 上传表单数据,但问题是我无法上传图像/文件。
表格代码
<form class="form-inline" id="form_add" enctype="multipart/form-data">
<input type="file" id="file-input" name="file-input" accept="image/*" >
<input type="text" class="form-control name" id="fname" placeholder="First Name" >
<select class="location" id="location" >
<option value="">Location</option>
<?php foreach($location as $loc): ?>
<option value="<?php echo $loc->city.', '.$loc->state;?>" ><?php echo $loc->city.', '.$loc->state;?></option>
<?php endforeach; ?>
</select>
<button type="submit" class="save_btn" id="submit" > <img src="save.png" class="Save"> </button>
</form>
脚本代码
<script>
$("#submit").click(function()
{
event.preventDefault();
var filename = $('input[type=file]').val();
var fname = $("#fname").val();
var location = $("#location").val();
if(filename != "" || fname != "" || location != "")
{
$.ajax({
type: "POST",
url: "Data/add_data",
data: {
filename : filename,
fname:fname,
location:location
},
cache: false,
success: function(result){
console.log(result);
}});
}
});
</script>
后端代码
$ImageFile = $this->input->post('filename');
$config['upload_path'] = './assets/client_img/.';
$config['allowed_types'] = 'gif|jpg|png|jpeg';
$config['max_size'] = 1024 * 8;
$config['encrypt_name'] = TRUE;
$this->load->library('upload', $config);
if (!$this->upload->do_upload('ImageFile'))
{
$error1 = array('error' => $this->upload->display_errors());
print_r($error1);
}
else
{
$data1 = $this->upload->data();
echo $data1['file_name'];
}
在后端代码中,我将 $ImageFile 的值设为 C:\fakepath\pic.jpg 但文件未上传,错误提示
您没有选择要上传的文件
谁能告诉我如何上传文件
【问题讨论】:
-
需要使用FormData并设置processData: false, stackoverflow.com/questions/6974684/…
-
@angel.bonev 使用建议链接中告诉的方法将不得不让我更改我的整个代码,是否有任何替代方法
-
为什么你需要改变整个代码只是将 ajax 中的数据更改为数据:FormData 并创建 FormData 类似的东西 var formData = new FormData(); formData.append('filename', $('input[type=file]')[0].files[0]); formData.append('fname', $('#fname')[0].val()); formData.append('location', $('#location')[0].val());
标签: javascript php jquery ajax file-upload