<rt id="uz9ct"><noframes id="uz9ct">
  • \r\n  

    歡迎來到微信jsapi測試界面-V型知識庫<\/h3><\/center>\r\n     

    基礎(chǔ)接口之判斷當(dāng)前客戶端是否支持指定的js接口<\/p>   \r\n     
    \r\n      圖像接口<\/h3>\r\n      拍照或從手機相冊中選圖接口<\/span>
    \r\n      chooseImage<\/button>
    \r\n      預(yù)覽圖片接口<\/span>
    \r\n      previewImage<\/button>
    \r\n      上傳圖片接口<\/span>
    \r\n      uploadImage<\/button>
    \r\n      下載圖片接口<\/span>
    \r\n      downloadImage<\/button>
    \r\n  顯示圖片\r\n  
    \r\n  

    国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

    首頁 微信小程式 微信開發(fā) 微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    Mar 26, 2017 pm 02:15 PM
    微信開發(fā)

    參數(shù)

    ? 描述
    #appId 公眾號碼的唯一標(biāo)識應(yīng)用id
    timestamp #產(chǎn)生簽章的時間戳記
    nonceStr 產(chǎn)生簽章的隨機串
    signature 簽名

    #上述表格中的四個參數(shù)是初始化呼叫微信jsapi的憑證,咱們在前幾節(jié)已經(jīng)反覆說明如何使用了,在這裡就不在貼出如何產(chǎn)生上述四個參數(shù)了

    完整的jsp程式碼如下:

    ##
    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <base href="<%=basePath%>">
        <title>微信jsapi測試-V型知識庫</title>
        <meta name="viewport" content="width=320.1,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
       <script src="http://res.wx.qq.com/open/js/jweixin-1.1.0.js"> </script> 
    <scriptsrc="http://libs.baidu.com/jquery/2.0.0/jquery.js"></script>
      </head>
      <body>
      <center><h3>歡迎來到微信jsapi測試界面-V型知識庫</h3></center>
         <p>基礎(chǔ)接口之判斷當(dāng)前客戶端是否支持指定的js接口</p>   
         <input type="button" value="checkJSAPI" id="checkJsApi"><br>
          <h3 id="menu-image">圖像接口</h3>
          <span class="desc">拍照或從手機相冊中選圖接口</span><br>
          <button class="btn btn_primary" id="chooseImage">chooseImage</button><br>
          <span class="desc">預(yù)覽圖片接口</span><br>
          <button class="btn btn_primary" id="previewImage">previewImage</button><br>
          <span class="desc">上傳圖片接口</span><br>
          <button class="btn btn_primary" id="uploadImage">uploadImage</button><br>
          <span class="desc">下載圖片接口</span><br>
          <button class="btn btn_primary" id="downloadImage">downloadImage</button><br>
      顯示圖片<img src="/static/imghw/default1.png"  data-src=""id="  class="lazy" alt=""id="faceImg"data-bd-imgshare-binded="1">
      <br>
      <script type="text/javascript">
      wx.config({  
        debug: true, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數(shù),可以在pc端打開,參數(shù)信息會通過log打出,僅在pc端時才會打印。  
        appId: &#39;${appId}&#39;, // 必填,公眾號的唯一標(biāo)識  
        timestamp: &#39;${ timestamp}&#39; , // 必填,生成簽名的時間戳  
        nonceStr: &#39;${ nonceStr}&#39;, // 必填,生成簽名的隨機串  
        signature: &#39;${ signature}&#39;,// 必填,簽名,見附錄1  
        jsApiList: [&#39;checkJsApi&#39;,
                    &#39;chooseImage&#39;,
                    &#39;previewImage&#39;,
                     &#39;uploadImage&#39;,
                     &#39;downloadImage&#39;
                   ] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2  
    });  
    wx.ready(function(){  
        // 5 圖片接口
      // 5.1 拍照、本地選圖
      var images = {
        localId: [],
        serverId: []
      };
      document.querySelector(&#39;#chooseImage&#39;).onclick = function () {
        wx.chooseImage({
          success: function (res) {
            images.localId = res.localIds;
            alert(&#39;已選擇 &#39; + res.localIds.length + &#39; 張圖片&#39;);
    $("#faceImg").attr("src", res.localIds[0]);//顯示圖片到頁面上
          }
        });
      };
      // 5.2 圖片預(yù)覽
      document.querySelector(&#39;#previewImage&#39;).onclick = function () {
        wx.previewImage({
          current: &#39;http://www.vxzsk.com/upload//bf04c9b5-5699-421d-900e-3b68bbe58a8920160816.jpg&#39;,
          urls: [
            &#39;http://www.vxzsk.com/upload//bf04c9b5-5699-421d-900e-3b68bbe58a8920160816.jpg&#39;,
            &#39;http://www.vxzsk.com/upload//bf04c9b5-5699-421d-900e-3b68bbe58a8920160816.jpg&#39;,
            &#39;http://www.vxzsk.com/upload//bf04c9b5-5699-421d-900e-3b68bbe58a8920160816.jpg&#39;
          ]
        });
      };
      // 5.3 上傳圖片
      document.querySelector(&#39;#uploadImage&#39;).onclick = function () {
        if (images.localId.length == 0) {
          alert(&#39;請先使用 chooseImage 接口選擇圖片&#39;);
          return;
        }
        var i = 0, length = images.localId.length;
        images.serverId = [];
        function upload() {
          wx.uploadImage({
            localId: images.localId[i],
            success: function (res) {
              i++;
              //alert(&#39;已上傳:&#39; + i + &#39;/&#39; + length);
              images.serverId.push(res.serverId);
              if (i < length) {
                upload();
              }
            },
            fail: function (res) {
              alert(JSON.stringify(res));
            }
          });
        }
        upload();
      };
      // 5.4 下載圖片
      document.querySelector(&#39;#downloadImage&#39;).onclick = function () {
        if (images.serverId.length === 0) {
          alert(&#39;請先使用 uploadImage 上傳圖片&#39;);
          return;
        }
        var i = 0, length = images.serverId.length;
        images.localId = [];
        function download() {
          wx.downloadImage({
            serverId: images.serverId[i],
            success: function (res) {
              i++;
              alert(&#39;已下載:&#39; + i + &#39;/&#39; + length);
              images.localId.push(res.localId);
              if (i < length) {
                download();
              }
            }
          });
        }
        download();
      };
    });  
     //初始化jsapi接口 狀態(tài)
    wx.error(function (res) {
      alert("調(diào)用微信jsapi返回的狀態(tài):"+res.errMsg);
    });
     </script>
      </body>
    </html>
    #1,上述程式碼html按鈕程式碼功能已經(jīng)描述的很清楚了,每點擊一個按鈕觸發(fā)一個js功能函數(shù)。

    2、點擊上傳圖片按鈕之前首先要點擊選擇圖片按鈕功能,上傳圖片成功後會返回serverid,所以本人認為這裡非常梗,調(diào)用微信jsapi上傳接口,我的圖片到底上傳到哪裡去了呢?其實我們把圖片上傳到微信伺服器上了也就是臨時素材裡面去了,可登陸微信官方管理平臺查看,你也可以呼叫微信臨時素材介面取得圖片。

    3、透過以上程式碼,我們就已經(jīng)把圖片上傳到微信伺服器了,但是我們上傳到微信伺服器的圖片只能保存3天,所以上傳完之後我們要把圖片下載到我們的本地伺服器,這裡用到微信下載多媒體介面http://file.api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID?其中media_id就是我們上面的serverId ,所以我們就可以把圖片下載到本地了,程式碼如下

    package com.test.weixin;
    import net.sf.json.JSONObject;
    import org.apache.log4j.Level;
    import org.apache.log4j.LogManager;
    import org.apache.log4j.Logger;
    import org.apache.log4j.Priority;
    import org.springframework.util.StringUtils;
    import java.io.*;
    import java.net.HttpURLConnection;
    import java.net.MalformedURLException;
    import java.net.URL;
    import java.net.URLConnection;
    /****
     * 
     * @author V型知識庫 www.vxzsk.com
     *
     */
    public class DloadImgUtil {
      /**
       * 根據(jù)內(nèi)容類型判斷文件擴展名
       *
       * @param contentType 內(nèi)容類型
       * @return
       */
      public static String getFileexpandedName(String contentType) {
        String fileEndWitsh = "";
        if ("image/jpeg".equals(contentType))
          fileEndWitsh = ".jpg";
        else if ("audio/mpeg".equals(contentType))
          fileEndWitsh = ".mp3";
        else if ("audio/amr".equals(contentType))
          fileEndWitsh = ".amr";
        else if ("video/mp4".equals(contentType))
          fileEndWitsh = ".mp4";
        else if ("video/mpeg4".equals(contentType))
          fileEndWitsh = ".mp4";
        return fileEndWitsh;
      }
      /**
       * 獲取媒體文件
       * @param accessToken 接口訪問憑證
       * @param mediaId 媒體文件id
       * @param savePath 文件在本地服務(wù)器上的存儲路徑
       * */
      public static String downloadMedia(String accessToken, String mediaId, String savePath) {
        try {
          accessToken = DloadImgUtil.getAccessToken();
        } catch (IOException e) {
          e.printStackTrace();
        }
        String filePath = null;
        // 拼接請求地址
        String requestUrl = "http://file.api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID";
        requestUrl = requestUrl.replace("ACCESS_TOKEN", accessToken).replace("MEDIA_ID", mediaId);
        try {
          URL url = new URL(requestUrl);
          HttpURLConnection conn = (HttpURLConnection) url.openConnection();
          conn.setDoInput(true);
          conn.setRequestMethod("GET");
          if (!savePath.endsWith("/")) {
            savePath += "/";
          }
          // 根據(jù)內(nèi)容類型獲取擴展名
          String fileExt = DloadImgUtil .getFileexpandedName(conn.getHeaderField("Content-Type"));
          // 將mediaId作為文件名
          filePath = savePath + mediaId + fileExt;
          BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
          FileOutputStream fos = new FileOutputStream(new File(filePath));
          byte[] buf = new byte[8096];
          int size = 0;
          while ((size = bis.read(buf)) != -1)
            fos.write(buf, 0, size);
          fos.close();
          bis.close();
          conn.disconnect();
          String info = String.format("下載媒體文件成功,filePath=" + filePath);
          System.out.println(info);
        } catch (Exception e) {
          filePath = null;
          String error = String.format("下載媒體文件失?。?s", e);
          System.out.println(error);
        }
        return filePath;
      }
      /***
          * 獲取acess_token 
          * 來源www.vxzsk.com
          * @return
          */
         public static String getAccessToken(){
                String appid="你公眾號基本設(shè)置里的應(yīng)用id";//應(yīng)用ID
                String appSecret="你公眾號基本設(shè)置里的應(yīng)用密鑰";//(應(yīng)用密鑰)
                String url ="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="+appid+"&secret="+appSecret+"";
                String backData=DloadImgUtil.sendGet(url, "utf-8", 10000);
                String accessToken = (String) JSONObject.fromObject(backData).get("access_token");  
                return accessToken;
         }
         /***
             * 模擬get請求
             * @param url
             * @param charset
             * @param timeout
             * @return
             */
             public static String sendGet(String url, String charset, int timeout)
              {
                String result = "";
                try
                {
                  URL u = new URL(url);
                  try
                  {
                    URLConnection conn = u.openConnection();
                    conn.connect();
                    conn.setConnectTimeout(timeout);
                    BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream(), charset));
                    String line="";
                    while ((line = in.readLine()) != null)
                    {
                      result = result + line;
                    }
                    in.close();
                  } catch (IOException e) {
                    return result;
                  }
                }
                catch (MalformedURLException e)
                {
                  return result;
                }
                return result;
              }
    }
    效果圖如下:


    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    #選擇圖片彈出的圖片詳情

    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    #上傳成功後傳回的serverId

    微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法

    以上是微信開發(fā)之微信jsapi選擇圖片,上傳圖片,預(yù)覽與下載圖片方法的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

    本網(wǎng)站聲明
    本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

    熱AI工具

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅(qū)動的應(yīng)用程序,用於創(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 教程
    1601
    29
    PHP教程
    1502
    276
    PHP微信開發(fā):如何實作訊息加密解密 PHP微信開發(fā):如何實作訊息加密解密 May 13, 2023 am 11:40 AM

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

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

    在微信公眾號開發(fā)中,投票功能經(jīng)常被運用。投票功能是讓使用者快速參與互動的好方式,也是舉辦活動和調(diào)查意見的重要工具。本文將為您介紹如何使用PHP實作微信投票功能。在取得微信公眾號授權(quán)首先,你需要取得微信公眾號的授權(quán)。在微信公眾平臺上,你需要設(shè)定微信公眾號碼的api地址、官方帳號和公眾號碼對應(yīng)的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ā)工具。一、準(zhǔn)備工作開發(fā)微信群發(fā)工具,我們需要掌握以下幾個技術(shù)點:PHP基礎(chǔ)知識微信公眾平臺開發(fā)開發(fā)工具:Sub

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

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

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

    在微信公眾號開發(fā)中,使用者標(biāo)籤管理是一個非常重要的功能,可以讓開發(fā)者更了解和管理自己的使用者。本篇文章將介紹如何使用PHP實作微信使用者標(biāo)籤管理功能。一、取得微信用戶openid在使用微信用戶標(biāo)籤管理功能之前,我們首先需要取得用戶的openid。在微信公眾號開發(fā)中,透過使用者授權(quán)的方式取得openid是比較常見的做法。在使用者授權(quán)完成後,我們可以透過以下程式碼取得用

    PHP微信開發(fā):如何實作群發(fā)訊息傳送記錄 PHP微信開發(fā):如何實作群發(fā)訊息傳送記錄 May 13, 2023 pm 04:31 PM

    隨著微信成為了人們生活中越來越重要的通訊工具,其敏捷的訊息傳遞功能迅速受到廣大企業(yè)和個人的青睞。對企業(yè)而言,將微信發(fā)展為一個行銷平臺已經(jīng)成為趨勢,而微信開發(fā)的重要性也逐漸凸顯。在其中,群發(fā)功能更是被廣泛使用,那麼,作為PHP程式設(shè)計師,如何實現(xiàn)群發(fā)訊息發(fā)送記錄呢?以下將為大家簡單介紹一下。 1.了解微信公眾號相關(guān)開發(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

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

    See all articles