小程序上傳文件至云存儲的實現(xiàn)
在小程序云開發(fā)中,要實現(xiàn)上傳文件至云存儲,有兩種方案:云函數(shù)和HTTP API,前者是在小程序內(nèi)調(diào)用的,而后者則是在小程序外調(diào)用的。本文主要講講如何使用HTTP API實現(xiàn)小程序外上傳文件至云存儲。
一、原料
① 小程序HTTP API
② PHP
③ Vue.js + Element UI
HTTP API需要在服務(wù)器端發(fā)起調(diào)用,而這里我選擇的后端語言是PHP。
Element UI只是作為前端舉例,我們可以用它的Upload組件來上傳文件,如果是原生上傳則直接用input file即可。
二、PHP調(diào)用小程序HTTP API
// 獲取access_token function getAccessToken(){ ? ? // APPID和SECRET均可在小程序后臺獲取 ? ? $appid = 'APPID'; ? ? $secret = 'SECRET'; ? ? $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".? $appid ."&secret=". $secret; ? ? $res = curl_get($url); ?// 使用GET方式請求微信接口 ? ? $res = json_decode($res,1); ? ? return $res['access_token']; } // 上傳文件到小程序云存儲 function upload(){ ? ? $path = $_REQUEST['path']; ? ? $url = "https://api.weixin.qq.com/tcb/uploadfile?access_token=". getAccessToken(); ? ? $data = array ('path' => $path,'env' => APP_CLOUD_ID); ?// APP_CLOUD_ID是你小程序的云環(huán)境ID ? ? $res = json_decode(request($url, $data),1); ? ? $fileName = $_FILES['file']['tmp_name']; ? ? $handle = fopen($fileName,"r"); ? ? $file = fread($handle,filesize($fileName)); ? ? curl_post( ? ? ? ? $res['url'],? ? ? ? ? array ( ? ? ? ? ? ? 'key' => $path, ? ? ? ? ? ? 'Signature' => $res['authorization'], ? ? ? ? ? ? 'x-cos-security-token' => $res['token'], ? ? ? ? ? ? 'x-cos-meta-fileid' => $res['cos_file_id'], ? ? ? ? ? ? 'file' => $file, ? ? ? ? ) ? ? ); ? ? echo json_encode(array( ? ? ? ? 'code' => 200, ? ? ? ? 'msg' => '文件上傳成功', ? ? ? ? 'data' => $res['file_id'] ? ? )); } // get請求 function curl_get($url) { ? ? $ch = curl_init(); ? ? curl_setopt($ch, CURLOPT_URL, $url); ? ? curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); ? ? curl_setopt($ch, CURLOPT_HEADER, 0); ? ? return curl_exec($ch); ? ? curl_close($ch); } // post請求 function curl_post($url, $data){ ? ? $ch = curl_init(); ? ? curl_setopt($ch, CURLOPT_URL, $url); ? ? curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); ? ? curl_setopt($ch, CURLOPT_POST, 1); ? ? curl_setopt($ch, CURLOPT_POSTFIELDS, $data); ? ? return curl_exec($ch); ? ? curl_close($ch); }
有關(guān)文件上傳的HTTP API具體用法可參考:獲取文件上傳鏈接
三、使用Element UI調(diào)用PHP接口
// VueJS <template> ? <el-upload ? ? ? class="avatar-uploader" ? ? ? :action="" ? ? ? accept="image/*,.jpg" ? ? ? :http-request="upload" ? ? ? :show-file-list="false" ? > ? ? <img v-if="image" :src="image" class="avatar" /> ? ? <i v-else class="el-icon-plus avatar-uploader-icon"></i> ? </el-upload> </template> <script> import axios from 'axios' const request = axios.create({ ? baseURL: process.env.BASE_API, // api 的 base_url ? timeout: 20000 }); export default { ? data() { ? ? return { ? ? ? image: '' ? ? }; ? }, ? methods: { ? ? async upload(e) { ? ? ? let formData = new FormData(); ? ? ? let path = `upload/${new Date().getTime() + e.file.name.match(/\.(.*)/)[0]}`; ? ? ? formData.append("path", path); ? ? ? formData.append("file", e.file); ? ? ? await request({ ? ? ? ? url: '/api/upload', ?// php提供的上傳接口 ? ? ? ? method: 'post', ? ? ? ? headers: { ? ? ? ? ? ? "Content-Type": "multipart/form-data",//設(shè)置headers ? ? ? ? }, ? ? ? ? data: formData ? ? ? }); ? ? ? this.image = '【小程序云存儲域名】' + path; ? ? } }; </script>
結(jié)束語
以上僅僅只是最近項目的摘錄和總結(jié),由于涉及到一些項目隱私,所以代碼并不是特別完整,但大體思路就是如此,已通過實踐檢驗可行,希望對一些正好有此需求的朋友有所幫助!
到此這篇關(guān)于小程序外上傳文件至云存儲的實現(xiàn)的文章就介紹到這了,更多相關(guān)小程序外上傳文件至云存儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用a標(biāo)簽自動解析URL分析網(wǎng)址實例
a標(biāo)簽也和window.location一樣,也有這樣屬性,因此可以利用它來分析網(wǎng)址,下面的實例代碼,大家可以看看2014-10-10javascript實現(xiàn)驗證身份證號的有效性并提示
下面分享的JS腳本是我用過的最完善的身份證號的驗證程序了,因為只有真正的身份證號才能被通過,小伙伴們可以試試。直接復(fù)制運行。2015-04-04以JavaScript來實現(xiàn)WordPress中的二級導(dǎo)航菜單的方法
這篇文章主要介紹了以JavaScript來實現(xiàn)WordPress中的二級導(dǎo)航菜單的方法,文中首先對WordPress基本的PHP導(dǎo)航菜單的做法給出了說明來作為基礎(chǔ),需要的朋友可以參考下2015-12-12