最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

又拍云 Node.js 实现文件上传、删除功能

来源:动视网 责编:小采 时间:2020-11-27 22:05:42
文档

又拍云 Node.js 实现文件上传、删除功能

又拍云 Node.js 实现文件上传、删除功能:Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require(express); const app = express(); const axios = require('axios'); app.set('port', process.env.PORT 8082
推荐度:
导读又拍云 Node.js 实现文件上传、删除功能:Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require(express); const app = express(); const axios = require('axios'); app.set('port', process.env.PORT 8082


Node.js 服务端

使用 Node.js + Express.js 实现 服务端

const express = require("express");
const app = express();
const axios = require('axios');
app.set('port', process.env.PORT || 8082);
// 静态资源目录,这里放在了根目录,生产环境不允许这样
app.use(express.static(__dirname));
// 启动一个端口为 8082 的服务器
app.listen(app.get('port'), () => {
 console.log("http://localhost:" + app.get('port'));
});

准备 Base、HMAC-SHA1、MD5 实现签名认证

详见:http://docs.upyun.com/api/authorization/#_5

const crypto = require("crypto");
// MD5
function MD5(value) {
 return crypto
 .createHash("md5")
 .update(value)
 .digest("hex");
}
// Base
function base(value) {
 return Buffer.from(value).toString("base");
}
// hmacsha1
function hmacsha1(secret, value) {
 return crypto.createHmac('sha1', secret).update(value, 'utf-8').digest().toString('base');
}

上传、删除接口

const date = new Date().toGMTString();
const bucketname = ""; // 空间名
const key = ""; // 操作员
const secret = ""; // 密码
const upyunUrl = 'http://v0.api.upyun.com/'
// Upload
app.get("/api/token/upload", (req, res) => {
 let fileName = (Math.random() * 100000000) >>> 0;
 let expiration = ((Date.now() / 1000) >>> 0) + 30 * 60; // 请求的过期时间,UNIX UTC 时间戳,单位秒。建议设为 30 分钟 http://docs.upyun.com/api/form_api/
 let method = "POST";
 let policy = base(
 JSON.stringify({
 bucket: bucketname,
 // "save-key": "/" + fileName + "{.suffix}",
 "save-key": "/{filename}{.suffix}",
 expiration: expiration
 })
 );
 let authorization =
 "UPYUN " +
 key +
 ":" +
 hmacsha1(MD5(secret), method + "&/" + bucketname + "&" + policy);
 res.json({
 msg: "OK",
 code: 200,
 data: {
 authorization: authorization,
 policy: policy
 }
 });
});
// Delete
app.get('/api/token/del', (req, res) => {
 let item = req.query.item;
 let method = "DELETE"
 let authorization = "UPYUN " +
 key +
 ":" + 
 hmacsha1(MD5(secret), method + '&/' + bucketname + item + '&'+ date);
 axios({
 url: upyunUrl + bucketname + item,
 method: 'DELETE',
 headers: {
 'Authorization': authorization,
 'Date': date
 }
 }).then(response => {
 res.json({
 msg: "OK",
 code: 200,
 data: {}
 }); 
 }).catch(err => {
 console.log('err', err)
 })
})

跨域接口调用

const cors = require('cors');

// CORS @see https://github.com/expressjs/cors
app.use(cors());

前端

前端使用 Vue.js 实现

引入 Bootstrap.css

<link rel="stylesheet" type="text/css" href="https://unpkg.com/bootstrap@4.1.3/dist/css/bootstrap.css">
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<!-- HTML -->
<div id="app">
 <div class="card" style="margin: 50px auto; width: 300px;">
 <div class="card-body">
 <h5 class="card-title">UPYun Upload & Delete</h5>
 <div class="card-text">
 <div class="form-group">
 <label for="file">Upload</label>
 <input type="file" id="file" class="form-control-file" @change="onChange">
 <div class="form-text text-muted">
 <ul>
 <li v-for="(item, index) in files">
 {{item}} <a href="javascript:;" rel="external nofollow" @click="onDel(item, index)">Del</a>
 </li>
 </ul>
 </div>
 </div>
 </div>
 </div>
 </div>
</div>

引入 Vue.js、Axios

<script src="https://unpkg.com/vue@2.5.17/dist/vue.js"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

JS

const upUrl = 'http://v0.api.upyun.com/' // +空间名,如:http://v0.api.upyun.com/yun-temp
 const baseApi = 'http://localhost:8082/api/'
 let uploadInput;
 let app = new Vue({
 el: '#app',
 data: {
 files: []
 },
 methods: {
 onChange: function () {
 getToken(token => {
 let formData = new FormData();
 formData.append("file", uploadInput.files[0])
 formData.append('policy', token.policy)
 formData.append("authorization", token.authorization)
 axios({
 method: 'POST',
 url: upUrl,
 data: formData
 }).then(res => {
 res = res || {}
 if (res.status !== 200) {
 console.log('error')
 return
 }
 let data = res.data || {}
 this.files.push(data.url)
 alert('Success')
 }).catch(err => {
 console.log(err);
 });
 });
 },
 onDel: function (item, index) {
 this.files.splice(index, 1)
 axios.request({
 url: baseApi + 'token/del',
 method: 'GET',
 params: {
 item: encodeURI(item)
 }
 }).then(res => {
 alert('Deleted.')
 }).catch(err => {
 console.log(err)
 })
 }
 },
 mounted () {
 uploadInput = $('file')
 }
 })
 // DOM 获取元素
 function $ (el) {
 return document.getElementById(el)
 }
 // 获取 token
 function getToken (fn) {
 let token = window.localStorage.getItem('token');
 token = JSON.parse(token) || {};
 let nowTime = Date.now();
 if (nowTime < token.expired && token.authorization && token.policy) {
 fn(token)
 return
 }
 axios({
 method: 'get',
 url: baseApi + 'token/upload'
 })
 .then(res => {
 let data = res.data || {}
 data = data.data || {}
 const authorization = data.authorization
 const policy = data.policy
 const expired = ((Date.now() / 1000) >>> 0) + 30 * 60;
 token = {
 authorization,
 policy,
 expired
 }
 fn(token)
 window.localStorage.setItem('token', JSON.stringify(token))
 });
 }

项目源码

https://github.com/givebest/UPyun-upload-delete-node.js

总结

以上所述是小编给大家介绍的又拍云 Node.js 实现文件上传、删除,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

文档

又拍云 Node.js 实现文件上传、删除功能

又拍云 Node.js 实现文件上传、删除功能:Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require(express); const app = express(); const axios = require('axios'); app.set('port', process.env.PORT 8082
推荐度:
标签: node.js 又拍云
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top