La plateforme publique WeChat, qui est ce que nous appelons habituellement « compte public », était autrefois nommée « plateforme officielle » et « plateforme média », mais a finalement été nommée. "Plateforme publique". D'après le nom de WeChat, je peux constater que la plateforme publique n'est pas seulement une plateforme utilisée par les fonctionnaires et les médias, mais une plateforme unifiée ouverte à tout le public.
Adresse de la plateforme publique WeChat : https://mp.weixin.qq.com/
La plateforme publique WeChat comprend quatre sections principales : compte d'abonnement, compte de service, mini-programme et compte d'entreprise. Selon le plan de classe ouverte de WeChat 2016, le compte Enterprise sera fusionné avec Enterprise WeChat à l'avenir, nous commencerons donc principalement par expliquer les trois premières parties :
Une brève comparaison des différences entre les trois premières et les points clés de ce cours et des suivants :
1. Les comptes d'abonnement et les comptes de service sont tous deux. « comptes publics » au sens traditionnel. Pour les capacités de messagerie de groupe, les différences détaillées peuvent être consultées sur la plateforme officielle : http://kf.qq.com/faq/140806zARbmm140826M36RJF.html Nous nous concentrerons sur le développement des capacités de service, et en termes de services, les modèles de développement des deux sont exactement les mêmes, sauf que les comptes de service peuvent utiliser plus de services interfaces , et les comptes d'abonnement sont des comptes de service « castrés ». Par conséquent, dans les cours suivants, nous utiliserons le numéro de service pour faire fonctionner le boîtier.
2. L'applet WeChat, à l'origine un « compte d'application WeChat », est une application ancrée dans l'écosystème WeChat. En raison des restrictions d'Apple et de Google, le « Compte App » est mort avant son lancement et a été remplacé par le « Mini Programme WeChat » avec des fonctions modérément émasculées. Son expérience de fonctionnement est comparable à celle d'une APP native, faisant des Mini Programmes un. direction de développement populaire de nos jours. Le nouveau cours de développement H5 de Jerry Education comprendra également le développement du populaire mini-programme WeChat.
Entrez sur la plateforme publique WeChat https://mp.weixin.qq.com. et cliquez sur S'inscrire maintenant dans le coin supérieur droit et sélectionnez « Compte de service » ou « Compte d'abonnement » pour vous inscrire (les comptes de service ne sont disponibles que pour les institutions Inscription des utilisateurs , les utilisateurs individuels ne peuvent choisir que des comptes d'abonnement)
Vous devez en remplir un lors de votre inscription. Remplissez simplement les informations sur la série en fonction des invites et ne seront pas décrites en détail ici.
Si vous ne souhaitez pas créer de compte pour le moment ou si vous ne parvenez pas à créer un compte de service, vous pouvez choisir de demander un compte test officiel. . Adresse de l'application : http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login Cliquez et scannez le code QR pour obtenir un compte test avec toutes les autorisations du compte de service.
Lorsque la plateforme publique WeChat accède au backend, elle doit fournir une adresse réseau externe accessible correctement. La plateforme WeChat a deux exigences pour l'URL du backend :
① Elle. doit pouvoir utiliser le réseau public Accès ② doit utiliser le port 80
Pour atteindre les deux points ci-dessus, nous pouvons choisir d'acheter un serveur réseau externe, tel qu'Alibaba Cloud, Baidu Cloud, Tencent Cloud ... sont tous de bons choix. S'il n'y a pas de serveur, vous pouvez choisir d'utiliser un outil de cartographie de réseau externe pour mapper notre lien réseau interne avec le réseau public. Certains bons logiciels de cartographie incluent : peanut shell, ngrok, nat123, etc...
. Ces logiciels peuvent tous être utilisés. Baidu est très simple à recherchez et téléchargez-le. Voici une brève explication sur la façon de l'utiliser :
① Ngrock : <.>
Entrez dans l'environnement DOS et passez au disque où se trouve ngrock Symbole, entrez ngrock8080 et appuyez sur Entrée :
②Peanut shell, nat123, vous pouvez installer le logiciel et l'utiliser dans le logiciel. Pour plus de détails, veuillez consulter l'expérience Baidu : http://jingyan.baidu.com/article/363872ec361d3f6e4ba16ff9.html Je n'entrerai pas dans les détails. ici
4. Principe d'interaction des données de la plateforme publique WeChatAprès avoir configuré l'adresse d'accès au réseau public, nous l'avons développée nous-mêmes. Le code d'arrière-plan peut être placé sur l'adresse du réseau public, alors comment les utilisateurs accéder à notre code ?Jetons un coup d'œil au principe d'interaction des données de la plateforme publique WeChat :
Comme vous pouvez le voir sur le image ci-dessus, la plate-forme publique WeChat ne sert en fait que de pont. Le code qui gère réellement les affaires et fournit des services est toujours placé sur notre propre serveur ou sur la cartographie du réseau public.
Ensuite, nous pouvons écrire le code backend sur notre propre ordinateur (serveur), fournir une URL accessible depuis le réseau public via l'outil de cartographie, puis lier cette URL au backend WeChat.
Le processus de développement réel sera indiqué ci-dessous. Nous pouvons nous référer aux documents de développement officiels : https://mp.weixin.qq.com/wiki
1. Remplissez la configuration du serveur Entrez sur la plateforme publique WeChat, cliquez sur [Développement - Configuration de base] à gauche et sélectionnez [Configuration du serveur]. Vous pouvez accéder à la page de configuration :URL : celle c'est ce que nous avons mentionné ci-dessus L'adresse d'accès au réseau public du serveur backend Jeton : mot de passe de vérification personnalisé du développeur EncodingAES2. Vérifiez si le message est valide Lorsque nous cliquons sur Soumettre, le serveur WeChat envoyez une demande Get, accédez à notre adresse ci-dessus et transmettez quatre paramètres en même temps :Clé : chaîne aléatoire , si le la méthode de cryptage et de décryptage des messages adopte le mode sans échec seule la vérification est requise
1. Utilisez MyEclipse pour créer un projet Web et créer un nouveau servlet :
2 Dans la méthode doGet du servlet, obtenez les quatre paramètres de vérification ci-dessus. :
Écrivez une classe d'outils pour utiliser la méthode de vérification :
3. 🎜 >
Utiliser sha1
méthode de cryptage ↓4. Appelez la méthode de vérification dans le Servlet et vérifiez le résultat
Si la vérification réussit, la chaîne aléatoire obtenue eahostr sera renvoyée à la plateforme WeChat dans. de la manière originale :
5. Démarrez Tomcat
et mappez l'adresse locale du servlet (par exemple, cette machine est : localhost:8080/WeiXin/servlet/WeiXinServlet) au réseau public. troisième partie ci-dessus, effectuez le mappage du réseau public pour garantir que l'adresse du réseau public est accessible correctement. Je mettrai directement le code sur le serveur public pour y accéder. Obtenez l'adresse suivanteEntrez les informations relatives à la configuration du backend WeChat :
Cliquez sur Soumettre, WeChat enverra la commande Get au servlet et appellera la méthode doGet pour effectuer l'opération de vérification que nous avons écrite. Enfin, si une chaîne aléatoire est renvoyée avec succès, la liaison est réussie.
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String signature = request.getParameter("signature"); String timestamp = request.getParameter("timestamp"); String nonce = request.getParameter("nonce"); String echostr = request.getParameter("echostr"); PrintWriter out = response.getWriter(); if(CheckUtil.checkSignature(signature, timestamp, nonce)){ //如果校验成功,将得到的随机字符串原路返回 out.print(echostr); } }Copier après la connexion
package com.jredu.util; import java.security.MessageDigest; import java.util.Arrays; public class CheckUtil { public static final String tooken = "jredu100"; //开发者自行定义Tooken public static boolean checkSignature(String signature,String timestamp,String nonce){ //1.定义数组存放tooken,timestamp,nonce String[] arr = {tooken,timestamp,nonce}; //2.对数组进行排序 Arrays.sort(arr); //3.生成字符串 StringBuffer sb = new StringBuffer(); for(String s : arr){ sb.append(s); }Copier après la connexion
//4.sha1加密,网上均有现成代码 String temp = getSha1(sb.toString()); //5.将加密后的字符串,与微信传来的加密签名比较,返回结果 return temp.equals(signature); } public static String getSha1(String str){ if(str==null||str.length()==0){ return null; } char hexDigits[] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'}; try { MessageDigest mdTemp = MessageDigest.getInstance("SHA1"); mdTemp.update(str.getBytes("UTF-8")); byte[] md = mdTemp.digest(); int j = md.length; char buf[] = new char[j*2]; int k = 0; for (int i = 0; i < j; i++) { byte byte0 = md[i]; buf[k++] = hexDigits[byte0 >>> 4 & 0xf]; buf[k++] = hexDigits[byte0 & 0xf];}Copier après la connexion
char hexDigits[] = {'0','1','2','3','4','5','6','7','8','9', 'a','b','c','d','e','f'}; try { MessageDigest mdTemp = MessageDigest.getInstance("SHA1"); mdTemp.update(str.getBytes("UTF-8")); byte[] md = mdTemp.digest(); int j = md.length; char buf[] = new char[j*2]; int k = 0; for (int i = 0; i < j; i++) { byte byte0 = md[i]; buf[k++] = hexDigits[byte0 >>> 4 & 0xf]; buf[k++] = hexDigits[byte0 & 0xf]; } return new String(buf); } catch (Exception e) { // TODO: handle exception return null; } } }Copier après la connexion
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!