>  기사  >  백엔드 개발  >  PHP WeChat 고급 인터페이스 호출 방법(맞춤 메뉴 인터페이스, 고객 서비스 인터페이스, QR 코드)_php 예

PHP WeChat 고급 인터페이스 호출 방법(맞춤 메뉴 인터페이스, 고객 서비스 인터페이스, QR 코드)_php 예

WBOY
WBOY원래의
2016-12-05 13:28:291113검색

WeChat 고급 인터페이스 호출 방법

WeChat 고급 인터페이스와 WeChat 일반 인터페이스의 차이점

백그라운드 서버는 WeChat 사용자와 통신하기 위해 WeChat 인터페이스를 호출할 수 있습니다. 이러한 인터페이스는 결제나 신원 인증 없이 호출할 수 있습니다. 그러나 일부 고급 인터페이스가 있습니다. WeChat 공식 계정은 사용자 정의 메뉴 및 WeChat 결제와 같은 고급 기능을 호출하기 위해 WeChat 인증을 통과하는 등 특정 권한에 도달해야 합니다.
그러나 WeChat 공개 계정의 테스트 계정 시스템은 이러한 고급 인터페이스를 적용할 수 있습니다(WeChat 결제와 같은 거래와 관련된 인터페이스 제외).

WeChat 고급 인터페이스 호출

WeChat 고급 인터페이스를 호출하려면 먼저 token_access 인터페이스를 호출해야 합니다. 이 인터페이스를 먼저 호출해야만 다른 고급 인터페이스를 호출할 수 있습니다.
다음과 같습니다. 고급 인터페이스 연결 회로도


token_access를 호출하려면 appID와 appsecreset이 필요합니다(이 둘의 출처는 WeChat 공용 계정 플랫폼 개발(1)에서 설명됨)

호출 코드는 다음과 같습니다

<&#63;php
$appid = "wxbad0b4x543aa0b5e";
$appsecret = "ed222a84da15cd24c4bdfa5d9adbabf2";
$url = "https://api.weixin.qq.com/cgi-bin/token&#63;grant_type=client_credential&appid=$appid&secret=$appsecret";
//下面是一个cURL会话过程,通过这个会话可以返回一段字符串{"access_token":"NU7Kr6v9L9TQaqm5NE3OTPctTZx797Wxw4Snd2WL2HHBqLCiXlDVOw2l-Se0I-WmOLLniAYLAwzhbYhXNjb"}
这就是我们要获得的Access Token了。在调用高级功能接口的时候就靠它。这个过程用的时候直接引用就好,不需要深究,这个cURL系统相关函数有点多而且复杂。

$ch = curl_init();//初始化
curl_setopt($ch, CURLOPT_URL, $url);//与url建立对话
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); //进行配置
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); //进行配置
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//进行配置
$output = curl_exec($ch);//执行对话,获取接口数据Access Token
curl_close($ch);//关闭会话
$jsoninfo = json_decode($output, true);//解码接口数据,将json格式字符串转换成php变量或数组。默认是变量,加true后是数组。
$access_token = $jsoninfo["access_token"];

&#63;>

WeChat 고급 인터페이스에 전화

1) 맞춤 메뉴 기능 호출

 //创建一个自定义菜单的json字符串
 $jsonmenu = '{
  "button":[
  {
   "name":"关于我们",
   "sub_button":[
   {
    "type":"click",
    "name":"公司简介",
    "key":"公司简介"
   },
   {
    "type":"click",
    "name":"社会责任",
    "key":"社会责任"
   },
   {
    "type":"click",
    "name":"联系我们",
    "key":"联系我们"
   }]
  },
  {
   "name":"产品服务",
   "sub_button":[
   {
    "type":"click",
    "name":"微信平台",
    "key":"微信平台"
   },
   {
    "type":"click",
    "name":"微博应用",
    "key":"微博应用"
   },
   {
    "type":"click",
    "name":"手机网站",
    "key":"手机网站"
   }]
  },
  {
   "name":"技术支持",
   "sub_button":[
   {
    "type":"click",
    "name":"文档下载",
    "key":"文档下载"
   },
   {
    "type":"click",
    "name":"技术社区",
    "key":"技术社区"
   },
   {
    "type":"click",
    "name":"服务热线",
    "key":"服务热线"
   }]
  }]
 }';

 $url = "https://api.weixin.qq.com/cgi-bin/menu/create&#63;access_token=".$access_token;//接口地址
$result = https_request($url, $jsonmenu);//与接口建立会话
var_dump($result);

function https_request($url,$data = null){
 $curl = curl_init();
 curl_setopt($curl, CURLOPT_URL, $url);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
 if (!empty($data)){
  curl_setopt($curl, CURLOPT_POST, 1);
  curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
 }
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
 $output = curl_exec($curl);
 curl_close($curl);
 return $output;
}
//把这段代码加入到上面的调用Access Token接口的代码中就可以实现在微信公众号界面添加菜单的功能。

위챗 공식 계정에 메뉴를 추가할 때, 메뉴 클릭 시 해당 효과를 어떻게 설정하나요?
여기에는 또 다른 xml 유형의 데이터 전송이 포함됩니다.

<xml>
<ToUserName><![CDATA[gh_82479813ed64]]></ToUserName>
<FromUserName><![CDATA[ojpX_jig-gyi3_Q9fHXQ4rdHniQs]]></FromUserName>
<CreateTime>1392297442</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[CLICK]]></Event>
<EventKey><![CDATA[公司简介]]></EventKey>
</xml>
//上面是点击click菜单的数据传递类型,数据会发送给后台服务器,然后服务器做出响应。

메뉴 종류도 많고, xml 형식도 다릅니다. 자세한 내용은 위챗 공식 계정 플랫폼에서 해당 문서를 확인하실 수 있습니다.

*여기서 설명하고 싶은 것은 위챗 공식 계정의 appID와 appsecret만 있으면 어떤 서버 공간에서든 이 PHP 코드를 실행하면 위챗 서버에 들어갈 수 있다는 것입니다. 반드시 해당 함수를 호출할 필요는 없습니다. 토큰 검증을 통해 서버에서 실행되어야 합니다. 토큰 확인은 백엔드 서버가 데이터 소스가 WeChat 서버에서 온 것인지 여부를 확인하기 위한 것이며 WeChat 서버의 상위 수준 인터페이스를 호출하는 것과는 거의 관련이 없습니다.
php 파일이 서버에서 실행되어야 효과가 나타납니다.

다른 고급 인터페이스를 호출하는 것은 사용자 정의 메뉴를 호출하는 것과 같습니다.

2) 고객 서비스 인터페이스에 전화

WeChat 사용자가 WeChat 공개 계정에 메시지를 적극적으로 보낼 때(메시지 보내기, 사용자 정의 메뉴 클릭 이벤트, 구독 이벤트, QR 코드 스캔, 결제 성공 이벤트 포함) WeChat은 메시지 데이터를 개발자에게 푸시합니다. 개발자는 일정 시간 내에 고객 서비스 인터페이스 메시지를 호출하고 JSON 데이터 패킷을 게시하여 사용자에게 메시지를 보낼 수 있습니다.

코드 복사 코드는 다음과 같습니다.
$access_token = "nFX6GFsspSLBKJLgMQ3kj1YM8_FchRE7vE2ZOIlmfiCOQntZKnBwuOen2GCBpFHBYS4QLGX9 fGoVf A36tftME2sRiYsKPzgGQKU-ygU7x8cgy_1tlQ4n1mhSumwQEGy6PK6rdTdo8O8GROuGE3Hiag";
$openid = "o7Lp5t6n59DeX3U0C7Kric9qEx-Q";//WeChat 사용자는 모두 openID를 가지고 있습니다

아래 그림은 openID를 얻는 방법을 보여줍니다.

$data = '{
 "touser":"'.$openid.'",
 "msgtype":"text",
 "text":
 {
   "content":"Hello World"
 }
}';//通过基础消息接口发送的数据是XML格式的,但是调用客服接口发送的数据是json数据格式,更易传输。 
$url = "https://api.weixin.qq.com/cgi-bin/message/custom/send&#63;access_token=".$access_token;
$result = https_request($url,$data);
var_dump($result);

function https_request($url,$data)
{
 $curl = curl_init();
 curl_setopt($curl, CURLOPT_URL, $url); 
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
 curl_setopt($curl, CURLOPT_POST, 1);
 curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
 $result = curl_exec($curl);
 if (curl_errno($curl)) {
  return 'Errno'.curl_error($curl);
 }
 curl_close($curl);
 return $result;
}

고객 서비스 인터페이스는 특정 형식의 그래픽 메시지, 음악 메시지 및 비디오 메시지를 보냅니다. WeChat 공개 플랫폼의 개발 도움말 문서를 참조하세요.
고객 서비스 인터페이스는 메시지 인터페이스와 혼합될 수 있습니다.

수동 응답 메시지 인터페이스를 통해 XML 데이터를 사용자에게 직접 보낼 수 있는데 왜 그러한 고객 서비스 인터페이스가 필요한지 이해하지 못할 수도 있습니다. 수동 응답 메시지는 동일한 메시지에 대해 한 번만 응답하는 것으로 이해될 수 있습니다. 음원 플랫폼에 가수 이름을 입력하면 수동 응답을 통해 전송된 메시지는 항상 같은 노래로 답장해 줍니다. 그러나 고객 서비스 인터페이스를 통해 매번 다른 노래에 응답할 수 있으며, 이는 MySQL 데이터베이스와 관련됩니다.

좀 더 간단하게, 주소를 포함한 속달 배송을 확인할 수 있는 위챗 공개 플랫폼입니다. 동일한 주문 번호를 입력할 때마다 백그라운드에서 주문 위치를 수동으로 답변하는 것처럼 매번 답변할 수 있습니다(동일한 텍스트에 대해 다른 응답이 가능함). 이것이 바로 고객 서비스 인터페이스입니다.

3) QR 코드 인터페이스 생성

QR 코드에는 임시 QR 코드와 영구 QR 코드의 두 가지 유형이 있습니다. 전자는 최대 1800초의 만료 시간을 갖습니다.
QR 코드를 생성하려면 3개의 인터페이스를 호출해야 합니다.
첫 번째는 access_token입니다
두 번째는 티켓 인터페이스를 생성하는 것입니다
세 번째는 두 번째 인터페이스를 통해 생성된 티켓을 QR코드 이미지로 교환하는 것이다.

$access_token = " xDx0pD_ZvXkHM3oeu5oGjDt1_9HxlA-9g0vtR6MZ-v4r7MpvZYC4ee4OxN97Lr4irkPKE94tzBUhpZG_OvqAC3D3XaWJIGIn0eeIZnfaofO1C3LNzGphd_rEv3pIimsW9lO-4FOw6D44T3sNsQ5yXQ";//假定获取的ACCESS TOKEN为这段代码。

//临时二维码
$qrcode = '{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 10000}}}';
//永久二维码
$qrcode = '{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 1000}}}';

$url = "https://api.weixin.qq.com/cgi-bin/qrcode/create&#63;access_token=$access_token";//创建ticket接口
$result = https_request($url,$qrcode);
$jsoninfo = json_decode($result, true);
$ticket = $jsoninfo["ticket"];

function https_request($url, $data = null){
 $curl = curl_init();
 curl_setopt($curl, CURLOPT_URL, $url);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
 if (!empty($data)){
  curl_setopt($curl, CURLOPT_POST, 1);
  curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
 }
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
 $output = curl_exec($curl);
 curl_close($curl);
 return $output;
}


$ticket = "gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA==";//获取ticket的字符串

$url = "https://mp.weixin.qq.com/cgi-bin/showqrcode&#63;ticket=".urlencode($ticket);//ticket对面二维码图片代码。
$imageInfo = downloadWeixinFile($url);

$filename = "qrcode.jpg";
$local_file = fopen($filename, 'w');
if (false !== $local_file){
 if (false !== fwrite($local_file, $imageInfo["body"])) {
  fclose($local_file);
 }
}

function downloadWeixinFile($url)
{
 $ch = curl_init($url);
 curl_setopt($ch, CURLOPT_HEADER, 0); 
 curl_setopt($ch, CURLOPT_NOBODY, 0); //只取body头
 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
 $package = curl_exec($ch);
 $httpinfo = curl_getinfo($ch);
 curl_close($ch);
 return array_merge(array('body' => $package), array('header' => $httpinfo)); 
}

서버 공간에서 이 코드를 실행하면 브라우저에서 QR 코드 이미지가 생성됩니다.

교통 정보, 일기 예보 등 WeChat 이외의 기능 인터페이스를 얻습니다.

위 글의 내용은 모두의 공부에 도움이 되길 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.