使用云服务器搭建微信公众号后台服务

简介: 使用云服务器搭建微信公众号后台服务

一、申请微信个人订阅号


1.注册开发者账号


如果你还不是微信订阅号开发者,请先在微信公众平台注册:


https://mp.weixin.qq.com  

2.获取微信订阅号公众平台认证字段信息


我们需要获取3个字段:AppID Token EncodingAESKey。


登录微信公众平台,依次进入 开发->基本配置 可以拿到 AppID。


在基本配置 -> 服务器配置 -> 修改配置 表单中:


URL 填第一步申请的域名;


Token 用户根据提示填写,用于后面校验服务端合法性;


EncodingAESKey 点击随机生成按钮来生成。


Snipaste_2019-11-18_14-40-41.png


当点击表单提交按钮时,微信会通过 Token 来校验 URL 的合法性,这个我们在后面步骤实现,此界面暂时保留不关闭。


二、搭建 HTTP 服务


1.安装 NodeJS 和 NPM


使用下面的命令安装 NodeJS 和 NPM


curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash -yum install nodejs -y  

安装完成后,使用下面的命令测试安装结果


node -v  

2.编写 HTTP Server 源码


创建工作目录


mkdir -p /data/release/weapp  

进入此工作目录


cd /data/release/weapp  

创建 package.json


在刚才创建的工作目录创建 package.json,添加我们服务器包的名称和版本号,如下。


package.json


{      "name": "weapp",      "version": "1.0.0"  }  

完成后,使用 Ctrl + S 保存文件


添加 Server 源码


在工作目录创建 app.js,使用 Express.js 来监听 5050 端口,可参考下面的示例代码(注:将 app.js 文件中的token/appid/encodingAESKey等配置项替换为你的订阅号对应的取值)。


app.js


// 引用 express 来支持 HTTP Server 的实现  const express = require('express');    // 引用微信公共平台自动回复消息接口服务中间件  var wechat = require('wechat');    // 创建一个 express 实例  const app = express();    // 配置微信公众平台参数,在教程第二步中获取  var config = {      token: 'your token', // 填第二步中获取的 token      appid: 'your appid', // 填第二步中获取的 appid      encodingAESKey: 'your encodingAESKey', // 填第二步中获取的 encodingAESKey      checkSignature: true // 可选,默认为true。由于微信公众平台接口调试工具在明文模式下不发送签名,所以如要使用该测试工具,请将其设置为false   };    app.use(express.query());    app.use('/', wechat(config, function (req, res, next) {      res.reply({          content: '你好,Hello World!',          type: 'text'      });  }));    // 监听端口,等待连接  const port = 5050;  app.listen(port);    // 输出服务器启动日志  console.log(Server listening at http://127.0.0.1:${port});  

3。运行 HTTP 服务


在开始之前,我们先来安装 PM2


npm install pm2 --global  

PM2 安装时间可能稍长,请耐心等候


安装 Express


服务器源码里使用到了 Express 模块,下面的命令使用 NPM 来安装 Express


cd /data/release/weapp  npm install express --save  

安装 Wechat


服务器源码里使用到了 Wechat 模块,下面的命令使用 NPM 来安装 Wechat


cd /data/release/weapp  npm install wechat --save  

启动服务


安装完成后,使用 PM2 来启动 HTTP 服务


cd /data/release/weapp  pm2 start app.js  

现在 HTTP 服务已经在 http://你的服务器IP:5050 运行


要查看服务输出的日志,可以使用下面的命令:


pm2 logs  

如果要重启服务,可以使用下面的命令:


pm2 restart app  

三、搭建 nginx 对外服务


1.安装 Nginx


在 CentOS 上,可直接使用 yum 来安装 Nginx


yum install nginx -y  

安装完成后,使用 nginx 命令启动 Nginx:


nginx  

此时,访问 http://你的服务器IP 可以看到 Nginx 的测试页面


2.配置 HTTP 反向代理


外网用户访问服务器的 Web 服务由 Nginx 提供,Nginx 需要配置反向代理才能使得 Web 服务转发到本地的 Node 服务。


