微信公众平台自定义菜单及高级接口PHP SDK
本文介绍介绍微信公众平台自定义菜单及高级接口的PHP SDK及使用方法。
作者
方倍工作室
修正记录:
2014.05.03 v1.0
SDK 源码:
<span 1</span> <span /*</span> <span 2</span> <span 方倍工作室 http://www.cnblogs.com/txw1958/ </span><span 3</span> <span CopyRight 2014 www.doucube.com All Rights Reserved </span><span 4</span> <span */</span> <span 5</span> <span 6</span> <span class</span><span class_weixin_adv </span><span 7</span> <span { </span><span 8</span> <span var</span> <span $appid</span> = ""<span ; </span><span 9</span> <span var</span> <span $appsecret</span> = ""<span ; </span><span 10</span> <span 11</span> <span //</span><span 构造函数,获取Access Token</span> <span 12</span> <span public</span> <span function</span> __construct(<span $appid</span> = <span NULL</span>, <span $appsecret</span> = <span NULL</span><span ) </span><span 13</span> <span { </span><span 14</span> <span if</span>(<span $appid</span><span ){ </span><span 15</span> <span $this</span>->appid = <span $appid</span><span ; </span><span 16</span> <span } </span><span 17</span> <span if</span>(<span $appsecret</span><span ){ </span><span 18</span> <span $this</span>->appsecret = <span $appsecret</span><span ; </span><span 19</span> <span } </span><span 20</span> <span 21</span> <span //</span><span hardcode</span> <span 22</span> <span $this</span>->lasttime = 1395049256<span ; </span><span 23</span> <span $this</span>->access_token = "nRZvVpDU7LxcSi7GnG2LrUcmKbAECzRf0NyDBwKlng4nMPf88d34pkzdNcvhqm4clidLGAS18cN1RTSK60p49zIZY4aO13sF-eqsCs0xjlbad-lKVskk8T7gALQ5dIrgXbQQ_TAesSasjJ210vIqTQ"<span ; </span><span 24</span> <span 25</span> <span if</span> (<span time</span>() > (<span $this</span>->lasttime + 7200<span )){ </span><span 26</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".<span $this</span>->appid."&secret=".<span $this</span>-><span appsecret; </span><span 27</span> <span $res</span> = <span $this</span>->https_request(<span $url</span><span ); </span><span 28</span> <span $result</span> = json_decode(<span $res</span>, <span true</span><span ); </span><span 29</span> <span //</span><span save to Database or Memcache</span> <span 30</span> <span $this</span>->access_token = <span $result</span>["access_token"<span ]; </span><span 31</span> <span $this</span>->lasttime = <span time</span><span (); </span><span 32</span> <span } </span><span 33</span> <span } </span><span 34</span> <span 35</span> <span //</span><span 获取关注者列表</span> <span 36</span> <span public</span> <span function</span> get_user_list(<span $next_openid</span> = <span NULL</span><span ) </span><span 37</span> <span { </span><span 38</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/user/get?access_token=".<span $this</span>->access_token."&next_openid=".<span $next_openid</span><span ; </span><span 39</span> <span $res</span> = <span $this</span>->https_request(<span $url</span><span ); </span><span 40</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 41</span> <span } </span><span 42</span> <span 43</span> <span //</span><span 获取用户基本信息</span> <span 44</span> <span public</span> <span function</span> get_user_info(<span $openid</span><span ) </span><span 45</span> <span { </span><span 46</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=".<span $this</span>->access_token."&openid=".<span $openid</span>."&lang=zh_CN"<span ; </span><span 47</span> <span $res</span> = <span $this</span>->https_request(<span $url</span><span ); </span><span 48</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 49</span> <span } </span><span 50</span> <span 51</span> <span //</span><span 创建菜单</span> <span 52</span> <span public</span> <span function</span> create_menu(<span $data</span><span ) </span><span 53</span> <span { </span><span 54</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".<span $this</span>-><span access_token; </span><span 55</span> <span $res</span> = <span $this</span>->https_request(<span $url</span>, <span $data</span><span ); </span><span 56</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 57</span> <span } </span><span 58</span> <span 59</span> <span //</span><span 发送客服消息,已实现发送文本,其他类型可扩展</span> <span 60</span> <span public</span> <span function</span> send_custom_message(<span $touser</span>, <span $type</span>, <span $data</span><span ) </span><span 61</span> <span { </span><span 62</span> <span $msg</span> = <span array</span>('touser' =><span $touser</span><span ); </span><span 63</span> <span switch</span>(<span $type</span><span ) </span><span 64</span> <span { </span><span 65</span> <span case</span> 'text': <span 66</span> <span $msg</span>['msgtype'] = 'text'<span ; </span><span 67</span> <span $msg</span>['text'] = <span array</span>('content'=> <span urlencode</span>(<span $data</span><span )); </span><span 68</span> <span break</span><span ; </span><span 69</span> <span } </span><span 70</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=".<span $this</span>-><span access_token; </span><span 71</span> <span return</span> <span $this</span>->https_request(<span $url</span>, <span urldecode</span>(json_encode(<span $msg</span><span ))); </span><span 72</span> <span } </span><span 73</span> <span 74</span> <span //</span><span 生成参数二维码</span> <span 75</span> <span public</span> <span function</span> create_qrcode(<span $scene_type</span>, <span $scene_id</span><span ) </span><span 76</span> <span { </span><span 77</span> <span switch</span>(<span $scene_type</span><span ) </span><span 78</span> <span { </span><span 79</span> <span case</span> 'QR_LIMIT_SCENE': <span //</span><span 永久</span> <span 80</span> <span $data</span> = '{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": '.<span $scene_id</span>.'}}}'<span ; </span><span 81</span> <span break</span><span ; </span><span 82</span> <span case</span> 'QR_SCENE': <span //</span><span 临时</span> <span 83</span> <span $data</span> = '{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": '.<span $scene_id</span>.'}}}'<span ; </span><span 84</span> <span break</span><span ; </span><span 85</span> <span } </span><span 86</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=".<span $this</span>-><span access_token; </span><span 87</span> <span $res</span> = <span $this</span>->https_request(<span $url</span>, <span $data</span><span ); </span><span 88</span> <span $result</span> = json_decode(<span $res</span>, <span true</span><span ); </span><span 89</span> <span return</span> "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".<span urlencode</span>(<span $result</span>["ticket"<span ]); </span><span 90</span> <span } </span><span 91</span> <span 92</span> <span //</span><span 创建分组</span> <span 93</span> <span public</span> <span function</span> create_group(<span $name</span><span ) </span><span 94</span> <span { </span><span 95</span> <span $data</span> = '{"group": {"name": "'.<span $name</span>.'"}}'<span ; </span><span 96</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/groups/create?access_token=".<span $this</span>-><span access_token; </span><span 97</span> <span $res</span> = <span $this</span>->https_request(<span $url</span>, <span $data</span><span ); </span><span 98</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 99</span> <span } </span><span 100</span> <span 101</span> <span //</span><span 移动用户分组</span> <span 102</span> <span public</span> <span function</span> update_group(<span $openid</span>, <span $to_groupid</span><span ) </span><span 103</span> <span { </span><span 104</span> <span $data</span> = '{"openid":"'.<span $openid</span>.'","to_groupid":'.<span $to_groupid</span>.'}'<span ; </span><span 105</span> <span $url</span> = "https://api.weixin.qq.com/cgi-bin/groups/members/update?access_token=".<span $this</span>-><span access_token; </span><span 106</span> <span $res</span> = <span $this</span>->https_request(<span $url</span>, <span $data</span><span ); </span><span 107</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 108</span> <span } </span><span 109</span> <span 110</span> <span //</span><span 上传多媒体文件</span> <span 111</span> <span public</span> <span function</span> upload_media(<span $type</span>, <span $file</span><span ) </span><span 112</span> <span { </span><span 113</span> <span $data</span> = <span array</span>("media" => "@".<span dirname</span>(<span __FILE__</span>).'\\'.<span $file</span><span ); </span><span 114</span> <span $url</span> = "http://file.api.weixin.qq.com/cgi-bin/media/upload?access_token=".<span $this</span>->access_token."&type=".<span $type</span><span ; </span><span 115</span> <span $res</span> = <span $this</span>->https_request(<span $url</span>, <span $data</span><span ); </span><span 116</span> <span return</span> json_decode(<span $res</span>, <span true</span><span ); </span><span 117</span> <span } </span><span 118</span> <span 119</span> <span //</span><span https请求(支持GET和POST)</span> <span 120</span> <span protected</span> <span function</span> https_request(<span $url</span>, <span $data</span> = <span null</span><span ) </span><span 121</span> <span { </span><span 122</span> <span $curl</span> =<span curl_init(); </span><span 123</span> curl_setopt(<span $curl</span>, CURLOPT_URL, <span $url</span><span ); </span><span 124</span> curl_setopt(<span $curl</span>, CURLOPT_SSL_VERIFYPEER, <span FALSE</span><span ); </span><span 125</span> curl_setopt(<span $curl</span>, CURLOPT_SSL_VERIFYHOST, <span FALSE</span><span ); </span><span 126</span> <span if</span> (!<span empty</span>(<span $data</span><span )){ </span><span 127</span> curl_setopt(<span $curl</span>, CURLOPT_POST, 1<span ); </span><span 128</span> curl_setopt(<span $curl</span>, CURLOPT_POSTFIELDS, <span $data</span><span ); </span><span 129</span> <span } </span><span 130</span> curl_setopt(<span $curl</span>, CURLOPT_RETURNTRANSFER, 1<span ); </span><span 131</span> <span $output</span> = curl_exec(<span $curl</span><span ); </span><span 132</span> curl_close(<span $curl</span><span ); </span><span 133</span> <span return</span> <span $output</span><span ; </span><span 134</span> <span } </span><span 135</span> }
调用方法:
初始化对象
<span $weixin</span> = <span new</span> class_weixin_adv("wx6222221b11111111", "3079cb22ad383ae7371d12aed1b2d0cc");
查看Access Token
<span var_dump</span>(<span $weixin</span>->access_token);
创建二维码
<span var_dump</span>(<span $weixin</span>->create_qrcode("QR_SCENE", "134324234"));
获取关注者列表
<span var_dump</span>(<span $weixin</span>->get_user_list());
获取用户信息
<span $openid</span> = "oLVPpjkttuZTbwDwN7vjHNlqsmPs"<span ; </span><span var_dump</span>(<span $weixin</span>->get_user_info(<span $openid</span>));
创建菜单
<span $data</span> ='{"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":"服务热线"}]}]}'<span ; </span><span var_dump</span>(<span $weixin</span>->create_menu(<span $data</span>));
用户分组
<span var_dump</span>(<span $weixin</span>->create_group("老师"<span )); </span><span var_dump</span>(<span $weixin</span>->update_group(<span $openid</span>, "100"));
上传下载多媒体
<span var_dump</span>(<span $weixin</span>->upload_media("image","pondbay.jpg"));
发送客服消息
<span var_dump</span>(<span $weixin</span>->send_custom_message(<span $openid</span>, "text", "asdf"));
=========================================================
方倍工作室微信公众平台账号关注方法:
1. 微信通讯录-添加朋友-查找公众号-搜索“方倍工作室”
2. 微信通讯录-添加朋友-搜号码-输入“pondbaystudio”
3. 使用微信扫描下面的二维码

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La combinaison de Vue.js et ASP.NET fournit des conseils et des suggestions pour l'optimisation des performances et l'expansion des applications Web. Avec le développement rapide des applications Web, l'optimisation des performances est devenue une tâche indispensable et importante pour les développeurs. En tant que framework frontal populaire, Vue.js combiné à ASP.NET peut nous aider à obtenir une meilleure optimisation et expansion des performances. Cet article présentera quelques conseils et suggestions, et fournira quelques exemples de code. 1. Réduire les requêtes HTTP Le nombre de requêtes HTTP affecte directement la vitesse de chargement des applications Web. passer

Traducteur | Révisé par Chen Jun | Chonglou Dans les années 1990, lorsque les gens parlaient de programmation logicielle, cela signifiait généralement choisir un éditeur, vérifier le code dans la base de code CVS ou SVN, puis compiler le code dans un fichier exécutable. Les environnements de développement intégrés (IDE) correspondants tels qu'Eclipse et Visual Studio peuvent intégrer la programmation, le développement, la documentation, la construction, les tests, le déploiement et d'autres étapes dans un cycle de vie complet de développement logiciel (SDLC), améliorant ainsi l'efficacité du travail des développeurs. Ces dernières années, les outils populaires de cloud computing et d'automatisation DevSecOps ont amélioré les capacités complètes des développeurs, permettant ainsi à un plus grand nombre d'entreprises de développer, de déployer et de maintenir plus facilement des applications logicielles. Aujourd’hui, l’IA générative est le développement de la prochaine génération

Comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET ? Introduction : MySQL est un système de gestion de bases de données largement utilisé qui offre des performances élevées, une fiabilité et une facilité d'utilisation. Dans le développement ASP.NET, l'utilisation d'une base de données MySQL pour le stockage des données est une exigence courante. Afin d'améliorer l'efficacité et les performances des connexions aux bases de données, nous devons utiliser et optimiser correctement le pool de connexions MySQL. Cet article explique comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET.

Comment se reconnecter à MySQL dans le programme ASP.NET ? Dans le développement ASP.NET, il est très courant d'utiliser la base de données MySQL. Cependant, pour des raisons de réseau ou de serveur de base de données, la connexion à la base de données peut parfois être interrompue ou expirer. Dans ce cas, afin de garantir la stabilité et la fiabilité du programme, nous devons rétablir la connexion après la déconnexion de la connexion. Cet article explique comment reconnecter les connexions MySQL dans les programmes ASP.NET. Pour référencer d'abord les espaces de noms nécessaires, référencez-les en tête du fichier de code

La combinaison de Vue.js et d'ASP.NET permet le développement et le déploiement d'applications au niveau de l'entreprise Dans le domaine technologique Internet en développement rapide actuel, le développement et le déploiement d'applications au niveau de l'entreprise sont devenus de plus en plus importants. Vue.js et ASP.NET sont deux technologies largement utilisées dans le développement front-end et back-end. Leur combinaison peut apporter de nombreux avantages au développement et au déploiement d'applications au niveau de l'entreprise. Cet article expliquera comment utiliser Vue.js et ASP.NET pour développer et déployer des applications au niveau de l'entreprise à travers des exemples de code. Tout d'abord, nous devons installer

Comment configurer et utiliser correctement le pool de connexions MySQL dans le programme ASP.NET ? Avec le développement d’Internet et l’augmentation du volume de données, la demande d’accès et de connexions aux bases de données augmente également. Afin d’améliorer les performances et la stabilité de la base de données, le pooling de connexions est devenu une technologie incontournable. Cet article explique principalement comment configurer et utiliser correctement le pool de connexions MySQL dans les programmes ASP.NET pour améliorer l'efficacité et la vitesse de réponse de la base de données. 1. Le concept et la fonction du pooling de connexions Le pooling de connexions est une technologie qui réutilise les connexions de bases de données. Elle est utilisée au début du programme.

Comment utiliser correctement et optimiser les performances des transactions du pool de connexions MySQL dans les programmes ASP.NET ? Dans les programmes ASP.NET, les transactions de base de données constituent une partie très importante. Les transactions garantissent la cohérence et l'intégrité de la base de données tout en offrant de meilleures performances. Lors de l'utilisation d'une base de données MySQL, il est essentiel d'utiliser un pool de connexions pour gérer les ressources de connexion et optimiser les performances. Tout d’abord, comprenons brièvement le concept de pool de connexions MySQL. Le pool de connexions est un pool tampon d'un groupe de connexions en pré-initialisant un certain nombre de connexions.

Les objets intégrés dans ASP.NET incluent "Request", "Response", "Session", "Server", "Application", "HttpContext", "Cache", "Trace", "Cookie" et "Server.MapPath" : 1. Requête, indiquant la requête HTTP émise par le client 2. Réponse : indiquant la réponse HTTP renvoyée par le serveur web au client ; client, etc
