Heim  >  Artikel  >  WeChat-Applet  >  Tutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js

Tutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js

高洛峰
高洛峰Original
2017-03-14 15:08:091825Durchsuche

Dieser Artikel enthält hauptsächlich Tutorials zur Entwicklung der öffentlichen WeChat-Plattform mit js und zur Entwicklung von WeChat

Wie verwende ich NodeJS, um die öffentliche WeChat-Plattform zu entwickeln?

Ich werde nicht viel mehr sagen. Lassen Sie uns zunächst kurz die Grundprinzipien der öffentlichen WeChat-Plattform vorstellen.

Der WeChat-Server entspricht einem Weiterleitungsserver. Das Endgerät (Mobiltelefon, Pad usw.) initiiert eine Anfrage an den WeChat-Server und der WeChat-Server leitet die Anfrage dann an den benutzerdefinierten Dienst weiter (hier). unserer konkreten Umsetzung). Nachdem der Dienst verarbeitet wurde, wird er an den WeChat-Server weitergeleitet und der WeChat-Server antwortet mit einer spezifischen Antwort an das Terminal. Das Kommunikationsprotokoll lautet: HTTP; das Datenformat ist:

XML. Der spezifische Prozess ist in der folgenden Abbildung dargestellt:

Tutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js

Tatsächlich müssen wir auf HTTP-Anfragen antworten. Wir analysieren den spezifischen Anforderungsinhalt gemäß einem bestimmten XML-Format. Nach der Verarbeitung müssen wir ihn auch gemäß einem bestimmten XML-Format zurückgeben.

Plattformregistrierung

Um die Entwicklung der öffentlichen WeChat-Plattform abzuschließen, müssen wir ein öffentliches WeChat-Plattformkonto registrieren. Die Registrierungsschritte sind wie folgt:

Öffnen Sie die offizielle Website der öffentlichen WeChat-Plattform, https://mp.weixin.qq.com/, und klicken Sie auf „Jetzt registrieren“.

Befolgen Sie dann die Anweisungen, um die grundlegenden Informationen einzugeben, Ihre E-Mail-Adresse zu aktivieren, den Typ, die Informationsregistrierung und die offiziellen Kontoinformationen auszuwählen und die Registrierung abzuschließen.

Nachdem die Registrierung abgeschlossen ist, müssen wir einige Grundeinstellungen für das offizielle Konto vornehmen. Melden Sie sich beim offiziellen Konto an, suchen Sie nach [Offizielle Kontoeinstellungen] und legen Sie dann den Avatar und andere Informationen fest.

NodeJS-Umgebungsaufbau

Wir müssen einen Server im öffentlichen Netzwerk finden, damit wir unsere NodeJS-Umgebung starten können. Nach dem Starten der Umgebung können wir die vom WeChat-Server gesendeten Nachrichten empfangen Festlegen der Zugangsadresse, und wir können auch Nachrichten an den WeChat-Server senden.

Installieren Sie auf dem öffentlichen Netzwerkserver. Nach Abschluss von NodeJS müssen wir auch einige von NodeJS verwendete Module installieren, z. B. Express, Node-XML, JSHA und andere Module. Es kann über den Befehl npm installiert werden.

Wir verwenden NodeJS, um das Senden und Empfangen von Nachrichten an den WeChat-Server sowie die Signaturauthentifizierung mit dem WeChat-Server zu implementieren.

In unserer Bearbeitungsumgebung rechts wurde die NodeJS-Umgebung für die Schüler installiert. Im folgenden Inhalt implementieren wir die Signaturauthentifizierung des WeChat-Servers für Studenten.

Erstellen Sie das Express-

Framework

Wir haben das Express-Modul im vorherigen Kurs installiert und in unserer Umgebung im rechten Dokument eine Datei mit dem Namen app.js erstellt. Jetzt werden wir das Express-Framework in dieser Datei vervollständigen. Der folgende Code:


var express = require("express");
var path=require('path');
var app = express();
server = require('http').Server(app);
app.set('views',dirname); // 设置视图 
app.set('view engine', 'html'); 
app.engine( '.html', require( 'ejs' ).express );
require('./index')(app); //路由配置文件
server.listen(80,function(){
console.log('App start,port 80.');
});
Fügen Sie dann eine Datei mit dem Namen test.html hinzu. Schreiben Sie den folgenden Inhalt


<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>汇智网</title>
</head>
<body>
<p><%=issuccess%></p>
</body>
</html>
Wir werden außerdem eine Datei mit dem Namen index.js hinzufügen, um unser Routing zu implementieren. Klicken Sie in der Bearbeitungsumgebung auf die Schaltfläche Datei hinzufügen

, um die Datei hinzuzufügen. Anschließend schreiben wir den folgenden Code, in dem die GET-Anfrage zur Überprüfung der Legitimität der konfigurierten URL und die POST-Anfrage verwendet wird wird zur Verarbeitung von WeChat-Nachrichten verwendet.


module.exports = function(app){
app.get(&#39;/&#39;,function(req,res){
res.render(&#39;test&#39;,{issuccess:"success"})
});
app.get(&#39;/interface&#39;,function(req,res){});
app.post(&#39;/interface&#39;,function(req,res){});
}
Damit ist das von uns benötigte Express-Framework abgeschlossen. Natürlich können wir auch den öffentlichen öffentlichen Ordner und die Middleware hinzufügen, die wir verwenden möchten. Speichern Sie die Datei, klicken Sie auf [Zum Ausführen senden] und dann auf [Zugriffstest], um es auszuprobieren. Notieren Sie sich die Adresse, um auf den Test zuzugreifen. Wir werden diese Adresse im nächsten Abschnitt verwenden.

WeChat-Serverkonfiguration

Wir melden uns bei der öffentlichen WeChat-Plattform an, suchen die Grundkonfiguration im Entwicklermodus und ändern dann die Serverkonfiguration. Wie im Bild gezeigt:

Tutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js

Zuerst muss die URL in den Pfad eingetragen werden, in dem wir nodejs installieren, um Daten im öffentlichen Netzwerk zu empfangen und zu senden. Wir können die Adresse von [Zugriffstest] im vorherigen Abschnitt eingeben und dann die entsprechende Route hinzufügen.

Das Token muss mit unserem benutzerdefinierten serverseitigen Token übereinstimmen. Nach dem Ausfüllen können Sie auf „Senden“ klicken. Vor dem Absenden starten wir app.js (klicken Sie auf „Senden zum Ausführen“). Auf diese Weise können wir anhand unseres Routenabgleichs überprüfen, ob die Signatur gültig ist.

Wenn die Konfiguration abgeschlossen ist, stellen Sie sicher, dass Sie die Konfiguration aktivieren.

Tutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js

网址接入

  公众平台用户提交信息后,微信服务器将发送GET请求到填写的URL上,并且带上四个参数:

  参数                     描述
  signature            微信加密签名
  timestamp            时间戳
  nonce                随机数
  echostr              随机字符串

  开发者通过检验signature对请求进行校验(下面有校验方式)。若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,否则接入失败。

  signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。

加密/校验流程:

1、将token、timestamp、nonce三个参数进行字典序排序;
2、将三个参数字符串拼接成一个字符串进行sha1加密;
3、开发者获得加密后的字符串可与signature对比,标识该请求来源于微信。
参数排序

  首先我们确认请求是来自微信服务器的get请求,那么就可以在index.js文件中进行添加代码了。然后在app.get(‘/interface',function(req,res){});的function中进行添加。

  先来获取各个参数的值,如下代码:


var token="weixin";
var signature = req.query.signature;
var timestamp = req.query.timestamp;
var echostr = req.query.echostr;
var nonce = req.query.nonce;

我们在这里对token进行设置,让其与微信服务器中设置的token一致。

然后对其中的token、timestamp、nonce进行排序,如下代码:


var oriArray = new Array();
oriArray[0] = nonce;
oriArray[1] = timestamp;
oriArray[2] = token;
oriArray.sort();

这样我们就完成了排序。

参数加密

  在上节中我们已经对参数进行了排序,然后我们在这一节中要将参数组成一个字符串,进行SH-1加密。在加密以前要用到jssha模块,在我们的文件中要引用该模块。


var jsSHA = require(&#39;jssha&#39;);

在上一节课中我们已经对参数排序完成,并存放在数组中,我们可以通过join方法来生成一个字符串,如下代码:


var original = oriArray.join(&#39;&#39;);

最后对该数据进行加密,如下代码:


var jsSHA = require(&#39;jssha&#39;);
var shaObj = new jsSHA(original, 'TEXT');
var scyptoString=shaObj.getHash('SHA-1', 'HEX');

好了这样就生成了我们需要的签名字符串scyptoString。

签名对比

  我们已经得到了我们想要的签名字符串scyptoString,然后我们就可以与来自微信服务器的签名进行对比了,对比通过,则我们就可以接收与发送消息了。


 if(signature == scyptoString){
 //验证成功
 } else {
 //验证失败
 }

Das obige ist der detaillierte Inhalt vonTutorial zur Entwicklung der öffentlichen WeChat-Plattform mit node.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn