亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
1.配置
2.調(diào)起拍照/相冊
3.上傳照片
js:
Controller
getInputStream
service
首頁 微信小程序 微信開發(fā) 微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片方法

微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片方法

Mar 09, 2017 pm 03:33 PM
微信開發(fā)

本文介紹微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片方法

1.配置

頁面引入通過jssdk授權后,傳入wx對象,首先配置需要的接口


wx.config({????/*?debug:?true,??*/
????appId:?appid,?
????timestamp:?timestamp,?
????nonceStr:?nonceStr,?
????signature:?signature,
????jsApiList:?[
?????????'chooseImage',//拍照或從手機相冊中選圖接口
?????????'previewImage',//預覽圖片接口
?????????'uploadImage',//上傳圖片接口
?????????'downloadImage'//下載圖片接口
?  ]
?});


?

2.調(diào)起拍照/相冊

將下面的方法放在需要點擊事件的回調(diào)函數(shù)里面?


wx.chooseImage({
????count:?1,?
????sizeType:?['compressed'],?
????sourceType:?['album',?'camera'],?
????success:?function?(res)?{
    //var?localIds?=?res.localIds;
???? ?$('.driver-card?img').prop('src',res.localIds[0]);
???? ?uploadPhoto.uploadToWeixinServer(res.localIds[0],'car')
???}
});


?

這時我們可以看到這樣的效果,代表調(diào)起成功了!chooseImage方法的成功回調(diào)里,我將選中的照片賦值給需要顯示的img的src(因為我這里只有一張照片,如果有多張用循環(huán)賦值即可),這樣一來,就可以直接顯示剛剛拍照/相冊里選中的照片了

微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片方法

?

3.上傳照片

在上面chooseImage的success回調(diào)里面,可以看到我調(diào)用了uploadToWeixinServer方法,參數(shù)為本地照片的Id


uploadToWeixinServer:?1


調(diào)用uploadImage接口后,將圖片上傳到了微信服務器,返回圖片的ID,這個時候需要用ajax異步上傳到自己的服務器里,調(diào)用微信提供的“獲取臨時素材”接口。當然也不一定是選擇完照片就立即上傳,還得根據(jù)實際業(yè)務需求出發(fā),也有是靜默上傳(沒有進度提示),也有是在最終提交表單時一起上傳

js:


uploadToOwnerServer:?function(serverId,type){
????????????$.ajax({
????????????????data:?{serverId:serverId,type:type},
????????????????type?:?"POST",
????????????????url?:?WX_ROOT?+?"wechat/uploadPhoto",
????????????????success?:?function(json)?{????????????????????if?(json)?{????????????????????????var?data?=?JSON.parse(json.data);????????????????????????if?('car'?==?type)?
????????????????????????????uploadPhoto.options.carImage?=?data.path?+?data.name????????????????????????else
????????????????????????????uploadPhoto.options.idCardImage?=?data.path?+?data.name
????????????????????????
????????????????????}
????????????????}
????????????});
????????},


?

Controller


