搜尋
首頁微信小程式小程式開發關於微信JS-SDK選取手機照片上傳的功能

關於微信JS-SDK選取手機照片上傳的功能

Jun 27, 2018 pm 02:24 PM
jssdk上傳微信

這篇文章主要為大家詳細介紹了微信JS-SDK選取手機照片上傳功能,具有一定的參考價值,有興趣的小夥伴們可以參考一下

專案中遇到需要選取照片上傳的需求,因為網頁是運行在微信的瀏覽器裡面,所以用微信的js-sdk 提供的選取照片功能,來進行專案開發。實際開發需要用到微信web開發者工具,詳細參考連結:https://mp.weixin.qq.com/wiki/10/e5f772f4521da17fa0d7304f68b97d7e.html。

1.設定微信JS-SDK相關檔案

1)、JSSDk使用最新的1.2.0版本:https://res.wx.qq.com /open/js/jweixin-1.2.0.js。

  ios網頁開發適配問題:

  變化:1.2.0以下版本的JSSDK不再支援透過使用chooseImage api傳回的localld以如:"img src=wxLocalResource: //50114659201332」的方式預覽圖片。

  適配建議:直接將JSSDK升級為1.2.0最新版本即可協助頁面自動適配,但在部分場景下可能無效,此時可以使用getLocalImgData 介面直接取得資料。

(後附詳解程式碼)

2)、jsapiSign.js檔:

/**
 * 使用jssdk接口的页面,必须引用该文件
 * actionUrl:后台服务请求地址
 * url:微信jssdk授权页面地址
 */
$.post("/getJsapiSign", {'url':location.href.split('#')[0]}, function(data) {
 wx.config({
 debug : false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
 appId : data.appid, // 必填,公众号的唯一标识
 timestamp : data.timestamp, // 必填,生成签名的时间戳
 nonceStr : data.noncestr, // 必填,生成签名的随机串
 signature : data.signature,// 必填,签名,见附录1
 jsApiList : [ 'checkJsApi',
  'onMenuShareTimeline',
  'onMenuShareAppMessage',
  'onMenuShareQQ',
  'onMenuShareWeibo',
  'hideMenuItems',
  'showMenuItems',
  'hideAllNonBaseMenuItem',
  'showAllNonBaseMenuItem',
  'translateVoice',
  'startRecord',
  'stopRecord',
  'onRecordEnd',
  'playVoice',
  'pauseVoice',
  'stopVoice',
  'uploadVoice',
  'downloadVoice',
  'chooseImage',
  'previewImage',
  'uploadImage',
  'downloadImage',
  'getNetworkType',
  'openLocation',
  'getLocation',
  'hideOptionMenu',
  'showOptionMenu',
  'closeWindow',
  'scanQRCode',
  'chooseWXPay',
  'openProductSpecificView',
  'addCard',
  'chooseCard',
  'openCard',
  'getLocalImgData'
 ]
 });
 
 wx.error(function(res) {
 alert("wx.config加载失败");
 });
}, 'json');

2.具體實作過程

1)、選取照片

這裡使用微信js-sdk 的chooseImage 方法,得到照片在本地儲存的id,十分簡單:

2)、取得照片資料

根據微信的官方開發文檔,得到的localId 可以直接作為img 元素的src 屬性進行顯示

3)、照片上傳

這裡使用微信js-sdk 的uploadImage 方法

wx.chooseImage({
 count: 1, // 默认9
 sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
 success: function (res) {
  var localIds = res.localIds; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
  wx.uploadImage({
  localId: localIds[0], // 需要上传的图片的本地ID,由chooseImage接口获得
  isShowProgressTips: 1, // 默认为1,显示进度提示
  success: function (res) {
   var medias = {'lid':localIds[0].toString(), 'sid':res.serverId};
   $('#img_media').attr('src', medias.lid);
  },fail:function(res){
   alert("上传失败");
  }
  });
 }
});

3.iOS WKWebview 網頁開發適配

# JSAPI相關適配

1)、將不再支援cache

變更:在WKWebview中將暫不支援cache jsapi。

適配建議:所有使用此api的開發者可去掉頁面相關邏輯。

2)、頁面透過LocalID預覽圖片

變更:1.2.0以下版本的JSSDK不再支援透過使用chooseImage api傳回的localld以如:」img src=wxLocalResource:// 50114659201332”的方式預覽圖片。

適合建議:直接將JSSDK升級為1.2.0最新版本即可幫助頁面自動適配,但在部分場景下可能無效,此時可以使用getLocalImgData 介面來直接取得資料。 (目前JSSDk線上版本是1.0.0 和1.1.0,更新版本為1.2.0 ,https://res.wx.qq.com/open/js/jweixin-1.2.0. js  )

if (window.__wxjs_is_wkwebview) {
 wx.getLocalImgData({
 localId: localIds[0], // 图片的localID
 success: function (res) {
  var localData = res.localData; // localData是图片的base64数据,可以用img标签显示
  localData = localData.replace('jgp', 'jpeg');//iOS 系统里面得到的数据,类型为 image/jgp,因此需要替换一下
  $('#img_media').attr('src', localData);
 },fail:function(res){
  alert("显示失败");
 }
 });
}

三、有使用JSSDK,並且使用了wx.config進行權限授權需關注jsapi呼叫的失敗問題

變更:WKWebview的內部實作變更使我們對微信內的頁面jsapi權限管理做了一定邏輯上的調整,有極小可能會發生先前授權正常的jsapi取得權限不正常,進而導致呼叫jsapi失敗。

適合建議:


1. iOS微信6.5.1,WKWebview在此版本中已知有以下問題:頁面使用HTML5的History API pushState; popstate;      replaceState等控制頁面導覽(典型的單一應用程式頁),同時使用JSSDK的wx.config為jsapi授權,此時大幾率會出現jsapi因為無權限而呼叫失敗的問題。在6.5.1中頁面若可能的情況下,可使用Anchor hash技術取代History技術來解決此問題。

2. iOS微信6.5.2及其之後版本,將不會存在以上問題,但不能100%確認有使用到history或hash技術更改頁面導航地址的頁面完全沒有此類問題,依然需要開發者註意關注此類問題。 本文已被整理到了《JavaScript微信開發技巧總結》,歡迎大家學習閱讀。

為大家推薦現在關注度比較高的微信小程式教學一篇:《微信小程式開發教學》小編為大家精心整理的,希望喜歡。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網! 相關推薦:

######微信小程式中支付後呼叫SDK的非同步通知及驗證處理訂單方法###############微信小程式中的網路請求(post請求與get請求)#########################

以上是關於微信JS-SDK選取手機照片上傳的功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中