经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
小程序上传文件至云存储的实现
来源:jb51  时间:2022/1/24 10:37:52  对本文有异议

在小程序云开发中,要实现上传文件至云存储,有两种方案:云函数和HTTP API,前者是在小程序内调用的,而后者则是在小程序外调用的。本文主要讲讲如何使用HTTP API实现小程序外上传文件至云存储。

一、原料

① 小程序HTTP API
② PHP
③ Vue.js + Element UI

HTTP API需要在服务器端发起调用,而这里我选择的后端语言是PHP。
Element UI只是作为前端举例,我们可以用它的Upload组件来上传文件,如果是原生上传则直接用input file即可。

二、PHP调用小程序HTTP API

  1. // 获取access_token
  2. function getAccessToken(){
  3. ? ? // APPID和SECRET均可在小程序后台获取
  4. ? ? $appid = 'APPID';
  5. ? ? $secret = 'SECRET';
  6. ? ? $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".?
  7. $appid ."&secret=". $secret;
  8. ? ? $res = curl_get($url); ?// 使用GET方式请求微信接口
  9. ? ? $res = json_decode($res,1);
  10. ? ? return $res['access_token'];
  11. }
  12.  
  13. // 上传文件到小程序云存储
  14. function upload(){
  15. ? ? $path = $_REQUEST['path'];
  16. ? ? $url = "https://api.weixin.qq.com/tcb/uploadfile?access_token=". getAccessToken();
  17. ? ? $data = array ('path' => $path,'env' => APP_CLOUD_ID); ?// APP_CLOUD_ID是你小程序的云环境ID
  18. ? ? $res = json_decode(request($url, $data),1);
  19. ? ? $fileName = $_FILES['file']['tmp_name'];
  20. ? ? $handle = fopen($fileName,"r");
  21. ? ? $file = fread($handle,filesize($fileName));
  22. ? ? curl_post(
  23. ? ? ? ? $res['url'],?
  24. ? ? ? ? array (
  25. ? ? ? ? ? ? 'key' => $path,
  26. ? ? ? ? ? ? 'Signature' => $res['authorization'],
  27. ? ? ? ? ? ? 'x-cos-security-token' => $res['token'],
  28. ? ? ? ? ? ? 'x-cos-meta-fileid' => $res['cos_file_id'],
  29. ? ? ? ? ? ? 'file' => $file,
  30. ? ? ? ? )
  31. ? ? );
  32. ? ? echo json_encode(array(
  33. ? ? ? ? 'code' => 200,
  34. ? ? ? ? 'msg' => '文件上传成功',
  35. ? ? ? ? 'data' => $res['file_id']
  36. ? ? ));
  37. }
  38.  
  39. // get请求
  40. function curl_get($url) {
  41. ? ? $ch = curl_init();
  42. ? ? curl_setopt($ch, CURLOPT_URL, $url);
  43. ? ? curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  44. ? ? curl_setopt($ch, CURLOPT_HEADER, 0);
  45. ? ? return curl_exec($ch);
  46. ? ? curl_close($ch);
  47. }
  48.  
  49. // post请求
  50. function curl_post($url, $data){
  51. ? ? $ch = curl_init();
  52. ? ? curl_setopt($ch, CURLOPT_URL, $url);
  53. ? ? curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  54. ? ? curl_setopt($ch, CURLOPT_POST, 1);
  55. ? ? curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  56. ? ? return curl_exec($ch);
  57. ? ? curl_close($ch);
  58. }

有关文件上传的HTTP API具体用法可参考:获取文件上传链接

三、使用Element UI调用PHP接口

  1. // VueJS
  2. <template>
  3. ? <el-upload
  4. ? ? ? class="avatar-uploader"
  5. ? ? ? :action=""
  6. ? ? ? accept="image/*,.jpg"
  7. ? ? ? :http-request="upload"
  8. ? ? ? :show-file-list="false"
  9. ? >
  10. ? ? <img v-if="image" :src="image" class="avatar" />
  11. ? ? <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  12. ? </el-upload>
  13. </template>
  14.  
  15. <script>
  16. import axios from 'axios'
  17. const request = axios.create({
  18. ? baseURL: process.env.BASE_API, // api 的 base_url
  19. ? timeout: 20000
  20. });
  21.  
  22. export default {
  23. ? data() {
  24. ? ? return {
  25. ? ? ? image: ''
  26. ? ? };
  27. ? },
  28. ? methods: {
  29. ? ? async upload(e) {
  30. ? ? ? let formData = new FormData();
  31. ? ? ? let path = `upload/${new Date().getTime() + e.file.name.match(/\.(.*)/)[0]}`;
  32. ? ? ? formData.append("path", path);
  33. ? ? ? formData.append("file", e.file);
  34. ? ? ? await request({
  35. ? ? ? ? url: '/api/upload', ?// php提供的上传接口
  36. ? ? ? ? method: 'post',
  37. ? ? ? ? headers: {
  38. ? ? ? ? ? ? "Content-Type": "multipart/form-data",//设置headers
  39. ? ? ? ? },
  40. ? ? ? ? data: formData
  41. ? ? ? });
  42. ? ? ? this.image = '【小程序云存储域名】' + path;
  43. ? ? }
  44. };
  45. </script>

结束语

以上仅仅只是最近项目的摘录和总结,由于涉及到一些项目隐私,所以代码并不是特别完整,但大体思路就是如此,已通过实践检验可行,希望对一些正好有此需求的朋友有所帮助!

到此这篇关于小程序外上传文件至云存储的实现的文章就介绍到这了,更多相关小程序外上传文件至云存储内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号