- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 CURL 命令将文件上传到服务器,但在少数 CLI 中会出现问题。当我运行我的 Node 应用程序时,只有安装了 CURL 的 CLI 才能正常工作。
let mnmPath = `http://xyz/api/123456/mnm-api`;
exec(`curl -X PUT -H "x-cdn-path:" ${mnmPath } --upload-file abcd.txt`, (error, stdout) => {
if (error) {
console.log({status: 1, message: 'Error while uploading Tarball to CDN'});
}
console.log({status: 0, message: 'CDN upload completed.'});
});
最佳答案
您需要以某种方式获取文件,在我的示例中,我假设您有一个文件选择器并且您可以从中访问数据
您需要使用 post 请求将文件发送到服务器,然后根据请求的成功使用 promises 进行捕获或解析。
https://github.com/axios/axios
https://developer.mozilla.org/en-US/docs/Web/API/FormData
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise
/*
example of getting a file from DOM but as long as you
pass a file to the function should be good
*/
// es6 promise
function postFileToServer(file) {
const formData = new FormData();
formData.append("file", file);
axios.post('/your-endpoint', formData)
.then(res => /* do something with res*/ console.log(res))
.catch(e => console.log('upload failed'))
}
function submit() {
const file = document.getElementById("file").files;
if (file.length > 0) {
postFileToServer(file[0])
}
}
input {display: block}
<script src="https://cdnjs.cloudflare.com/ajax/libs/axios/0.18.0/axios.js"></script>
<input id="file" type="file" />
<button onclick="submit()">submit</button>
来自 FormData 文档
The FormData interface provides a way to easily construct a set of key/value pairs representing form fields and their values, which can then be easily sent using the XMLHttpRequest.send() method. It uses the same format a form would use if the encoding type were set to "multipart/form-data".
基本上,它将其格式化为易于操作的对象,准备发送到外部服务。您将需要检查您使用的服务如何接受该文件。
关于javascript - 如何使用任何 Node 库尤其是 axios 将文件上传到服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51159522/
我是一名优秀的程序员,十分优秀!