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')); });
准备 Base64、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"); } // Base64 function base64(value) { return Buffer.from(value).toString("base64"); } // hmacsha1 function hmacsha1(secret, value) { return crypto.createHmac('sha1', secret).update(value, 'utf-8').digest().toString('base64'); }
上传、删除接口
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 = base64( 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="/UploadFiles/2021-04-02/axios.min.js">引入 Vue.js、Axios
<script src="/UploadFiles/2021-04-02/vue.js">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 实现文件上传、删除,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]