ホームページ  >  記事  >  ウェブフロントエンド  >  node.js WeChatパブリックプラットフォーム開発tutorial_node.js

node.js WeChatパブリックプラットフォーム開発tutorial_node.js

WBOY
WBOYオリジナル
2016-05-16 15:12:012084ブラウズ

nodejs を使用して WeChat パブリック プラットフォームを開発するにはどうすればよいですか?

これ以上は言いません。WeChat パブリック プラットフォームの基本原則を簡単に紹介しましょう。

WeChat サーバーは転送サーバーに相当します。端末 (携帯電話、Pad など) は WeChat サーバーへのリクエストを開始し、WeChat サーバーはそのリクエストをカスタム サービスに転送します (ここでは具体的な実装を示します)。 )。サービスが処理された後、WeChat サーバーに転送され、WeChat サーバーは端末に特定の応答を返します。通信プロトコルは HTTP、データ形式は XML です。
具体的なプロセスを次の図に示します。

実際に行う必要があるのは、HTTP リクエストに応答することです。特定のリクエストのコンテンツを特定の XML 形式に従って解析し、処理後、それを特定の XML 形式に従って返す必要があります。

プラットフォーム登録

WeChat パブリック プラットフォームの開発を完了するには、WeChat パブリック プラットフォームのアカウントを登録する必要があります。登録手順は次のとおりです。
WeChat パブリック プラットフォームの公式 Web サイト https://mp.weixin.qq.com/ を開き、[今すぐ登録] をクリックします。

その後、画面の指示に従って基本情報の入力、メールの起動、種類、情報登録、公式アカウント情報の選択を行って登録を完了してください。

登録が完了したら、公式アカウントの基本設定を行う必要があります。公式アカウントにログインし、[公式アカウント設定]からアバターなどを設定します。

nodejs 環境のセットアップ

nodejs 環境を開始するには、パブリック インターネット上でサーバーを見つける必要があります。環境を開始した後、アクセス アドレスを設定することで、WeChat サーバーから送信されたメッセージを受信したり、メッセージを送信したりすることができます。 WeChatサーバー。

パブリックサーバーにnodejsをインストールした後、express、node-xml、jssha、その他のモジュールなど、nodejsで使用されるいくつかのモジュールもインストールする必要があります。 npmコマンドでインストールできます。

nodejs を使用して、WeChat サーバーへのメッセージの送受信と、WeChat サーバーとの署名認証を実装します。

右側の編集環境には、学生用に nodejs 環境がインストールされています。以下のコンテンツでは、学生向けにWeChatサーバーの署名認証を実装していきます。

Express フレームワークの作成

前のコースで Express モジュールをインストールし、右側の環境に app.js という名前のファイルを作成しました。ここで、このファイル内の Express フレームワークを完成させます。次のコード:

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.');
});

次に、test.html という名前のファイルを追加します。次のように書きます

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>汇智网</title>
</head>
<body>
<div><%=issuccess%></div>
</body>
</html>

ルーティングを実装するには、index.js という名前のファイルを追加する必要もあります。編集環境で [ファイルの追加] ボタンをクリックしてファイルを追加し、次のコードを記述します。このコードでは、構成された URL の正当性を確認するために GET リクエストが使用され、WeChat メッセージを処理するために POST リクエストが使用されます。

module.exports = function(app){
app.get('/',function(req,res){
res.render('test',{issuccess:"success"})
});
app.get('/interface',function(req,res){});
app.post('/interface',function(req,res){});
}

这样我们需要的express框架就完成了,当然我们还可以添加public公共文件夹以及我们要用到的中间件。保存文件,点击【提交运行】,然后点击【访问测试】,去试试吧。记下访问测试的地址,我们将在下一节中会用到该地址。

微信服务器配置

  我们登录微信公众平台,在开发者模式下面找到基本配置,然后修改服务器配置。如图所示:

  首先URL要填写公网上我们安装nodejs接收与发送数据的路径。我们可以填写上节中【访问测试】的地址,然后加上对应的路由就可以了。

  Token要与我们自定义服务器端的token一致。填写完成以后,就可以点击提交了,在提交以前,我们启动app.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('jssha');

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

var original = oriArray.join('');

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

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

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

签名对比

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。