PHP は、フォト アルバムを選択し、写真を撮ってアップロードする WeChat JS-SDK インターフェイス メソッドを実装します。

墨辰丷
リリース: 2023-03-28 12:04:02
オリジナル
2004 人が閲覧しました

この記事では、PHP で WeChat JS-SDK インターフェースを実装してアルバムを選択し、写真を撮ってアップロードする方法を主に紹介します。これには、PHP WeChat インターフェースの呼び出しスキルが含まれます。必要な友人はそれを参照できます。

理解: WeChat アップロード インターフェイスは、写真を撮るかローカル写真を選択し、WeChat サーバーにアップロードし、ID を取得し、トークンとこの ID を通じて写真を取得し、サーバーに保存します。

レンダリング:

WeChat jsインターフェースを介して基礎となるプログラムを呼び出します。

jsファイルを導入して設定する必要があります。

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
wx.config({
  debug: false,
  appId: &#39;wxed7996e9ad58345d&#39;,
  timestamp: 1449717454,
  nonceStr: &#39;asdfasdfasdf&#39;,
  signature: &#39;b74fb4ab4790172d2ab7e58f0051a1523aaa4803&#39;,
  jsApiList: [
    &#39;chooseImage&#39;,
    &#39;uploadImage&#39;
  ]
});
ログイン後にコピー

ここで、appId は WeChat パブリック プラットフォーム ID、timestamp は現在のタイムスタンプ、nonceStr はランダムな文字列、signature は署名です。

signature は最も重要なパラメータです。それを入手するには多くの手順が必要です。

まず、access_token を取得します。これは 2 時間存続でき、1 日 2000 回の取得が許可されています。それを超える場合は取得できません。

// 获取access_token 两小时有效
private function get_access_token(){
    $appid = C(&#39;oauth_config.appid&#39;);
    $appsecret = C(&#39;oauth_config.appsecret&#39;);
    $url = &#39;https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=&#39;.$appid.&#39;&secret=&#39;.$appsecret;
    $rurl = file_get_contents($url);
    $rurl = json_decode($rurl,true);
    if(array_key_exists(&#39;errcode&#39;,$rurl)){
      return false;
    }else{
      $access_token = $rurl[&#39;access_token&#39;];
      return $access_token;
    }
}
ログイン後にコピー

次に、jsticketを取得します

// 获取jsticket 两小时有效
private function getjsticket(){ // 只允许本类调用,继承的都不可以调用,公开调用就更不可以了
    $access_token = $this->get_access_token();
    $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$access_token."&type=jsapi"; // 两小时有效
    $rurl = file_get_contents($url);
    $rurl = json_decode($rurl,true);
    if($rurl[&#39;errcode&#39;] != 0){
      return false;
    }else{
      $jsticket = $rurl[&#39;ticket&#39;];
      return $jsticket;
    }
}
ログイン後にコピー

次に、複数のパラメータを結合して暗号化することによって形成され、有効な署名を取得します。

// 获取 signature
private function getsignature(){
    $noncestr = &#39;&#39;;
    $jsapi_ticket = $this->getjsticket();
    $timestamp = time();
    $url = &#39;http://zhudianbao.diandodo.com/index.php?g=Opener&m=Merchant&a=open&#39;;
    $string1 = &#39;jsapi_ticket=&#39;.$jsapi_ticket.&#39;&noncestr=&#39;.$noncestr.&#39;&timestamp=&#39;.$timestamp.&#39;&url=&#39;.$url;
    $signature = sha1($string1);
    return $signature;
}
ログイン後にコピー

設定後、使用できるようになります。写真を選択する機能と写真をアップロードする機能の 2 つを使用しました。

function chooseImage(obj){
  // 选择张片
  wx.chooseImage({
    count: 1, // 默认9
    sizeType: [&#39;original&#39;, &#39;compressed&#39;], // 可以指定是原图还是压缩图,默认二者都有
    sourceType: [&#39;album&#39;, &#39;camera&#39;], // 可以指定来源是相册还是相机,默认二者都有
    success: function(res) {
      var localIds = res.localIds; // 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
      $(obj).attr(&#39;src&#39;, localIds);
      // 上传照片
      wx.uploadImage({
        localId: &#39;&#39; + localIds,
        isShowProgressTips: 1,
        success: function(res) {
          serverId = res.serverId;
          $(obj).next().val(serverId); // 把上传成功后获取的值附上
        }
      });
    }
  });
}
ログイン後にコピー

写真によって返された localID を選択するのは非常に興味深いものです。これはアップロードに使用でき、画像を表示するために img の src 属性に配置できます。

アップロードが成功したら、serverId を取得し、この ID を使用して、WeChat サーバーにアップロードされた画像ファイルをダウンロードし、自分のサーバーに保存できます。

// 获取图片地址
private function getmedia($access_token,$media_id,$foldername){
    $url = "http://file.api.weixin.qq.com/cgi-bin/media/get?access_token=".$access_token."&media_id=".$media_id;
    if (!file_exists("./Uploads/User_cert/".$foldername)) {
      mkdir("./Uploads/User_cert/".$foldername, 0777, true);
    }
    $targetName = &#39;./Uploads/User_cert/&#39;.$foldername.&#39;/&#39;.date(&#39;YmdHis&#39;).rand(1000,9999).&#39;.jpg&#39;;
    $ch = curl_init($url); // 初始化
    $fp = fopen($targetName, &#39;wb&#39;); // 打开写入
    curl_setopt($ch, CURLOPT_FILE, $fp); // 设置输出文件的位置,值是一个资源类型
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_exec($ch);
    curl_close($ch);
    fclose($fp);
    return $targetName;
}
ログイン後にコピー

複数の写真が同時にアップロードされる可能性があるため、写真に同じ名前が付けられないようにするには、rand 乱数を追加します。

$targetName = &#39;./Uploads/User_cert/&#39;.$foldername.&#39;/&#39;.date(&#39;YmdHis&#39;).rand(1000,9999).&#39;.jpg&#39;;
ログイン後にコピー

このserverIdはフォームの形式でサーバーに送信され、ファイルに書き込まれ、アドレスが取得され、アドレスがサーバーに保存されます。

WeChat の js と jquery は競合せず、一緒に使用できます。

素晴らしい JSSDK クラスを添付します

<?php
class JSSDK {
 private $appId;
 private $appSecret;
 public function __construct($appId, $appSecret) {
  $this->appId = $appId;
  $this->appSecret = $appSecret;
 }
 public function getSignPackage() {
  $jsapiTicket = $this->getJsApiTicket();
  // 注意 URL 一定要动态获取,不能 hardcode.
  $protocol = (!empty($_SERVER[&#39;HTTPS&#39;]) && $_SERVER[&#39;HTTPS&#39;] !== &#39;off&#39; || $_SERVER[&#39;SERVER_PORT&#39;] == 443) ? "https://" : "http://";
  $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
  $timestamp = time();
  $nonceStr = $this->createNonceStr();
  // 这里参数的顺序要按照 key 值 ASCII 码升序排序
  $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";
  $signature = sha1($string);
  $signPackage = array(
   "appId"   => $this->appId,
   "nonceStr" => $nonceStr,
   "timestamp" => $timestamp,
   "url"    => $url,
   "signature" => $signature,
   "rawString" => $string
  );
  return $signPackage; 
 }
 private function createNonceStr($length = 16) {
  $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
  $str = "";
  for ($i = 0; $i < $length; $i++) {
   $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
  }
  return $str;
 }
 private function getJsApiTicket() {
  // jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例
  $data = json_decode(file_get_contents("jsapi_ticket.json"));
  if ($data->expire_time < time()) {
   $accessToken = $this->getAccessToken();
   // 如果是企业号用以下 URL 获取 ticket
   // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";
   $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";
   $res = json_decode($this->httpGet($url));
   $ticket = $res->ticket;
   if ($ticket) {
    $data->expire_time = time() + 7000;
    $data->jsapi_ticket = $ticket;
    $fp = fopen("jsapi_ticket.json", "w");
    fwrite($fp, json_encode($data));
    fclose($fp);
   }
  } else {
   $ticket = $data->jsapi_ticket;
  }
  return $ticket;
 }
 private function getAccessToken() {
  // access_token 应该全局存储与更新,以下代码以写入到文件中做示例
  $data = json_decode(file_get_contents("access_token.json"));
  if ($data->expire_time < time()) {
   // 如果是企业号用以下URL获取access_token
   // $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";
   $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";
   $res = json_decode($this->httpGet($url));
   $access_token = $res->access_token;
   if ($access_token) {
    $data->expire_time = time() + 7000;
    $data->access_token = $access_token;
    $fp = fopen("access_token.json", "w");
    fwrite($fp, json_encode($data));
    fclose($fp);
   }
  } else {
   $access_token = $data->access_token;
  }
  return $access_token;
 }
 private function httpGet($url) {
  $curl = curl_init();
  curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
  curl_setopt($curl, CURLOPT_TIMEOUT, 500);
  // 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。
  // 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。
  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);
  curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);
  curl_setopt($curl, CURLOPT_URL, $url);
  $res = curl_exec($curl);
  curl_close($curl);
  return $res;
 }
}
ログイン後にコピー

以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。


関連する推奨事項:

PHP 電子メールの使用方法

PHP Cookieの理解と使用

PHP 関連する知識と

PHPを使用するキャッシュに関する関連知識を理解して適用するためのセッション

以上がPHP は、フォト アルバムを選択し、写真を撮ってアップロードする WeChat JS-SDK インターフェイス メソッドを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート