Développement d'une plateforme publique PHP WeChat Partage d'exemples de messagerie de groupe WeChat

墨辰丷
Libérer: 2023-03-29 06:20:02
original
2762 Les gens l'ont consulté

Cet article présente principalement en détail la messagerie de groupe WeChat développée par la plateforme publique php WeChat. Elle a une certaine valeur de référence. Les amis intéressés peuvent s'y référer

Objectif

.

Fini l'envoi de messages de groupe sur le compte officiel WeChat. Ici, complétez simplement l’envoi de texte simple. Vous pouvez également envoyer des images vocales, etc., mais le format des données est différent. Il existe un lien ci-dessous pour interroger le format d'envoi des données du type de données.

2. Le processus d'envoi de messages texte de groupe

Obtenez un compte public de test (ceux qui ont un compte n'ont pas besoin d'un compte de test, mais les comptes formels en ont plus restrictions). Les utilisateurs suivent le compte public ci-dessus. Le compte obtient notre access_token via appid et appsecret et envoie des messages texte de groupe via access_token

3. Obtenez un compte public de test + suivez le compte public

1), obtenez un compte de test public

Accédez au lien ci-dessus et sélectionnez "Interface Test Number Application" pour l'ouvrir directementhttp://mp.weixin.qq.com/ debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/indexScannez le code QR pour vous connecter via le client WeChat.

Après vous être connecté, vous pouvez obtenir les informations d'un compte public de test. Il existe principalement deux paramètres, appId et appsecret, qui identifieront de manière unique un compte officiel, et ils doivent être utilisés comme paramètres pour obtenir les informations de l'utilisateur. ,

2) Configuration des informations de l'interface

Pour cette étape, vous pouvez vous référer aux instructions d'accès à WeChat. Cette page fournit un exemple de téléchargement php, qui est. très simple et fondamentalement, modifiez simplement le TOKEN personnalisé, puis placez la page de vérification sur votre propre serveur.

Ici, je donne un exemple de ce que j'ai fait :

Préparer les ressources :

Nom de domaine + espace (le mien est un espace sae + nom de domaine Wanwang), php pour vérification uniquement J'ai créé un wx_sample.php

wx_sample.php

dans le répertoire racine de l'espace pointé par le fichier
<?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;
}

}
}

?>
Copier après la connexion

puis j'ai renseigné les informations de configuration Token (doit correspond au wx_sample ci-dessus .php), URL (l'adresse de wx_sample.php)

Ensuite, soumettez-le

Si l'invite échoue, veuillez vérifier le jeton et URL [S'il s'agit de votre propre nom de domaine et de votre propre espace, veuillez l'enregistrer ; pour Baidu sae et Sina sae, vous devez en faire la demande vous-même et obtenir la certification (prenez simplement une photo de vous tenant la pièce d'identité et téléchargez-la, c'est très simple, cela ne prendra que 2 jours), cette étape est obligatoire 】

3) Configurer le nom de domaine de sécurité de l'interface JS

Assurez-vous de ne pas inclure de protocole lorsque vous remplissez ce champ nom de domaine, par exemple http://www.sagosoft.com/ C'est faux, c'est l'URL Ce n'est pas un nom de domaine

Le nom de domaine devrait être quelque chose comme www.sagosoft.com [Sinon, un domaine URL invalide sera demandé lors de l'accès à WeChat js-sdk]

4) Suivre le compte public

Ce n'est qu'en suivant le compte public que l'utilisateur peut autoriser Connectez-vous à un tiers et obtenez des informations sur l'utilisateur en ouvrant le lien avec les informations du compte public. Par conséquent, nous devons également utiliser notre WeChat pour suivre l'identifiant WeChat. Le fonctionnement est le suivant :

C'est toujours la page qui a sauté après une connexion réussie. Nous pouvons voir que la page a un code QR. Vous pouvez scanner le code QR. Suivez le code QR. Si vous suivez avec succès, il y aura des informations supplémentaires sur l'utilisateur dans la « Liste des utilisateurs » à droite. Comme le montre la figure ci-dessous :

5) Configurez la fonction de rappel

Lorsque nous accédons à une page Web tierce (c'est-à-dire notre propre page Web) sur le client WeChat, nous pouvons utiliser le mécanisme d'autorisation de la page Web WeChat. Nous avons non seulement besoin de l'appid et du appsecret obtenus précédemment, mais également des paramètres de nom de domaine pour le rappel après l'autorisation de l'utilisateur, c'est-à-dire l'endroit où la page accédera. après autorisation de l'utilisateur. La configuration spécifique est la suivante :

Sur la page à l'instant, il y a une "Autorisation de page Web pour obtenir les informations de base de l'utilisateur", cliquez sur la modification suivante

pour renseigner le nom de domaine de rappel :

Le nom de domaine est le nom de domaine racine configuré ci-dessus si l'URL que vous avez renseignée dans les "Informations de configuration de l'interface" ci-dessus est zcr.sinaaappc.com/wx_sample. php, remplissez simplement zcr.sinaaappc.com ici.

Si votre URL n'a pas été mise sur liste noire, elle apparaîtra en haut

Remarque :

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
}
Copier après la connexion

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格式数据发送)——发送其他格式数据,只需要改里面参数信息即可,具体可查看微信官方文档:


参数说明:

例子:发送给所有人

url:

复制代码 代码如下:

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

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


返回数据:

参数意义:

错误码及其以及查询:

全局错误码解析

使用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>"}
}
Copier après la connexion


返回数据:


{
"errcode": 0,
"errmsg": "send job submission success",
"msg_id": 3147483654
}
Copier après la connexion


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

微信号接收到的内容:

Développement dune plateforme publique PHP WeChat Partage dexemples de messagerie de groupe WeChat

致谢:感谢您的阅读!

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

相关推荐:

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

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!