【发布时间】:2018-01-14 22:21:35
【问题描述】:
我正在使用 vue.js 2.1 和 Laravel 5.4 从没有表单的组件上传文件。
问题:在服务器端,这条语句return $request->file('my_file'); 返回null。为什么?
vue 组件是这样的:
<template>
<input id="my_file" type="file" @change="fileChanged($event)">
<button v-if="my_file" @click="update">Upload</button>
</template>
<script>
export default {
data () {
return {
my_file: null,
}
},
methods: {
fileChanged(e) {
var files = e.target.files || e.dataTransfer.files;
if (!files.length)
return;
this.createImage(files[0]);
},
createImage(file) {
var image = new Image();
var reader = new FileReader();
var vm = this;
reader.onload = (e) => {
vm.my_file = e.target.result;
};
reader.readAsDataURL(file);
},
update() {
axios.put('/api/update/', {
my_file: this.my_file,
})
.then(response => {
console.log(response.data);
})
.catch(error => {
console.log(error);
});
}
}
}
</script>
在服务器端,我有以下方法:
public function update(Request $request)
{
return $request->file('my_file');
// $request->file('my_file')->store();
}
我错过了什么?所以我可以使用 Laravel 提供的函数$request->file('my_file')->store(); 来上传文件。
编辑
我已将 http 动词从 put 更改为 post,如下所示:
trySomeThing () {
var data = new FormData();
var file = this.$refs.fileInput.files[0];
data.append('attachment_file', file);
data.append('msg', 'hello');
axios.post('/api/try', data)
.then(response => {
console.log(response.data)
});
},
在控制器上,我有:
public function try(Request $request)
{
if ($request->hasFile('my_file')) {
$file = $request->file('my_file');
//$file->getFilename();
return var_dump($file);
} else {
return var_dump($_POST);
}
}
返回的响应显示如下:
【问题讨论】:
-
在 vuejs 中使用
formData
标签: php laravel vue.js laravel-5 vuejs2