Nginx 配置目录在 /etc/nginx/conf.d,我们在该目录创建 wechat.conf


wechat.conf


server {          listen 80;          server_name www.example.com; # 改为第一步申请的域名            location / {              proxy_pass http://127.0.0.1:5050;          }      }  

按 Ctrl + S 保存配置文件,让 Nginx 重新加载配置使其生效:


nginx -s reload  

在浏览器通过 http 的方式访问你解析的域名来测试 HTTP 是否成功启动


四、使用Server端回复微信消息


1.提交服务端配置


我们将第一步微信公众平台中保留的表单提交,同时将 基本配置 -> 服务器配置 启用


2.关注、发送与消息回复


首先通过二维码关注微信订阅号


在聊天界面向微信公众号发送一条消息


最终我们会回到一条 你好,Hello World! 的回复

阿里云服务器:活动地址

购买可领取:阿里云代金券

相关实践学习
基于ECS搭建FTP服务
本教程介绍如何在Linux实例上安装并配置vsftpd,在被动模式下,使用本地用户访问FTP服务器的配置方法。。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5月前
|
小程序 Java 关系型数据库
基于微信小程序的智慧养老服务系统
本系统基于Java、MySQL和Spring Boot技术,构建高效、安全的养老院管理系统,提升信息处理速度与管理规范性,实现数据自动化备份与网络化管理,助力养老机构信息化升级。
|
9月前
|
存储 缓存 运维
微信读书十周年,后台架构的技术演进和实践总结
微信读书经过了多年的发展,赢得了良好的用户口碑,后台系统的服务质量直接影响着用户的体验。团队多年来始终保持着“小而美”的基因,快速试错与迭代成为常态。后台团队在日常业务开发的同时,需要主动寻求更多架构上的突破,提升后台服务的可用性、扩展性,以不断适应业务与团队的变化。
367 0
|
9月前
|
监控 数据可视化 BI
微信计数器统计工具,QQ统计器手机APP,通过autojs实现后台
这是一款基于AutoJS的微信/QQ新增好友监控脚本,具备后台运行、自动统计每日新增好友数量、生成简单报表及定时提醒功能。
|
小程序 Java 关系型数据库
基于Java微信小程序同城家政服务系统设计和实现(源码+LW+调试文档+讲解等)
基于Java微信小程序同城家政服务系统设计和实现(源码+LW+调试文档+讲解等)
微信小程序没有后台切换如何解决
微信小程序没有后台切换如何解决
|
弹性计算 小程序 UED
|
监控 网络安全 调度
Quartz.Net整合NetCore3.1,部署到IIS服务器上后台定时Job不被调度的解决方案
解决Quartz.NET在.NET Core 3.1应用中部署到IIS服务器上不被调度的问题,通常需要综合考虑应用配置、IIS设置、日志分析等多个方面。采用上述策略,结合细致的测试和监控,可以有效地提高定时任务的稳定性和可靠性。在实施任何更改后,务必进行充分的测试,以验证问题是否得到解决,并监控生产环境的表现,确保长期稳定性。
1340 1
|
小程序 JavaScript Java
微信小程序+SpringBoot接入后台服务,接口数据来自后端
这篇文章介绍了如何将微信小程序与SpringBoot后端服务进行数据交互,包括后端接口的编写、小程序获取接口数据的方法,以及数据在小程序中的展示。同时,还涉及到了使用Vue搭建后台管理系统,方便数据的查看和管理。
微信小程序+SpringBoot接入后台服务,接口数据来自后端
|
小程序
尝试使用阿里云服务器搭建微信小程序
华北电力大学核工程大一学生,出于对编程的热爱与大创项目需求,涉足微信小程序搭建。初期在实验指导下克服不熟悉编程的困难,但后期发现教程引导不足,尤其是对于代码定位缺乏清晰指引。建议加强网页图像指导,以适应不同编程水平用户,尤其是新手。
尝试使用阿里云服务器搭建微信小程序
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的智能推荐的校园社区服务微信小程序附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的智能推荐的校园社区服务微信小程序附带文章源码部署视频讲解等
239 0

热门文章

最新文章