阿里云对象存储oss前端上传文件[element-ui]

相关技术:nodejs,express,vue.js,element-ui ,
完整项目github地址

阿里云对象存储oss前端直传

oss上传文件有两种方式,一种是上传到服务器,服务器传输到oss,清空临时文件,另一种是直接通过用户端传输到oss,服务器只提供签名,和回调。

优势:减轻了服务器鸭梨。劣势:对用户上传行为没法很好的监控。

config 配置

oss bucket 配置跨域 务必在控制台设置跨域

修改里的config配置 ./router.js

start 启动

1、npm i

2、node app.js

demo

访问element-ui demo, localhost:2050/demo/index.html,

原生 localhost:2050/demo/index2.html

签名核心

const express = require("express")
const router = express.Router()
const crypto = require("crypto")
const config = {
  dirPath: 'oss/file/', //oss 文件夹 不存在会自动创建
  bucket: 'glhtest', //oss应用名
  region: 'oss-cn-hangzhou', //oss节点名
  accessKeyId: '不给看', //申请的osskey
  accessKeySecret: '不给看', //申请的osssecret
  callbackIp: "116.62.102.2", //回调ip,一定要能被外网访问的地址,你可以暂时用这个...后台的代码和下面路由一致,不过不建议
  callbackPort: "2225", //回调端口
  callbackPath: "acapi/be/ossCallback", //回调接口
  expAfter: 60000, //签名失效时间
  maxSize: 1048576000 //最大文件大小
}

router.get("/ossSign", (req, res) => {
  const {
    bucket,
    region,
    expAfter,
    maxSize,
    dirPath,
    accessKeyId,
    accessKeySecret,
    callbackIp,
    callbackPort,
    callbackPath
  } = config
  const host = `http://${bucket}.${region}.aliyuncs.com` //你的oss完整地址
  const expireTime = new Date().getTime() + expAfter
  const expiration = new Date(expireTime).toISOString()
  const policyString = JSON.stringify({
    expiration,
    conditions: [
      ['content-length-range', 0, maxSize],
      ['starts-with', '$key', dirPath]
    ]
  })
  const policy = Buffer(policyString).toString("base64")
  const Signature = crypto.createHmac('sha1', accessKeySecret).update(policy).digest("base64")
  const callbackBody = {
    "callbackUrl": `http://${callbackIp}:${callbackPort}/${callbackPath}`,
    "callbackHost": `${callbackIp}`,
    "callbackBody": "{\"filename\": ${object},\"size\": ${size}}",
    "callbackBodyType": "application/json"
  }
  const callback = Buffer(JSON.stringify(callbackBody)).toString('base64')
  res.json({
    statusCode: 200,
    message: 'oss签名成功',
    result: {
      Signature,
      policy,
      host,
      'OSSAccessKeyId': accessKeyId,
      'key': expireTime,
      'success_action_status': 200,
      dirPath,
      callback
    }
  })
})

router.post("/ossCallback", (req, res, next) => {
  res.json({
    statusCode: 200,
    message: 'oss参数回调',
    result: {
      ...req.body
    }
  })
})

module.exports = router
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,001评论 19 139
  • 阿里云对象存储OSS,主要是用于存储静态资源文件,它提供了很多方便的操作图片的方法(缩放旋转水印等),在实现了OS...
    记住你姓李阅读 10,531评论 0 9
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,638评论 25 708
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,974评论 6 342
  • 刚刚到这个学校的时候,心理说不上来的滋味。父亲一个人送我来,帮我报到领被子,买水瓶拖行李,父母刚刚离婚,就算学校再...
    莉莎阅读 363评论 0 0