前言
后端用的是 Rails ActiveStorage direct_upload
的处理方式, 前端被要求:
- 提供文件的
MD5-Base64
校验值,获得上传地址; - 将文件上传到上述指定地址(此处会校验文件的 MD5-Base64 值是否与上一步给的一致);
- 将文件的
signed_id
作为文件参数。
相关知识
因为目前开发任务重且紧,暂时略过此部分,只记录结论要点,后续有时间再补充相关知识
要点小结
3.0 上传文件(后端 Rails: activeStorage)
Step 1: 计算文件 MD5-Base64 摘要
-
小程序中前端无法获取文件的 Binary 格式 ,因此无法自行或使用第三方库来计算文件的
MD5
值,但幸运的是,小程序也提供了 API 来做这件事,请使用:wx.getFileInfo - 将获得的
MD5
值转为Base64
格式。可使用此项目中utils/base64.js
的encode
方法,该方法适用于转换字符串。也可使用CryptoJS
库,需要注意的是,CryptoJS.enc.Base64.stringify
需要的参数是WordArray
格式,不能直接传String
,要先用CryptoJS.enc.Utf8.parse
转换一下字符串
Step 2: 上传文件到上一步返回的指定 direct_upload
地址
- 小程序前端无法直接获得文件的
Binary
格式传给后端,但可以通过 wx.uploadFile 上传文件,通过此接口发送请求,后端可获取到文件Binary
格式 - 后端提供的上传文件接口需符合
wx.uploadFile
的要求,即 请求方式为POST
, 并指定所需文件key
名(而不是直接要求把Binary
文件丢在请求body
中)