vue 公眾號H5 使用微信JSAPI 錄音 完整齊全

官方文檔必須首當其沖?

1.微信jsAPI 錄音文檔

2.獲取微信臨時素材文檔

首先H5錄音功能的話 對于普通H5網(wǎng)上是有很多的方法 插件? 但是兼容性很差 特別是對于ios 一開始想的是用H5 做個通用的 但是一圈下來 發(fā)現(xiàn)兼容性就很難受??

好在項目是基于微信公眾號 放棄使用普通H5的想法 轉(zhuǎn)戰(zhàn)使用微信提供的 JSAPI 錄音功能 一下子解決了兼容的問題 微信已經(jīng)幫忙處理完畢?

接下來說一下 注意事項??

在使用微信提供的錄音功能前

1.首先的是進入微信公眾號后臺 公眾號設(shè)置的功能設(shè)置?里填寫“JS接口安全域名” 一定要記得?

2.先引入微信JS 簡單的?

http://res.wx.qq.com/open/js/jweixin-1.6.0.js">(https://res.wx.qq.com/open/js/jweixin-1.6.0.js

3.注冊微信配置 使用wx.config()? ?將要使用的api 填寫到j(luò)sApiList里面 要記得?

注意:簽名問題 一是服務(wù)端算法問題 二是前端當前地址和請求的地址不同 也會出現(xiàn)簽名錯誤? 關(guān)于簽名問題 其他文章也有說明產(chǎn)生的原因

錄音功能 不是立即使用 所以 只需檢測是否配置環(huán)境成功即可 wx.ready()..等回調(diào)方法



.js 配置注冊微信環(huán)境代碼示例

