手把手教你基于CentOS8搭建微信订阅号后台服务(一)
一、准备域名并完成解析
- 关于域名,我买的是阿里的一个1元/年的廉价域名,同时国内域名都需要备案,当时在这里耽搁了挺久的。
- 域名解析的话,在阿里云官方帮助文档里有。传送门:https://help.aliyun.com/document_detail/29716.html
二、申请微信个人订阅号
- 在微信公众号平台注册开发者账号
- 获取公众平台认证字段信息
- AppID:登入平台,选择 开发-基本配置
- Token:基本配置-服务器配置-修改配置,url填写第一步申请的域名,编一个Token
- EncodingAESKey:随机获取
保留页面,进入下一步
三、搭建HTTP服务
使用Node + Express搭建一个HTTP服务器
安装NodeJS 和 npm
常用的兄弟应该已经装过了,没装过的用下面的代码安装:
curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash - yum install nodejs -y测试
node -v
出现版本号,说明安装成功。编写 HTTP Server 源码
- 创建工作目录
mkdir -p /data/release/weapp - 进入工作目录
cd /data/release/weapp - 创建 package.json
- 在刚才创建的工作目录创建 package.json,添加我们服务器包的名称和版本号
vim package.json
{ "name":"weapp", "version":"v6.10.3" }
- 创建工作目录
添加 Server 源码
需开放5050端口,官方文档传送门:https://help.aliyun.com/document_detail/25471.html?spm=a2c6h.13066369.0.0.1eec1ecffpabDV&source=5176.11533457&userCode=xbifxhv7&type=copy
-工作目录创建 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}`);
- 运行 HTTP 服务
- 安装PM2:
npm install pm2 --global - 安装Express
cd /data/release/weapp
npm install express --save
- 安装 Wechat
cd /data/release/weapp
npm install wechat --save
- 启动服务
cd /data/release/weapp
pm2 start app.js
- 查看服务输出的日志
pm2 logs - 重启服务
pm2 restart app
我们使用 PM2 来进行 Node 进程的运行、监控和管理 - NPM 仓库在国内访问速度可能不太理想,如果实在太慢可以尝试使用 CNPM 的 Registry 进行安装
npm install pm2 -g --registry=https://r.cnpmjs.org/
四、搭建 Nginx 对外服务
简单来讲,就是做一个外网可以访问的途径。
- 安装 Nginx(我之前宝塔都装过了,这里也可以用命令安装)
yum install nginx -y - 启动 Nginx
nginx
理论上到这就可以域名访问了 - 配置 HTTP 反向代理
Nginx 配置目录在 /etc/nginx/conf.d,我们在该目录创建 wechat.conf
server {
listen 80;
server_name www.example.com; # 改为第一步申请的域名
location / {
proxy_pass http://127.0.0.1:5050;
}
}
nginx -s reload
##在浏览器通过 http 的方式访问你解析的域名来测试 HTTP 是否成功启动
五、使用Server端回复微信消息
- 提交服务端配置
- 我们将第二步微信公众平台中保留的表单提交,同时将 基本配置 - 服务器配置 启用
2.关注、发送与消息回复 - 首先通过二维码关注微信订阅号
- 在聊天界面向微信公众号发送一条消息
- 最终我们会回到一条 你好,Hello World! 的回复
- 我们将第二步微信公众平台中保留的表单提交,同时将 基本配置 - 服务器配置 启用
end
手把手教你基于CentOS8搭建微信订阅号后台服务(一)的更多相关文章
- 使用python django快速搭建微信公众号后台
前言 使用python语言,django web框架,以及wechatpy,快速完成微信公众号后台服务的简易搭建,做记录于此. wechatpy是一个python的微信公众平台sdk,封装了被动消息和 ...
- 【转】手把手教你读取Android版微信和手Q的聊天记录(仅作技术研究学习)
1.引言 特别说明:本文内容仅用于即时通讯技术研究和学习之用,请勿用于非法用途.如本文内容有不妥之处,请联系JackJiang进行处理! 我司有关部门为了获取黑产群的动态,有同事潜伏在大量的黑产群 ...
- 手把手教你读取Android版微信和手Q的聊天记录(仅作技术研究学习)
1.引言 特别说明:本文内容仅用于即时通讯技术研究和学习之用,请勿用于非法用途.如本文内容有不妥之处,请联系JackJiang进行处理! 我司有关部门为了获取黑产群的动态,有同事潜伏在大量的黑产群 ...
- 手把手教你用vue-cli搭建vue项目
手把手教你用vue-cli搭建vue项目 本篇主要是利用vue-cli来搭建vue项目,其中前提是node和npm已经安装好,文章结尾将会简单提到一个简单的例子.使用vue-cli搭建项目最开始我也是 ...
- 手把手教你使用 VuePress 搭建个人博客
手把手教你使用 VuePress 搭建个人博客 有阅读障碍的同学,可以跳过第一至四节,下载我写好的工具包: git clone https://github.com/zhangyunchencc/vu ...
- 手把手教你用Python搭建自己的量化回测框架【均值回归策略】
手把手教你用Python搭建自己的量化回测框架[均值回归策略] 引言 大部分量化策略都可以归类为均值回归与动量策略.事实上,只有当股票价格是均值回归或趋势的,交易策略才能盈利.否则,价格是随机游走的, ...
- SpringCloud学习之手把手教你用IDEA搭建入门项目(二)
本篇博客是承接上一篇<手把手教你用IDEA搭建SpringCloud入门项目(一)>,不清楚的请到我的博客空间查看后再看本篇博客 1)先创建一个Eureka服务注册中心模块,用来作为服务的 ...
- 手把手教你认识并搭建Nginx
手把手教你认识并搭建Nginx Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor ...
- 沉淀,再出发——手把手教你使用VirtualBox搭建含有三个虚拟节点的Hadoop集群
手把手教你使用VirtualBox搭建含有三个虚拟节点的Hadoop集群 一.准备,再出发 在项目启动之前,让我们看一下前面所做的工作.首先我们掌握了一些Linux的基本命令和重要的文件,其次我们学会 ...
随机推荐
- 高并发&性能优化(二)------系统监控工具使用
上一篇主要从总体介绍了高并发&性能优化的相关思路和方法,本篇主要介绍系统监控工具. [CPU查看工具] ------top命令(性能) 进入top命令后,按1即可看到每核CPU的运行指标与详细 ...
- MPI计算π
MPI计算\(\pi\) 利用公式 \[\int_0^1 \frac{4}{1+x^2}dx = \pi \] #include<stdio.h> #include<mpi.h> ...
- [CSP-S2019]划分 题解
CSP-S2 2019 D2T2 考场上读完题感觉是DP就直接扔了开T3了,考完才发现部分分好像不难拿,枯了 题意分析 给出一个数列,要求将其分成几段,使每段的和非严格递增,求最小的每段的和的平方和. ...
- vue路由守卫+cookie实现页面跳转时验证用户是否登录----(二)设置路由守卫
上一篇我们已经封装好了cookie方法,登录成功之后也可以吧用户信息存到cookie中,接下来需要在router/index.js中引入一下cookie.js文件 然后继续添加以下代码 /* * be ...
- 2020重新出发,MySql基础,性能优化
@ 目录 MySQL性能优化 MySQL性能优化简述 使用 SHOW STATUS 命令 使用慢查询日志 MySQL 查询分析器 EXPLAIN DESCRIBE 索引对查询速度的影响 MySQL优化 ...
- 删除MBR分区如何使用光盘恢复
1.备份MBR分区表 dd if=/dev/sda of=/data/mbr.bak bs=1 count=64 skip=446 分区表前512字节分为三部分,第一部分446字节与启动相关 ...
- Black & White(尺取)
链接:https://ac.nowcoder.com/acm/contest/893/F来源:牛客网 * 第一行一个整数 T ,表示接下来有 T 个样例.* 首先输入n,m,表示S串的长度n和操作次数 ...
- HTML语言基本单词与css基本单词
DOCTYPE 文档 html 网页 head 头部 body 主体 title 题目 p 段落 color 颜色 style 样式 backgroun ...
- three.js尝试(二)模拟游戏开发:3D人物在地图上行走
本次尝试,模拟了一个小人物在场景中行走,使用简单模型建立了森林,图片纹理模拟草地,加载3D模型呈现人物,使用按键asdw模拟人物的行走,行走和站立时人物的切换等. 主要用到点:3D模型的加载,模型的动 ...
- 15_Python的模块module
1.模块的概述 1.模块是Python程序架构的一个核心概念,每一个以.py结尾的Python源代码文件都是一个模块 2.模块名和标识符的命名规则一样,由数字字母下划线组成且不能以数字开头,也不要和系 ...