@RequestMapping(value?=?"/uploadPhoto",?method?=?RequestMethod.POST)????public?@ResponseBody?HttpResult?uploadPhoto(@RequestParam?String?serverId,@RequestParam?String?type)?throws?Exception{
????????LOGGER.info("RestFul?of?uploadPhoto?parameters?serverId:{},type:{}",serverId,type);????????
????????try?{????????????/**?將圖片保存到本地服務器?**/
????????????String?photoName?=?type?+?new?Date().getTime()?+?UUID.randomUUID().toString();????????????
????????????//文件路徑不存在則創(chuàng)建
????????????File?saveFile?=?new?File(PIC_PATH?+?type);????????????if?(!saveFile.mkdir())?saveFile.mkdir();
????????????
????????????wechatService.saveImageToDisk(serverId,?photoName,?PIC_PATH?+?type?+?"/");
????????????LOGGER.info("Download?the?picture?from?weixin?server?pathL:{}",PIC_PATH?+?type?+?"/");
????????????JSONObject?data?=?new?JSONObject();
????????????data.put("name",?type?+?"/"?+?photoName+".jpg");
????????????data.put("path",?PIC_SERVER?+?"/");
????????????
????????????HttpResult?rs?=?new?HttpResult();
????????????rs.setCode(200);
????????????rs.setData(data.toJSONString());
????????????LOGGER.info("Download?the?picture?from?weixin?server?is?successful!serverId:{},photoName:{}",serverId,photoName);
????????????LOGGER.info("HttpResult?data:{}",rs.getData());????????????return?rs;
????????}?catch?(Exception?e)?{
????????????LOGGER.error("Download?the?picture?from?weixin?server?is?error",serverId);????????????return?null;
????????}


這里我使用了一個UUID生成主鍵規(guī)則,通過類型+時間戳+唯一字符串定義圖片名稱。如果上傳成功,同時又將自己服務器的圖片地址返回給前端。

?

getInputStream

調(diào)用微信提供的獲取臨時素材接口下載還在微信服務器上的圖片,參數(shù)為前端提交上來的媒體文件ID,最終將文件轉(zhuǎn)化為輸入流對象


/**
?????*?根據(jù)文件id下載文件?
?????*?@param?accessToken
?????*?@param?mediaId?
?????*?@return?文件流對象?????*/
????public?InputStream?getInputStream(String?accessToken,?String?mediaId)?{??
????????InputStream?is?=?null;??
????????String?url?=?"http://ipnx.cn/"+?accessToken?+?"&media_id="?+?mediaId;??
????????try?{??
????????????URL?urlGet?=?new?URL(url);??
????????????HttpURLConnection?http?=?(HttpURLConnection)?urlGet.openConnection();??
????????????http.setRequestMethod("GET");?//?必須是get方式請求??
????????????http.setRequestProperty("Content-Type","application/x-www-form-urlencoded");??
????????????http.setDoOutput(true);??
????????????http.setDoInput(true);??
????????????System.setProperty("sun.net.client.defaultConnectTimeout",?"30000");//?連接超時30秒??
????????????System.setProperty("sun.net.client.defaultReadTimeout",?"30000");?//?讀取超時30秒??????????????http.connect();??
????????????//?獲取文件轉(zhuǎn)化為byte流??
????????????is?=?http.getInputStream();??
????????}?catch?(Exception?e)?{??
????????????LOGGER.error("Failed?to?convert?inputStream?from?weixin?server,accessToken:{},mediaId:{}",accessToken,mediaId);
????????}??
????????return?is;??
??
????}


?

service

通過循環(huán)解析流對象,將文件寫入自己的服務器


public?void?saveImageToDisk(String?mediaId,?String?picName,?String?picPath)?throws?Exception?{??
????????String?accessToken?=?getBaseAccessToken();
????????InputStream?inputStream?=?getInputStream(accessToken,?mediaId);?
????????
????????//?循環(huán)取出流中的數(shù)據(jù)
????????byte[]?data?=?new?byte[1024];??
????????int?len?=?0;??
????????FileOutputStream?fileOutputStream?=?null;??
????????try?{??
????????????fileOutputStream?=?new?FileOutputStream(picPath+picName+".jpg");??
????????????while?((len?=?inputStream.read(data))?!=?-1)?{??
????????????????fileOutputStream.write(data,?0,?len);??
????????????}??
????????????LOGGER.info("Write?the?fileInputStream?is?successful");
????????}?catch?(IOException?e)?{??
????????????LOGGER.error("Write?the?fileInputStream?is?error");
????????}?finally?{??
????????????if?(inputStream?!=?null)?{??
????????????????try?{??
????????????????????inputStream.close();??
????????????????}?catch?(IOException?e)?{??
????????????????????LOGGER.error("Close?the?fileInputStream?is?error");
????????????????}??
????????????}??
????????????if?(fileOutputStream?!=?null)?{??
????????????????try?{??
????????????????????fileOutputStream.close();??
????????????????}?catch?(IOException?e)?{??
????????????????????LOGGER.error("Close?the?fileOutputStream?is?error");
????????????????}??
????????????}??
????????}??
????}


?

以上是微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片方法的詳細內(nèi)容。更多信息請關注PHP中文網(wǎng)其他相關文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
PHP微信開發(fā):如何實現(xiàn)消息加密解密 PHP微信開發(fā):如何實現(xiàn)消息加密解密 May 13, 2023 am 11:40 AM

PHP是一種開源的腳本語言,廣泛應用于Web開發(fā)和服務器端編程,尤其在微信開發(fā)中得到了廣泛的應用。如今,越來越多的企業(yè)和開發(fā)者開始使用PHP進行微信開發(fā),因為它成為了一款真正的易學易用的開發(fā)語言。在微信開發(fā)中,消息的加密和解密是一個非常重要的問題,因為它們涉及到數(shù)據(jù)的安全性。對于沒有加密和解密方式的消息,黑客可以輕松獲取到其中的數(shù)據(jù),對用戶造成威脅

PHP微信開發(fā):如何實現(xiàn)投票功能 PHP微信開發(fā):如何實現(xiàn)投票功能 May 14, 2023 am 11:21 AM

在微信公眾號開發(fā)中,投票功能經(jīng)常被運用。投票功能是讓用戶快速參與互動的好方式,也是舉辦活動和調(diào)查意見的重要工具。本文將為您介紹如何使用PHP實現(xiàn)微信投票功能。獲取微信公眾號授權首先,你需要獲取微信公眾號的授權。在微信公眾平臺上,你需要配置微信公眾號的api地址、官方賬號和公眾號對應的token。在我們使用PHP語言開發(fā)的過程中,我們需要使用微信官方提供的PH

用PHP開發(fā)微信群發(fā)工具 用PHP開發(fā)微信群發(fā)工具 May 13, 2023 pm 05:00 PM

隨著微信的普及,越來越多的企業(yè)開始將其作為營銷工具。而微信群發(fā)功能,則是企業(yè)進行微信營銷的重要手段之一。但是,如果只依靠手動發(fā)送,對于營銷人員來說是一件極為費時費力的工作。所以,開發(fā)一款微信群發(fā)工具就顯得尤為重要。本文將介紹如何使用PHP開發(fā)微信群發(fā)工具。一、準備工作開發(fā)微信群發(fā)工具,我們需要掌握以下幾個技術點:PHP基礎知識微信公眾平臺開發(fā)開發(fā)工具:Sub

PHP微信開發(fā):如何實現(xiàn)客服聊天窗口管理 PHP微信開發(fā):如何實現(xiàn)客服聊天窗口管理 May 13, 2023 pm 05:51 PM

微信是目前全球用戶規(guī)模最大的社交平臺之一,隨著移動互聯(lián)網(wǎng)的普及,越來越多的企業(yè)開始意識到微信營銷的重要性。在進行微信營銷時,客服服務是至關重要的一環(huán)。為了更好地管理客服聊天窗口,我們可以借助PHP語言進行微信開發(fā)。一、PHP微信開發(fā)簡介PHP是一種開源的服務器端腳本語言,廣泛運用于Web開發(fā)領域。結合微信公眾平臺提供的開發(fā)接口,我們可以使用PHP語言進行微信

PHP微信開發(fā):如何實現(xiàn)用戶標簽管理 PHP微信開發(fā):如何實現(xiàn)用戶標簽管理 May 13, 2023 pm 04:31 PM

在微信公眾號開發(fā)中,用戶標簽管理是一個非常重要的功能,可以讓開發(fā)者更好地了解和管理自己的用戶。本篇文章將介紹如何使用PHP實現(xiàn)微信用戶標簽管理功能。一、獲取微信用戶openid在使用微信用戶標簽管理功能之前,我們首先需要獲取用戶的openid。在微信公眾號開發(fā)中,通過用戶授權的方式獲取openid是比較常見的做法。在用戶授權完成后,我們可以通過以下代碼獲取用

PHP微信開發(fā):如何實現(xiàn)群發(fā)消息發(fā)送記錄 PHP微信開發(fā):如何實現(xiàn)群發(fā)消息發(fā)送記錄 May 13, 2023 pm 04:31 PM

隨著微信成為了人們生活中越來越重要的一個通訊工具,其敏捷的消息傳遞功能迅速受到廣大企業(yè)和個人的青睞。對于企業(yè)而言,將微信發(fā)展為一個營銷平臺已經(jīng)成為趨勢,而微信開發(fā)的重要性也逐漸凸顯。在其中,群發(fā)功能更是被廣泛使用,那么,作為PHP程序員,如何實現(xiàn)群發(fā)消息發(fā)送記錄呢?下面將為大家簡單介紹一下。1.了解微信公眾號相關開發(fā)知識在了解如何實現(xiàn)群發(fā)消息發(fā)送記錄之前,我

使用PHP實現(xiàn)微信公眾號開發(fā)的步驟 使用PHP實現(xiàn)微信公眾號開發(fā)的步驟 Jun 27, 2023 pm 12:26 PM

如何使用PHP實現(xiàn)微信公眾號開發(fā)微信公眾號已經(jīng)成為了很多企業(yè)推廣和互動的重要渠道,而PHP作為一種常用的Web語言,也可以用來進行微信公眾號的開發(fā)。本文將介紹一下使用PHP實現(xiàn)微信公眾號開發(fā)的具體步驟。第一步:獲取微信公眾號的開發(fā)者賬號在開始微信公眾號開發(fā)之前,需要先去申請一個微信公眾號的開發(fā)者賬號。具體的注冊流程可以參見微信公眾平臺的官方網(wǎng)

如何使用PHP進行微信開發(fā)? 如何使用PHP進行微信開發(fā)? May 21, 2023 am 08:37 AM

隨著互聯(lián)網(wǎng)和移動智能設備的發(fā)展,微信成為了社交和營銷領域不可或缺的一部分。在這個越來越數(shù)字化的時代,如何使用PHP進行微信開發(fā)已經(jīng)成為了很多開發(fā)者的關注點。本文主要介紹如何使用PHP進行微信開發(fā)的相關知識點,以及其中的一些技巧和注意事項。一、開發(fā)環(huán)境準備在進行微信開發(fā)之前,首先需要準備好相應的開發(fā)環(huán)境。具體來說,需要安裝PHP的運行環(huán)境,以及微信公眾平臺提

See all articles