>  기사  >  백엔드 개발  >  PHP WeChat 공개 플랫폼 개발 WeChat 그룹 메시징 예제 공유

PHP WeChat 공개 플랫폼 개발 WeChat 그룹 메시징 예제 공유

墨辰丷
墨辰丷원래의
2018-06-01 11:33:142746검색

이 글은 주로 php WeChat 공개 플랫폼에서 개발한 WeChat 그룹 메시징을 자세히 소개합니다. 관심 있는 친구들이 참고할 수 있습니다.

1. 목적

WeChat 공개 계정에서 작성됩니다. 여기까지만 하면 간단한 문자 전송이 완료됩니다. 음성 사진 등을 보낼 수도 있지만 데이터 형식이 다릅니다. 데이터 형식의 데이터 전송 형식을 쿼리하려면 아래 링크가 있습니다.

2. 대량 문자 메시지 전송 과정

테스트 공개 계정을 얻습니다(계정이 있는 경우 테스트 계정이 필요하지 않지만 공식 계정은 더 많은 제한이 있음). appid 및 appsecret을 통해 access_token을 보내고 access_token SMS를 통해 대량으로 전송하세요

3. 테스트 공개 계정을 만들고

1) 공개 테스트 계정을 만들고

위의 링크를 방문하여 "인터페이스 테스트 계정"을 선택하세요. 애플리케이션"을 직접 열려면 http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/indexQR 코드를 스캔하여 WeChat 클라이언트를 통해 로그인하세요.

 로그인 후 테스트 공개 계정의 정보를 얻을 수 있습니다. 공식 계정을 고유하게 식별하는 매개변수는 주로 appId와 appsecret 두 가지가 있으며, 이를 사용자 정보를 얻기 위한 매개변수로 사용해야 합니다. ,

2) 인터페이스 정보 구성

이 단계는 WeChat 액세스 지침을 참조할 수 있습니다. 이 페이지는 기본적으로 사용자 정의 TOKEN을 수정한 후 확인만 하면 됩니다. 페이지 자신의 서버에 올려보세요.

여기에 내가 한 일의 예가 나와 있습니다.

리소스 준비:

도메인 이름 + 공백(내 것은 sae space + Wanwang 도메인 이름), 확인용으로만 PHP 파일

다음이 가리키는 공간 루트 디렉터리를 만들었습니다. 도메인 이름 A wx_sample.php

wx_sample.php

<?php
/**
* wechat php test
*/

//define your token
define("TOKEN", "weixin");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid();

class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET["echostr"];

//valid signature , option
if($this->checkSignature()){
echo $echoStr;
exit;
}
}

public function responseMsg()
{
//get post data, May be due to the different environments
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

//extract post data
if (!empty($postStr)){
/* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection,
the best way is to check the validity of xml by yourself */
libxml_disable_entity_loader(true);
$postObj = simplexml_load_string($postStr, &#39;SimpleXMLElement&#39;, LIBXML_NOCDATA);
$fromUsername = $postObj->FromUserName;
$toUsername = $postObj->ToUserName;
$keyword = trim($postObj->Content);
$time = time();
$textTpl = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>0</FuncFlag>
</xml>"; 
if(!empty( $keyword ))
{
$msgType = "text";
$contentStr = "Welcome to wechat world!";
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
echo $resultStr;
}else{
echo "Input something...";
}

}else {
echo "";
exit;
}
}

private function checkSignature()
{
// you must define TOKEN by yourself
if (!defined("TOKEN")) {
throw new Exception(&#39;TOKEN is not defined!&#39;);
}

$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];

$token = TOKEN;
$tmpArr = array($token, $timestamp, $nonce);
// use SORT_STRING rule
sort($tmpArr, SORT_STRING);
$tmpStr = implode( $tmpArr );
$tmpStr = sha1( $tmpStr );

if( $tmpStr == $signature ){
return true;
}else{
return false;
}

}
}

?>

를 입력한 다음 구성 정보 토큰(위 wx_sample.php의 토큰과 일치해야 함), URL(wx_sample.php 주소)

을 입력합니다.

그런 다음 제출하세요.

프롬프트가 실패하면 토큰과 URL을 확인하세요. [자신의 도메인 이름과 공간인 경우 Baidu sae와 Sina sae가 직접 신청하고 인증을 받아야 합니다. (ID를 들고 있는 손의 사진을 찍어 업로드하면 됩니다. 매우 간단하고 최단 2일이 소요됩니다.) 이 단계가 필요합니다.】

3) JS 인터페이스 보안 도메인 이름을 구성합니다

도메인 이름을 입력할 때 프로토콜을 포함하려면(예: http://www.sagosoft.com/) 틀렸습니다. 도메인 이름이 아닌 URL입니다

 도메인 이름은 www.sagosoft와 유사해야 합니다. com [그렇지 않으면 WeChat js-sdk에 액세스할 때 잘못된 URL 도메인이 표시됩니다.]

4) 공개 계정 팔로우

사용자는 이 페이지만 팔로우할 수 있습니다. 공개 계정이 있는 경우에만 공개 계정으로 링크를 열 수 있습니다. 제3자에게 로그인 권한을 부여하고 사용자 정보를 획득하기 위한 정보입니다. 따라서 WeChat ID를 따라가려면 WeChat을 사용해야 합니다. 작업은 다음과 같습니다.

로그인에 성공한 후에도 여전히 페이지에 QR 코드가 있는 것을 볼 수 있습니다. 성공적으로 팔로우했다면 오른쪽의 "사용자 목록"에 사용자 정보가 한 명 더 표시됩니다. 아래 그림과 같이

5) 콜백 기능 구성

WeChat 클라이언트에서 타사 웹페이지(즉, 자체 웹페이지)에 액세스할 때 WeChat 웹페이지 인증 메커니즘을 사용할 수 있습니다. 이전에 이를 얻어야 할 뿐만 아니라, 얻은 appid 및 appsecret에는 사용자가 승인한 후 콜백에 대한 도메인 이름 설정, 즉 사용자가 승인한 후 페이지가 이동할 위치도 있어야 합니다. 구체적인 구성은 다음과 같습니다.

아직 페이지에 "사용자 기본 정보를 얻기 위한 웹페이지 인증"이 있습니다. 뒤에 있는 수정 사항을 클릭하세요.

콜백 도메인 이름 입력:

도메인 이름 위에서 구성한 루트 도메인 이름입니다. 위의 "인터페이스 구성 정보"에 입력한 URL은 zcr.sinaaappc.com/wx_sample.php입니다. 여기에 zcr.sinaaappc.com을 입력하면 됩니다.

귀하의 URL이 블랙리스트에 등록되지 않은 경우 상단에 표시됩니다.

참고:

1、这里填写的是域名(是一个字符串),而不是URL,因此请勿加http://等协议头;
2、授权回调域名配置规范为全域名,比如需要网页授权的域名为:www.qq.com,配置以后此域名下面的页面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以进行OAuth2.0鉴权。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com无法进行OAuth2.0鉴权

到这里,我们就完成了公众号测试账号的获取和配置,已经用户关注微信公众号。

4、通过appid和appsecret获取我们的access_token

  access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。

获取方法:

http请求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

参数说明:


返回说明

正常情况下,微信会返回下述JSON数据包给公众号:

复制代码 代码如下:

{"access_token":"ACCESS_TOKEN","expires_in":7200}

错误时微信会返回错误码等信息,JSON数据包示例如下(该示例为AppID无效错误):


复制代码 代码如下:

{"errcode":40013,"errmsg":"invalid appid"}

例子:

获取access_token:

复制代码 代码如下:

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx4d1cb8dbd827a16e9&secret=d462d4c36b116795d1d99dcf0547af5443d

返回数据:


{
"access_token": "qR5UK2vMf5aTHV8e-uB10FZW0caTZm_1kbkUe4OPK2ILVvNaoa7pLzYWqLUAmx6Sjq1E7pKHrVAtuG0_1MPkqmDfOkm2750kaLWNk59DS-iDOpjjxompJtXa3WhbN5FKRWNhADAVAR",
"expires_in": 7200
}

5、通过access_token群发短信

  在公众平台网站上,为订阅号提供了每天一条的群发权限,为服务号提供每月(自然月)4条的群发权限。而对于某些具备开发能力的公众号运营者,可以通过高级群发接口,实现更灵活的群发能力。

请注意:

1、对于认证订阅号,群发接口每天可成功调用1次,此次群发可选择发送给全部用户或某个分组;
2、对于认证服务号虽然开发者使用高级群发接口的每日调用限制为100次,但是用户每月只能接收4条,无论在公众平台网站上,还是使用接口群发,用户每月只能接收4条群发消息,多于4条的群发将对该用户发送失败;
3、具备微信支付权限的公众号,在使用群发接口上传、群发图文消息类型时,可使用标签加入外链;
4、开发者可以使用预览接口校对消息样式和排版,通过预览接口可发送编辑好的消息给指定用户校验效果。

1)根据分组进行群发【订阅号与服务号认证后均可用】

调用接口:

复制代码 代码如下:

http请求方式: POSThttps://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=ACCESS_TOKEN

在body添加如下数据(以JSON格式数据发送)——发送其他格式数据,只需要改里面参数信息即可,具体可查看微信官方文档:


{
"filter":{
"is_to_all":false,
"group_id":2
},
"text":{
"content":"CONTENT"
},
"msgtype":"text"
}

参数说明:

例子:发送给所有人

url:

复制代码 代码如下:

https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=KBoNONaJZ4-KhafQVJoQ6VBX0F-bls7nAsJBn8Fy7GLwav4Be1lRJcob1RHH6wW35IxxFwkJnZfnc-On9EQITg3oxEWUw7O2YyVW9naDknu6PQX9fnSmQcr8ojTK8Ug-HDTcAAABXN

发送的json数据:发送给所有人


{
"filter":{
"is_to_all":true
},
"text":{
"content":"CONTENT"
},
"msgtype":"text"
}

返回数据:

{
"errcode": 0,
"errmsg": "send job submission success",
"msg_id": 1000000003
}

参数意义:

错误码及其以及查询:

全局错误码解析

使用postman模拟https请求发送如下图所示:

2)根据OpenID列表群发【订阅号不可用,服务号认证后可用】

发送的http请求url:(注意:和上面的不同)


复制代码 代码如下:

http请求方式: POSThttps://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=ACCESS_TOKEN

数据格式:


复制代码 代码如下:

{"touser":["OPENID1","OPENID2"],"msgtype": "text","text": { "content": "hello from boxer."}}

其中OPENID1和OPENID2是我们要发送的微信用户openId(用户的唯一标示)。

例子:

发送"oF3PcsnsrMiJzEwalZZbAfWQpxCI","oF3PcshH1CUIhR_WYau6swUiPzlw" 两个用户。

内容为:hello from boxer.欢迎来到百度

url:


复制代码 代码如下:

https://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=wRyTbnsiu18ssEhMPLf4bDfeT-Bt6e6tgR4CQGVLBipRcyJPkdAKPYfM6-qkKuHUN8uRKJh6Xvm0OuAdFgqOo8Ru8hoDxl-cGc9bh-ezJb2ZUcJSnQk2s416zI8kbEOfOGYdAFARJB

json数据:


{
"touser":[
"oF3PcsnsrMiJzEwalZZbAfWQpxCI",
"oF3PcshH1CUIhR_WYau6swUiPzlw"
],
"msgtype": "text",
"text": { "content": "hello from boxer.<a href=&#39;http://www.seewoedu.com/&#39;>欢迎希沃学院</a>"}
}


返回数据:


{
"errcode": 0,
"errmsg": "send job submission success",
"msg_id": 3147483654
}


使用postman模拟发送请求如下:

微信号接收到的内容:

PHP WeChat 공개 플랫폼 개발 WeChat 그룹 메시징 예제 공유

致谢:感谢您的阅读!

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

PHP实现屏蔽关键字的方法
PHP实现的自定义数组排序函数与排序类的方法
PHP实现的自定义数组排序函数与排序类

위 내용은 PHP WeChat 공개 플랫폼 개발 WeChat 그룹 메시징 예제 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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