亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

小程序上傳文件至云存儲的實現(xiàn)

 更新時間:2022年01月24日 09:54:16   作者:前端王睿  
在小程序云開發(fā)中,要實現(xiàn)上傳文件至云存儲,有兩種方案:云函數(shù)和HTTP?API,本文主要講講如何使用HTTP?API實現(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)文章

  • JS隨機調(diào)用指定函數(shù)的方法

    JS隨機調(diào)用指定函數(shù)的方法

    這篇文章主要介紹了JS隨機調(diào)用指定函數(shù)的方法,涉及javascript定時器的相關(guān)使用技巧,需要的朋友可以參考下
    2015-07-07
  • js 替換

    js 替換

    2008-02-02
  • js批量設(shè)置樣式的三種方法不推薦使用with

    js批量設(shè)置樣式的三種方法不推薦使用with

    批量設(shè)置樣式的三種方法:第一種使用JSON/第二種使用cssText/使用第三種with(不推薦使用),感興趣的朋友可以參考下,希望可以幫助到你
    2013-02-02
  • JS?if?else語句(條件判斷語句)的詳細使用

    JS?if?else語句(條件判斷語句)的詳細使用

    條件語句用于基于不同的條件來執(zhí)行不同的動作,下面這篇文章主要給大家介紹了關(guān)于JS?if?else語句(條件判斷語句)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • 利用a標(biāo)簽自動解析URL分析網(wǎng)址實例

    利用a標(biāo)簽自動解析URL分析網(wǎng)址實例

    a標(biāo)簽也和window.location一樣,也有這樣屬性,因此可以利用它來分析網(wǎng)址,下面的實例代碼,大家可以看看
    2014-10-10
  • js 打開新頁面在屏幕中間的實現(xiàn)方法

    js 打開新頁面在屏幕中間的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s 打開新頁面在屏幕中間的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • leaflet的開發(fā)入門教程

    leaflet的開發(fā)入門教程

    leaflet是領(lǐng)先的開源JavaScript庫為移動設(shè)備設(shè)計的互動地圖。接下來通過本文來給大家介紹下leaflet的開發(fā)入門教程,需要的朋友可以參考下
    2016-11-11
  • javascript實現(xiàn)驗證身份證號的有效性并提示

    javascript實現(xiàn)驗證身份證號的有效性并提示

    下面分享的JS腳本是我用過的最完善的身份證號的驗證程序了,因為只有真正的身份證號才能被通過,小伙伴們可以試試。直接復(fù)制運行。
    2015-04-04
  • JS封裝cavans多種濾鏡組件

    JS封裝cavans多種濾鏡組件

    這篇文章主要介紹了JS封裝cavans多種濾鏡組件,本文主要是講解圖片濾鏡的效果以及實現(xiàn)思路,如需更多的濾鏡效果可以研究算法或者參考其他的一些開源庫glfx.js、lena.js等等,需要的朋友可以參考下
    2022-02-02
  • 以JavaScript來實現(xiàn)WordPress中的二級導(dǎo)航菜單的方法

    以JavaScript來實現(xiàn)WordPress中的二級導(dǎo)航菜單的方法

    這篇文章主要介紹了以JavaScript來實現(xiàn)WordPress中的二級導(dǎo)航菜單的方法,文中首先對WordPress基本的PHP導(dǎo)航菜單的做法給出了說明來作為基礎(chǔ),需要的朋友可以參考下
    2015-12-12

最新評論