如何通过反应在 axios 中设置多部分?
How do I set multipart in axios with react?
当我卷曲某些东西时,它工作正常:
curl -L -i -H 'x-device-id: abc' -F "url=http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4" http://example.com/upload
如何让它与 axios 一起正常工作?如果这很重要,我正在使用 React:
uploadURL (url) {
return axios.post({
url: 'http://example.com/upload',
data: {
url: url
},
headers: {
'x-device-id': 'stuff',
'Content-Type': 'multipart/form-data'
}
})
.then((response) => response.data)
}
由于某些原因这不起作用。
如果您要发送字母数字数据,请尝试更改
'Content-Type': 'multipart/form-data'
至
'Content-Type': 'application/x-www-form-urlencoded'
如果您要发送 non-alphanumeric 数据,请尝试完全删除 'Content-Type'。
如果还是不行,考虑试试request-promise(至少可以测试下是不是真的axios问题)
下面是我如何使用 axios 在 React 中上传文件
import React from 'react'
import axios, { post } from 'axios';
class SimpleReactFileUpload extends React.Component {
constructor(props) {
super(props);
this.state ={
file:null
}
this.onFormSubmit = this.onFormSubmit.bind(this)
this.onChange = this.onChange.bind(this)
this.fileUpload = this.fileUpload.bind(this)
}
onFormSubmit(e){
e.preventDefault() // Stop form submit
this.fileUpload(this.state.file).then((response)=>{
console.log(response.data);
})
}
onChange(e) {
this.setState({file:e.target.files[0]})
}
fileUpload(file){
const url = 'http://example.com/file-upload';
const formData = new FormData();
formData.append('file',file)
const config = {
headers: {
'content-type': 'multipart/form-data'
}
}
return post(url, formData,config)
}
render() {
return (
<form onSubmit={this.onFormSubmit}>
<h1>File Upload</h1>
<input type="file" onChange={this.onChange} />
<button type="submit">Upload</button>
</form>
)
}
}
export default SimpleReactFileUpload
好的。我尝试了以上两种方法,但它对我不起作用。经过反复试验,我才知道实际上文件没有保存在 'this.state.file' 变量中。
fileUpload = (e) => {
let data = e.target.files
if(e.target.files[0]!=null){
this.props.UserAction.fileUpload(data[0], this.fallBackMethod)
}
}
这里的 fileUpload 是一个不同的 js 文件,它接受两个这样的参数
export default (file , callback) => {
const formData = new FormData();
formData.append('fileUpload', file);
return dispatch => {
axios.put(BaseUrl.RestUrl + "ur/url", formData)
.then(response => {
callback(response.data);
}).catch(error => {
console.log("***** "+error)
});
}
}
不要忘记在构造函数中绑定方法。让我知道您是否需要更多帮助。
当我卷曲某些东西时,它工作正常:
curl -L -i -H 'x-device-id: abc' -F "url=http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4" http://example.com/upload
如何让它与 axios 一起正常工作?如果这很重要,我正在使用 React:
uploadURL (url) {
return axios.post({
url: 'http://example.com/upload',
data: {
url: url
},
headers: {
'x-device-id': 'stuff',
'Content-Type': 'multipart/form-data'
}
})
.then((response) => response.data)
}
由于某些原因这不起作用。
如果您要发送字母数字数据,请尝试更改
'Content-Type': 'multipart/form-data'
至
'Content-Type': 'application/x-www-form-urlencoded'
如果您要发送 non-alphanumeric 数据,请尝试完全删除 'Content-Type'。
如果还是不行,考虑试试request-promise(至少可以测试下是不是真的axios问题)
下面是我如何使用 axios 在 React 中上传文件
import React from 'react'
import axios, { post } from 'axios';
class SimpleReactFileUpload extends React.Component {
constructor(props) {
super(props);
this.state ={
file:null
}
this.onFormSubmit = this.onFormSubmit.bind(this)
this.onChange = this.onChange.bind(this)
this.fileUpload = this.fileUpload.bind(this)
}
onFormSubmit(e){
e.preventDefault() // Stop form submit
this.fileUpload(this.state.file).then((response)=>{
console.log(response.data);
})
}
onChange(e) {
this.setState({file:e.target.files[0]})
}
fileUpload(file){
const url = 'http://example.com/file-upload';
const formData = new FormData();
formData.append('file',file)
const config = {
headers: {
'content-type': 'multipart/form-data'
}
}
return post(url, formData,config)
}
render() {
return (
<form onSubmit={this.onFormSubmit}>
<h1>File Upload</h1>
<input type="file" onChange={this.onChange} />
<button type="submit">Upload</button>
</form>
)
}
}
export default SimpleReactFileUpload
好的。我尝试了以上两种方法,但它对我不起作用。经过反复试验,我才知道实际上文件没有保存在 'this.state.file' 变量中。
fileUpload = (e) => {
let data = e.target.files
if(e.target.files[0]!=null){
this.props.UserAction.fileUpload(data[0], this.fallBackMethod)
}
}
这里的 fileUpload 是一个不同的 js 文件,它接受两个这样的参数
export default (file , callback) => {
const formData = new FormData();
formData.append('fileUpload', file);
return dispatch => {
axios.put(BaseUrl.RestUrl + "ur/url", formData)
.then(response => {
callback(response.data);
}).catch(error => {
console.log("***** "+error)
});
}
}
不要忘记在构造函数中绑定方法。让我知道您是否需要更多帮助。