当前位置:   article > 正文

js 使用预签名(presigned) url 上传文件到 AWS S3服务(解决生成的文件格式错误问题)_aws上传图片,拿到预签名后,文件需要怎么处理

aws上传图片,拿到预签名后,文件需要怎么处理

背景
项目里有图片上传的需求,具体实现是后端生成presigned url(预签名url,里面包含上传到AWS S3所需要的一些认证标识信息)给到前端,前端通过这个URL将文件上传到云服务上。但是上传成功后,从CDN上下载下来的文件打不开,而且只有前端有这个问题,客户端可以正常上传,一开始以为是框架问题,而且亚马逊官方也没有直接上传相关的文档(都是使用SDK的方式上传),所以问题很难定位,后来在github上找到了方案。
相关步骤

 

  1.  从后端获取presigned url ,亚马逊官网有Java、PHP、node等生成presigned url的文档在这里插入图片描述
  2. 使用presigned url上传图片,前端使用的是element UI + axios, 这里使用的element UI 自定义上传的方式,特别需要注意的就是直接上传文件,不要用formdata的格式上传
     

HTML部分

  1. <el-upload
  2. class="avatar-uploader"
  3. action="123"
  4. :http-request="upload"
  5. :before-upload="beforeAvatarUpload">
  6. <img v-if="params.defaultImgUrl" :src="params.defaultImgUrl" class="avatar">
  7. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  8. </el-upload>
  1. upload(res)
  2. {
  3. let file = res.file; //注意:直接上传file文件,不要用FormData对象的形式传
  4. let config = {
  5. headers: {
  6. 'Content-Type': 'multipart/form-data'
  7. }
  8. };
  9. //从接口获取presigned url
  10. getUploadUrl({uploadType: 6}).then(res => {
  11. let result = res.data;
  12. if (result.code === 0) {
  13. const info = JSON.parse(result.msg);
  14. //需要用put方法上传,post会报405,aws官方规定是put方法
  15. axios.put(info.presignedUrl, file, config)
  16. .then(res => {
  17. if (res.status == 200) {
  18. this.params.defaultImgUrl = info.cdnUrl;
  19. }
  20. }).catch(
  21. err => {
  22. console.log(err)
  23. }
  24. )
  25. }
  26. }).catch(err => {
  27. console.log('get upload info', err)
  28. })
  29. }

坑点


一般图片、文件上传都是使用FormData对象传递二进制文件,所以笔者一开始也是采用的这种方式上传到AWS上,但是上传完之后,下载后的图片无法打开,将其二进制数据与原文件二级制数进行对比,发现有额外的二进制数据 

 

  • 后来在github上找到了解决方案,原来使FormData对象上传文件到aws上会损坏原文件的二进制数据,直接上传文件对象就行

附上参考的解决方案github地址:
https://github.com/aws/aws-sdk-js/issues/547

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/707167
推荐阅读
相关标签
  

闽ICP备14008679号