Die öffentliche WeChat-Plattform, die wir normalerweise als „öffentliches Konto“ bezeichnen, wurde einst als „offizielle Plattform“ und „Medienplattform“ bezeichnet, erhielt aber schließlich den Namen „Öffentliche Plattform“. Anhand der Benennung von WeChat kann ich erkennen, dass die öffentliche Plattform nicht nur eine Plattform ist, die von Beamten und Medien genutzt wird, sondern eine einheitliche Plattform, die der gesamten Öffentlichkeit offen steht.
Adresse der öffentlichen WeChat-Plattform: https://mp.weixin.qq.com/
Die öffentliche WeChat-Plattform besteht aus vier Hauptabschnitten: Abonnementkonto, Dienstkonto, Miniprogramm und Unternehmenskonto. Gemäß dem offenen Kursplan von WeChat für 2016 wird das Enterprise-Konto in Zukunft mit Enterprise WeChat zusammengeführt, daher beginnen wir hauptsächlich mit der Erläuterung der ersten drei Teile:
Ein kurzer Vergleich der Unterschiede zwischen den ersten drei und den wichtigsten Punkten dieses und der folgenden Kurse:
1. Abonnementkonten und Dienstkonten „Öffentliche Konten“ im herkömmlichen Sinne. Detaillierte Unterschiede zu Gruppen-Messaging-Funktionen können auf der offiziellen Plattform eingesehen werden: http://kf.qq.com/faq/140806zARbmm140826M36RJF.html Wir werden uns auf die Entwicklung von Service-Funktionen konzentrieren In Bezug auf Dienste sind die Entwicklungsmodelle der beiden genau gleich, mit der Ausnahme, dass Dienstkonten mehr Dienstschnittstellen verwenden können und Abonnementkonten „kastrierte“ Dienstkonten sind. Daher werden wir in den folgenden Kursen Dienstkonten zur Verwaltung von Fällen verwenden.
2. Das WeChat-Applet, ursprünglich ein „WeChat-Anwendungskonto“, ist eine APP, die im WeChat-Ökosystem verwurzelt ist. Aufgrund von Einschränkungen durch Apple und Google starb das „App-Konto“ vor seiner Einführung und wurde durch das „WeChat Mini-Programm“ mit moderat entmannten Funktionen ersetzt. Sein Bedienerlebnis ist mit dem einer nativen APP vergleichbar, was Mini-Programme zu einem macht heutzutage beliebte Entwicklungsrichtung. Der neue H5-Entwicklungskurs von Jerry Education wird auch die beliebte WeChat-Miniprogrammentwicklung umfassen. 2. Vorbereitung für die Kontoentwicklung1.Benutzerregistrierung verfügbar, einzelne Benutzer können nur Abonnementkonten auswählen)
Sie müssen bei der Registrierung eines ausfüllen. Füllen Sie einfach die Serieninformationen gemäß den Eingabeaufforderungen aus und werden hier nicht im Detail beschrieben. 2. Beantragung eines Testkontos Wenn Sie vorerst kein Konto registrieren möchten oder nicht in der Lage sind, ein Dienstkonto zu registrieren, können Sie sich für die Beantragung eines offiziellen Testkontos entscheiden . Anwendungsadresse: http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login Klicken Sie und scannen Sie den QR-Code, um ein Testkonto mit allen Berechtigungen des Dienstkontos zu erhalten.① Es muss in der Lage sein, das öffentliche Netzwerk zu nutzen. Zugriff ② muss Port 80 verwenden
Um die beiden oben genannten Punkte zu erreichen, können wir uns für den Kauf eines externen Netzwerkservers entscheiden, z. B. Alibaba Cloud, Baidu Cloud, Tencent Cloud ... sind alles gute Entscheidungen. Wenn kein Server vorhanden ist, können Sie ein externes Netzwerk-Mapping-Tool verwenden, um unsere interne Netzwerkverbindung dem öffentlichen Netzwerk zuzuordnen. Zu den guten Mapping-Software gehören: Peanut Shell, Ngrok, Nat123 usw. Diese Software kann alle verwendet werden. Baidu ist sehr einfachzu suchen und herunterzuladen. Hier finden Sie eine kurze Erklärung zur Verwendung:
① Ngrock:
Betreten Sie die DOS-Umgebung und wechseln Sie zu der Festplatte, auf der sich ngrock befindet. Symbol, geben Sie ngrock8080 ein und drücken Sie die Eingabetaste:
②Peanut Shell, nat123, Sie können die -Software installieren und in der Software bedienen. Weitere Informationen finden Sie in der Baidu-Erfahrung: http://jingyan.baidu.com/article/363872ec361d3f6e4ba16ff9.html. Ich werde nicht auf Details eingehen hier
4. Prinzip der Dateninteraktion auf der öffentlichen WeChat-PlattformNachdem wir die öffentliche Netzwerkzugriffsadresse eingerichtet haben, haben wir sie selbst entwickelt. Der Hintergrundcode kann auf der öffentlichen Netzwerkadresse platziert werden. Wie können Benutzer dies tun? Zugriff auf unseren Code?Werfen wir einen Blick auf das Dateninteraktionsprinzip der öffentlichen WeChat-Plattform:
Wie Sie aus dem sehen können Bild oben: Die öffentliche WeChat-Plattform dient eigentlich nur als Brücke. Der Code, der tatsächlich Geschäfte abwickelt und Dienste bereitstellt, wird immer noch auf unserem eigenen Server oder in der öffentlichen Netzwerkzuordnung platziert.
Anschließend können wir den Backend-Code auf unserem eigenen Computer (Server) schreiben, über das Mapping-Tool eine URL bereitstellen, auf die vom öffentlichen Netzwerk aus zugegriffen werden kann, und diese URL dann an das WeChat-Backend binden.
Der eigentliche Entwicklungsprozess wird unten aufgeführt. Wir können auf die offiziellen Entwicklungsdokumente verweisen: https://mp.weixin.qq.com/wiki
Betreten Sie die öffentliche WeChat-Plattform, klicken Sie links auf [Entwicklung – Grundkonfiguration] und wählen Sie [Serverkonfiguration]. Sie können die Konfigurationsseite aufrufen:
Darunter:
URL: that ist das, was wir oben erwähnt haben. Die öffentliche Netzwerkzugriffsadresse des Backend-Servers
Token: benutzerdefiniertes Verifizierungskennwort des Entwicklers
EncodingAESSchlüssel: zufällige Zeichenfolge , wenn The Die Nachrichtenverschlüsselungs- und -entschlüsselungsmethode verwendet den Abgesicherten Modusnur eine Überprüfung ist erforderlich
Wenn wir auf „Senden“ klicken, wird der WeChat-Server dies tun Senden Sie eine Get-Anfrage, gehen Sie zu unserer oben genannten Adresse und übergeben Sie gleichzeitig vier Parameter:
Wir bestehen. Überprüfen Sie die Signatur, um die Anfrage zu überprüfen (die Überprüfungsmethode finden Sie unten). Wenn bestätigt wird, dass diese GET-Anfrage vom WeChat-Server stammt, geben Sie bitte den Inhalt des Parameters echostr so zurück, wie er ist. Dann wird der Zugriff wirksam und Sie werden erfolgreich zum Entwickler, andernfalls schlägt der Zugriff fehl . Der Verschlüsselungs-/Verifizierungsprozess ist wie folgt:
Als nächstes implementieren wir die Codeoperation.
1. Verwenden Sie MyEclipse, um ein Webprojekt und ein neues Servlet zu erstellen:
2. Rufen Sie in der doGet-Methode des Servlets die oben genannten vier Überprüfungsparameter ab :
3. Schreiben Sie eine Werkzeugklasse, um die Verifizierungsmethode auszuführen:
für Verifizierungsschritte siehe oben [5-2] dreistufiger Betriebsprozess
Verwenden Sie die sha1-Verschlüsselungsmethode ↓
4. Rufen Sie die Überprüfungsmethode im Servlet auf und überprüfen Sie das Ergebnis Wenn die Überprüfung erfolgreich ist, wird die erhaltene Zufallszeichenfolge eahostr an die WeChat-Plattform zurückgegeben Der ursprüngliche Weg:
An diesem Punkt sind die Servlet- und Check-Tool-Klassen abgeschlossen.
5. Starten Sie Tomcat und ordnen Sie die lokale Adresse des Servlets (zum Beispiel: localhost:8080/WeiXin/servlet/WeiXinServlet) zu Im dritten Teil oben führen Sie eine öffentliche Netzwerkzuordnung durch, um sicherzustellen, dass auf die öffentliche Netzwerkadresse korrekt zugegriffen werden kann.
Ich werde den Code für den Zugriff direkt auf den öffentlichen Server stellen. Holen Sie sich die folgende Adresse
Geben Sie Informationen zur WeChat-Backend-Konfiguration ein:
Klicken Sie auf „Senden“. WeChat sendet den Get-Befehl an das Servlet und ruft die doGet-Methode auf, um den von uns geschriebenen Überprüfungsvorgang auszuführen. Wenn schließlich eine zufällige Zeichenfolge erfolgreich zurückgegeben wird, ist die Bindung erfolgreich.
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); } }Nach dem Login kopieren
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); }Nach dem Login kopieren
//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];}Nach dem Login kopieren
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; } } }Nach dem Login kopieren
Das obige ist der detaillierte Inhalt vonVerwendung von JAVA zur Entwicklung der öffentlichen WeChat-Plattform (1) – Umgebungsaufbau und Entwicklungszugriff. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!