ホームページ  >  記事  >  バックエンド開発  >  PHP WeChat パブリック プラットフォームの開発 WeChat グループ メッセージングのサンプル共有

PHP WeChat パブリック プラットフォームの開発 WeChat グループ メッセージングのサンプル共有

墨辰丷
墨辰丷オリジナル
2018-06-01 11:33:142809ブラウズ

この記事は主にphp WeChatパブリックプラットフォームによって開発されたWeChatグループメッセージングを詳しく紹介します。興味のある友人はそれを参照してください

1.WeChatパブリックアカウントで完了します。ここで簡単なテキスト送信を完了するだけです。音声画像なども送信できますが、データ形式が異なります。データタイプのデータ送信形式を問い合わせるには、以下のリンクがあります。

2. 大量のテキストメッセージを送信するプロセス

テスト公開アカウントを取得します(アカウントをお持ちの方はテストアカウントは必要ありませんが、公式アカウントを取得するには、上記の公開アカウントをフォローする必要があります)。 appid と appsecret を通じて access_token を送信し、access_token SMS を通じて大量に送信します

3. テスト用パブリック アカウントを取得し、パブリック アカウントをフォローします

1)、パブリック テスト アカウントを取得します

上記のリンクにアクセスして、[Interface Test Account] を選択します「アプリケーション」をクリックして直接開きます

http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index

QR コードをスキャンして、WeChat クライアント経由でログインします。

ログイン後、テスト公開アカウントの情報を取得できます。公式アカウントを一意に識別するパラメータは主にappIdとappsecretの2つで、ユーザーの情報を取得するためのパラメータとして使用する必要があります。 ,

2) インターフェース情報の設定

このステップについては、WeChat のアクセス手順を参照してください。基本的には、カスタマイズした TOKEN を変更するだけです。検証ページ 自分のサーバーに置きます。

ここで私がやったことの例を示します:

リソースを準備します:

ドメイン名 + スペース (私のものは sae スペース + 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) 公開アカウントをフォローする

ユーザーはこれのみをフォローできます公開アカウントをお持ちの場合にのみ、公開アカウントとのリンクを開くことができます第三者がログインしてユーザー情報を取得することを許可するための情報。したがって、WeChat ID をフォローするためにも WeChat を使用する必要があります。 操作は次のとおりです。

ログインに成功した後、ページに QR コードがあることがわかります。フォローに成功すると、右側の「ユーザーリスト」にもう1人のユーザーの情報が表示されます。以下の図に示すように:

5) コールバック関数を構成します

WeChat クライアントでサードパーティの Web ページ (つまり、独自の Web ページ) にアクセスするときは、WeChat Web ページの承認メカニズムを使用できます。取得する appid と appsecret は、事前に取得するだけでなく、ユーザーが承認した後のコールバック、つまりユーザーが承認した後にページがジャンプする場所のドメイン名設定も必要です。具体的な設定は次のとおりです:

今のページにはまだ「ユーザーの基本情報を取得するための Web ページの承認」があります。

の後ろにある変更をクリックします。コールバック ドメイン名を入力します:

ドメイン名上記の「インターフェース構成情報」に入力された 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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。