export async function wechatSharefund (columnInfo) {

? const data = await wechatConfig(location.href.split('#')[0]) // 返回的微信信息

? console.log(data)

? if (data.code === 0) {

? ? // 注冊

? ? wx.config({

? ? ? debug: false, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數(shù)罪治,可以在pc端打開汁尺,參數(shù)信息會通過log打出允懂,僅在pc端時才會打印。

? ? ? appId: data.data.appId, // 必填脸爱,公眾號的唯一標識

? ? ? timestamp: data.data.timestamp, // 必填,生成簽名的時間戳

? ? ? nonceStr: data.data.nonceStr, // 必填,生成簽名的隨機串

? ? ? signature: data.data.signature, // 必填载城,簽名

? ? ? jsApiList: [

? ? ? ? 'updateAppMessageShareData',

? ? ? ? 'updateTimelineShareData',

? ? ? ? 'startRecord',

? ? ? ? 'stopRecord',

? ? ? ? 'playVoice',

? ? ? ? 'onVoiceRecordEnd',

? ? ? ? 'uploadVoice',

? ? ? ? 'onVoicePlayEnd',

? ? ? ? 'downloadVoice'

? ? ? ] // 必填,需要使用的JS接口列表

? ? })

? ? // 是否成功

? ? wx.ready(function(res) {

? ? ? console.log([res, 90])

? ? ? wx.updateAppMessageShareData({

? ? ? ? title: '我是自定義首頁7丫汀K咄摺!Aο浮睬澡!好友' + store.getters.doctorId,

? ? ? ? desc: '自定義描述', // 分享描述

? ? ? ? link: 'https://doctor.taiori.com/doctor/hospitalIndex?userParam=' + store.getters.doctorId,

? ? ? ? imgUrl: '', // 分享圖標

? ? ? ? success: function () {

? ? ? ? ? // 設(shè)置成功

? ? ? ? }

? ? ? })

? ? ? wx.updateTimelineShareData({

? ? ? ? title: "我是自定義首頁!眠蚂!圈" + store.getters.doctorId,

? ? ? ? link: 'https://doctor.taiori.com/doctor/hospitalIndex?userParam=' + store.getters.doctorId,

? ? ? ? imgUrl: '',

? ? ? ? success: function() {

? ? ? ? }

? ? ? });


? ? });

? ? // 是否支持指定JS接口

? ? wx.checkJsApi({

? ? ? jsApiList: ['startRecord'], // 需要檢測的JS接口列表煞聪,所有JS接口列表見附錄2,

? ? ? success: function (res) {

? ? ? console.log([res, '114'])

? ? ? store.commit('jsApiList', res)

? ? ? // 以鍵值對的形式返回,可用的api值true河狐,不可用為false

? ? ? // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}

? ? ? }

? ? })

? ? wx.error(function(res){

? ? ? console.log(res)

? ? })

? }



在使用的地方 引入.j文件

import { wechatSharefund } from '.js'

mounted () {

? wechatSharefund()

}

使用簡單的

? touchstart () {

? ? ? console.log('開始錄音')

? ? ? if (this.localId) {

? ? ? ? return

? ? ? }

? ? ? let that = this

? ? ? wx.startRecord({

? ? ? ? success: function(e){

? ? ? ? ? ? // 開始錄音的代碼處理

? ? ? ? },

? ? ? ? cancel: function (e) {

? ? ? ? ? ? console.log(e)

? ? ? ? }

? ? ? })

? ? },

? ? touchend () {

? ? ? console.log('結(jié)束錄音')

? ? ? if (this.localId) {

? ? ? ? return

? ? ? }

? ? ? let that = this

? ? ? clearInterval(this.timer)

? ? ? wx.stopRecord({

? ? ? ? success: function (res) {

? ? ? ? ? // 結(jié)束后的代碼處理

? ? ? ? }

? ? ? })

? ? }



?最后 會涉及到 保存錄音 及 上傳到自己服務(wù)器動作 簡單的 使用相對于的API

微信臨時素材返回的是speex文件 需要解碼成想要的播放MAP3或者wav 前端可直接播放的鏈接 解碼微信有提供方法?

uploadVoice() {

? ? ? ? ? ? ? ? let that = this

? ? ? ? ? ? ? ? // 上傳到微信為臨時素材

? ? ? ? ? ? ? ? wx.uploadVoice({

? ? ? ? ? ? ? ? ? ? localId: this.localId, // 需要上傳的音頻的本地ID米绕,由stopRecord接口獲得

? ? ? ? ? ? ? ? ? ? isShowProgressTips: 1, // 默認為1瑟捣,顯示進度提示

? ? ? ? ? ? ? ? ? ? success: function (res) {

? ? ? ? ? ? ? ? ? ? ? ? // 獲得微信服務(wù)端音頻ID

? ? ? ? ? ? ? ? ? ? ? ? var serverId = res.serverId; // 返回音頻的服務(wù)器端ID

? ? ? ? ? ? ? ? ? ? ? ? console.log(res)

? ? ? ? ? ? ? ? ? ? ? ? // 服務(wù)端提供接口 傳遞 音頻ID 由服務(wù)端處理從微信服務(wù)端下載臨時素材 存為自己的服務(wù)器鏈接

? ? ? ? ? ? ? ? ? ? ? ? // http請求方式: GET,https調(diào)用 https://api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID 請求示例(示例為通過curl命令獲取多媒體文件)

? ? ? ? ? ? ? ? ? ? ? ? // curl -I -G "https://api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID"

? ? ? ? ? ? ? ? ? ? ? ? // $.ajax({

? ? ? ? ? ? ? ? ? ? ? ? //? ? url: 'https://api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID', // 服務(wù)端提供的接口鏈接

? ? ? ? ? ? ? ? ? ? ? ? //? ? type: 'GET',

? ? ? ? ? ? ? ? ? ? ? ? //? ? dataType: "json",

? ? ? ? ? ? ? ? ? ? ? ? //? ? success: function (data) {

? ? ? ? ? ? ? ? ? ? ? ? //? ? ? ? alert('文件已經(jīng)保存到自己的服務(wù)器');

? ? ? ? ? ? ? ? ? ? ? ? //? ? },

? ? ? ? ? ? ? ? ? ? ? ? //? ? error: function (xhr, errorType, error) {

? ? ? ? ? ? ? ? ? ? ? ? //? ? ? ? console.log(error);

? ? ? ? ? ? ? ? ? ? ? ? //? ? }

? ? ? ? ? ? ? ? ? ? ? ? // });

? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? });

? ? ? ? ? ? }

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末馋艺,一起剝皮案震驚了整個濱河市栅干,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌捐祠,老刑警劉巖碱鳞,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異踱蛀,居然都是意外死亡窿给,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進店門率拒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來崩泡,“玉大人,你說我怎么就攤上這事猬膨〗亲玻” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵勃痴,是天一觀的道長谒所。 經(jīng)常有香客問我,道長沛申,這世上最難降的妖魔是什么劣领? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮铁材,結(jié)果婚禮上尖淘,老公的妹妹穿的比我還像新娘。我一直安慰自己著觉,他們只是感情好德澈,可當我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著固惯,像睡著了一般梆造。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上葬毫,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天镇辉,我揣著相機與錄音,去河邊找鬼贴捡。 笑死忽肛,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的烂斋。 我是一名探鬼主播屹逛,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼础废,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了罕模?” 一聲冷哼從身側(cè)響起评腺,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎淑掌,沒想到半個月后蒿讥,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡抛腕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年芋绸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片担敌。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡摔敛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出全封,到底是詐尸還是另有隱情马昙,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布售貌,位于F島的核電站给猾,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏颂跨。R本人自食惡果不足惜敢伸,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望恒削。 院中可真熱鬧池颈,春花似錦、人聲如沸钓丰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽携丁。三九已至琢歇,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間梦鉴,已是汗流浹背李茫。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留肥橙,地道東北人魄宏。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像存筏,于是被迫代替她去往敵國和親宠互。 傳聞我的和親對象是個殘疾皇子味榛,可洞房花燭夜當晚...
    茶點故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容