• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

独立部署小程序基于nodejs的服务器

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

完全自定义的部署小程序服务器, 不依托于腾讯云服务器体系.
以阿里云服务器为基础建立.
服务器语言选用nodejs.

目的

实现https基本访问请求
实现会话管理
实现socket长连接
一个基于socket的小游戏

源代码在这里:
https://github.com/acharzuo/wx_miniapp_baseDemo

基础要求

有一台服务器(在外网能访问的服务器)
有一个已经备案的域名(必须备案)
有一个已经申请的https证书域名(二级即可)
客户端代码:



我的实验环境:
服务器: 阿里云云服务器ecs (https://ecs.console.aliyun.com/)
备案域名: 9z9z.vip
https证书(ca证书): (免费型DV SSL) (https://common-buy.aliyun.com/ )
https证书申请域名: wuxing.9z9z.vip

配置nodejs环境

登录服务器, 安装nodejs环境

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

查看nodejs版本.

node -v

安装配置mongode环境

# 安装mongodb及客户端工具
yum install mongodb-server mongodb -y
#建立mongo数据和日志存储目录
mkdir -p /data/mongodb
mkdir -p /data/logs/mongodb
# 启动mongo
mongod --fork --dbpath /data/mongodb --logpath /data/logs/mongodb/weapp.log
#  键入mongo控制台,添加用户
mongo
> use weapp;
> db.createUser({ user: \'weapp\', pwd: \'weapp-dev\', roles: [\'dbAdmin\', \'readWrite\']});
或者 
db.addUser({ user: \'weapp\', pwd: \'weapp-dev\', roles: [\'dbAdmin\', \'readWrite\']}); 
> exit;

安装pm2, nodejs服务器管理器

npm install pm2 -g 

修改源代码中的appid和appSecretId
在, 微信小程序后台, 设置->开发设置中获取.
https://mp.weixin.qq.com/wxopen/devprofile?action=get_profile&token=1411655674&lang=zh_CN

上传源代码中的server目录到服务器目录,安装node依赖包

npm install

启动服务器

pm2 start app.js

配置nginx, 部署https证书

安装nginx服务器

yum install nginx -y

将申请的ssl证书上传到/etc/nginx目录中.
打开新建配置/etc/nginx/conf.d/ssl.conf

# WebSocket 配置
map $http_upgrade $connection_upgrade {
    default upgrade;
    \'\' close;
}
server {
        listen 443;
        server_name wuxing.9z9z.vip; # 改为绑定证书的域名
        # ssl 配置
        ssl on;
        ssl_certificate 214355946590.pem; # 改为自己申请得到的 crt 文件的名称或者绝对路径
        ssl_certificate_key 214355946590.key; # 改为自己申请得到的 key 文件的名称或者绝对路径
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
        ssl_prefer_server_ciphers on;
        # WebSocket 配置
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection $connection_upgrade;
        location / {
            proxy_pass http://127.0.0.1:8765;
        }
    }

重新启动nginx

service nginx reload
或者 nginx -s reload

此时直接在浏览器中
https://wuxing.9z9z.vip/hello
会有正常输出的字符串:Response from express
服务器配置成功.

设置小程序的服务器域名

打开小程序后台, 设置 -> 开发设置. 设置服务器域名

打开小程序开发工具

配置appid

打开app.js, 将config.host改为设置的网址."wuxing.9z9z.vip"


完成.


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
最强CP!阿里云联手支付宝小程序如何助力双11?发布时间:2022-07-18
下一篇:
微信小程序页面跳转发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap