1天搭建免费微信小程序商店卖茶(3)连载中
liuian 2025-05-28 18:46 6 浏览
前期准备
前两篇文章,分别架设好了小程序商站的后台服务端(提供小程序的数据接口,存储商品和交易信息等等),编译并且在手机上成功打开了测试版小程序,成功拉取到了服务器上的测试数据。
本篇开始,为“真实”运营进行下一步动作。要运营,肯定不能光看那些测试数据,要发布真实的商品和真实的支付订单以及快递流转,所以需要一个后台管理界面,我们选用的海风小店提供了两种数据管理方式(其实是3种,你是大神的话可以手写sql直接管理数据库),其中一种是部署在本地电脑上,直接在电脑浏览器里打开管理界面(相当于用mysql数据库管理软件的可视化版本),优点是方便和安全(真安全啊,没其它动数据库数据的手段),缺点是只能一台电脑上管理,所以综合大多数人的需求,我们在之前那台作小程序服务端的服务器上部署(也可以是一台全新的服务器,做到管理界面和数据分离,读者可以举一反三,我们现在只讲最简单、通用的)。
代码获取
上文提到,本地管理使用的是hioshop-admin源码,我们需要架设在服务器上通过web访问管理,需要用到hioshop-admin-web(
https://github.com/iamdarcy/hioshop-admin-web)。
因为这个admin-web其实就是纯静态的html页面,基于vue,所以只需要把它部署到任意的web服务器目录下,就可以得到管理界面。
因为这台服务器上,我已经安装了nginx架设官网,所以直接把这个代码编译出来放到网站子目录下即可。
**这里没有用docker容器,是为了快速,因为已经有现成的网站了,这样最快,后面有空会做一个docker镜像包含这个admin-web端的,直接运行就可以提供web服务。
代码生成
通过git clone
https://github.com/iamdarcy/hioshop-admin-web或直接zip下载的源码,可以通过npm工具直接运行dev版本(使用nodejs内置web服务能力启动一个监听9528的端口的http服务器,可以预览效果),测试正常后编译出web静态页面拷贝到生产环境的web服务器目录下。
1.正常获取nodejs和npm环境
参考上文服务器端或网上手册,安装nodejs和npm,最简单的是
apt get install nodejs npm
cd hioshop-admin-web //进入源码目录
npm install //安装依赖文件
没有错误后,运行开发测试:
npm run dev
一切正常的话,会运行测试端口http供你访问(同样,需打开阿里云防火墙访问端口权限)。
需要注意,显示的是阿里云的内网地址,需要用真实的外网地址访问,如果访问时有其它权限错误,也不折腾了,这步是确认代码是正常的,只是看一眼, 实际不这么用,走下一步。
- 真实编译web
先修改配置文件,需要修改src/config/api.js中的rootUrl需要指向之前创建的小程序后台服务端的server接口地址,即之前小程序获取数据的接口地址,带上admin/,例如:http://www.meiwutea.com:8360/admin/。
这个配置文件里还有一个配置参数是七牛云的对象存储接口,这个如果缺失不影响测试,但后面要添加商品时,上传图片会失败,因为这个小程序服务端不在本地存储图片等多媒体数据,而是放到七牛云空间上面(好处是比云主机便宜,50G空间如果用户不多,大概10块钱可以用两年),需要你去七牛云「链接」注册一个账号(需要微信实名认证后开通权限),获取api开发接口参数(回到服务器端部署那一步,修改服务端配置文件hioshop-server/src/common/config/config.js录入正确的七牛云api接口参数,需要注意的是domain/源码作者写的比较模糊容易误导,需要是类似http://xxx.meiwutea.com/这样的格式,要带前面的http://前缀和/后缀不能少),新用户可以有30天的免费测试空间可用。
执行npm run build:prod,成功后,会在当前目录dist目录下生成小程序商站服务端管理代码(即,纯静态网页),拷贝到web服务器目录即可,例如mkdir /var/www/html/admin; cp -R dist/* /var/www/html/admin/。
生成的disk目录下的静态web页面,必须拷贝到web服务器根目录的admin目录下(如果该目录已经被占用,需要修改源码vue.config.js中的publicPath: "/admin",重新编译生成)。
如果需要,还可以修改源码nano
src/components/WelcomePage.vue ,可以去掉管理首页两条源码开发者加上去的测试信息。
部署服务器管理端
上部获取到管理界面web后,就可以部署到web服务器上提供服务器后台数据管理界面了,这里假设本台服务器已经正常运行了web服务器了,以nginx为例。
修改nginx配置文件,增加admin路径:
location /admin {
proxy_set_header X-Forwarded-Proto $scheme;
alias /var/www/html/admin;
}
systemctl restart nginx重启服务器,即可在你的网站的admin路径下(例如:http://www.xxxx.com/admin)打开小程序服务端管理界面了,默认管理账号、密码都是qilelab.com,登录后可以修改管理员用户名和密码。
初始化数据
因为这个源码有点历史了,所以有些数据需要更新和清空,但管理界面为了数据安全,大多不提供删除功能,比如测试的订单和购物车数据,以及大量的商品数据一条条删是比较累的,需要在MySQL WorkBench软件里远程直接修改数据库。
比如各地行政区域,保存在hiolabs_region表中。
可以清空的测试数据有:
hiolabs_cart 购物车
hiolabs_order 订单
hiolabs_order_express 订单关联快递信息
hiolabs_order_goods 订单关联商品信息
界面上也可以删除但可以批量快速删除的有:
hiolabs_goods 商品表
等等。
这些操作完成后,你大概率不再需要直接从开发电脑上连接服务器数据库了,可以在阿里云上删掉3306端口,保护你的数据安全。
小程序测试
再补充一下上一篇小程序忘了提的事,如果小程序开发环境电脑上预览和手机上调试模式下可以正常加载服务器的商品数据,而提交上传给其他人看不了,其实是忘了在小程序管理后台设置服务器域名了。
为了数据安全,正式的小程序,只允许与指定的域名通信,只有在开发阶段,才可以任意指定ip地址或域名进行数据测试,所以开发部署小程序商店,还是需要有一个ICP备案过的域名和网站服务器的,否则,需要使用微信的云开发服务器,每个月付服务费。
小程序微信支付注意事项
至此,如果一切顺利,你可以有一个能正常运行的微信小程序商店了,能够通过服务器管理界面管理商品,在小程序上下单、支付和发货了。
但需要注意小程序新规,电商类微信支付会在小程序管理后台产生对应的订单,本次架设的小程序由于历史原因,没有对接微信官方的发货接口,所以需要在小程序管理后台人工发货,否则支付的钱会被平台冻结大概10天才能解冻,甚至导致支付接口被封。
所以如果小程序每天发货订单数据少,除了在管理界面填快递单号发货,还要记得人工去微信小程序管理后台同样填快递单号发货(不过有excel表格可以批量发货)。
如果你每天的小程序订单多的忙不过来,这款小程序商店可能不适合,需要另外寻找收费的服务商提供服务了。
安全提醒
本次部署教程突出的是快,所以有些安全方面的问题有所疏忽,比如服务端提供给小程序的数据接口采用http明文传输,服务端管理界面也是http接口(所以采用在服务端同一台服务器部署管理界面,只允许本机localhost地址访问,能规避掉一些风险)。
所以实际商用环境下,建议全站https保护起来,采用nginx的代理功能可以很容量做到这一点,但相应的上面代码中的配置的http地址路径也要有所调整。
首先,还是正常架设一个能访问的nginx web服务器,有一个已经ICP备案的域名。通过https://certbot.eff.org/可以通过脚本,全自动为你的网站生成ssl加密证书并启用https,确认你可以直接通过例如https://www.meiwutea.com方式访问你的原网站,我们接下来要把前面文章提到的小程序商站的服务端接口地址从http升级到https。
修改nginx配置文件:
location /myshop/ {
proxy_pass http://localhost:8080/;
//表示把服务端对外提供的小程序以及管理界面的数据接口从8080端口,代理到443端口的myshop路径下,例如原来配置的是
http://www.meiwutea.com:8080,升级后通过
https://www.meiwutea.com/myshop/访问,原来
http://www.meiwutea.com:8080/admin/升级为
https://www.meiwutea.com/myshop/admin。
}
location /static {
proxy_pass http://localhost:8080;
//因为服务端有一些静态web资源是放到根目录的static目录下的,例如
http://www.meiwutea.com:8080/static/css/xxx.css,现在升级为
https://www.meiwutea.com/static/css/xxx.css。
}
修改完重启nginx后,对应要修改小程序config/api.js中的ApiRoot地址为新的https地址,修改配置管理界面的config/api.js中的rootUrl为新的https地址(简单记住,是在小程序的配置地址后面加admin/)。
微信小程序的管理后台的服务器域名也要相应升级成https:
这一通修改后,在配置管理界面新建商品上传图片,以及小程序上实际跑支付流程时,还会发现了一些异常,跟踪后发现是https升级后造成的,需要做如下调整。
首先,服务端
src/common/config/config.js中的微信支付的notify_url,需要升级为正确的https地址,例如上例中就是
https://www.meiwutea.com/myshop/api/pay/notify,可以手工在浏览器按你的域名地址测试,如果显示FAIL字样表示是正确的,如果出现404或者其它错误,则小程序上支付后订单会依然为未支付状态,请重新检查上述修改。
然后原来正常工作的七牛云又上传不了图片了,检查浏览器日志错误发现,是因为https页面调用了七牛http的接口,并且七牛提供的测试域名是仅支持http。
前往七牛云管理后台,启用自定义域名,先创建http方式的自定义域名,然后会提示你可以升级为HTTPS,这样就不需要在创建的时候提供你自己的ssl证书,避免麻烦。
最后,需要修改后台admin-web的src/config/api.js中的qiniu: 'https://up-z0.qiniup.com',启动https接口,服务端配置文件中也需要同时填写正确的七牛云HTTP和HTTPS两个参数。
这样,你就可以有全站HTTPS加密,保护你的小程序和配置管理界面的通信安全了,当然,最后,还是要做好阿里云的服务器快照,避免数据丢失,出现异常时,去小程序管理后台暂停支付接口保护资金安全等等,这是运营完全自己管理的系统要养成的习惯性动作了。
文章预告
下一篇,将把上面文章中的程序猿专属内容和过于技术的语言和步骤去掉,介绍怎么通过下载两个docker镜像文件例如:meiwutea-server.tgz, meiwutea-admin.tgz,只要运行几条命令例如:
docker import meiwutea-server.tgz meiwutea-server
docker import meiwutea-admin.tgz meiwutea-admin
docker run --name server -p 8080:8360 -d meiwutea-server
docker run --name admin -p 80:80 -d meiwutea-admin
就可以获得一个能正常运行的微信小程序服务端和管理端。文章的编写速度,由大家的点赞、评论驱动哈,记得收藏、关注本号,上火的小伙伴记得来杯茶,欢迎淘宝:梅坞寻茶。
相关推荐
- Firefox火狐浏览器126版更新修复PDF.js漏洞
-
IT之家5月28日消息,Mozilla基金会在5月14日推出了Firefox火狐浏览器126版本,官方在更新信息中提到该版本主要修复了浏览器内置的PDF组件(PDF.js...
- 在Web应用中集成 PDF.js: 通过jsdelivr实现动态加载与批注的思考
-
PDF文档在现代Web应用中越来越常见,无论是作为文档预览、报告展示还是在线编辑的载体。Mozilla的PDF.js是一个功能强大的JavaScript库,它使得在浏览器端渲染和显示...
- PDF文件长出“AI大脑”?网友惊呼:这操作太“黑科技”了
-
你以为PDF只是用来阅读文档的?这次它彻底颠覆了你的想象!极客AidenBai最新整活——直接把大语言模型(LLM)塞进PDF里,打开文件就能让AI讲故事、陪你聊天!更夸张的是,连Linux系统都能...
- 5种开源PDF解析方案(JS/Node.js)及实战教程
-
hi,大家好,我是徐小夕.徐小夕【知乎专栏作家】掘金签约作者,定期分享AI创业,可视化,企业实战项目知识,深度复盘企业中经常遇到的500+技术问题解决方案。【关注趣谈前端,技术路上不迷茫】最近一直...
- 好用的JavaScript客户端PDF插件——jsPDF
-
介绍和往常一样,jsPDF是一个开源的客户端的PDF解决方案,在之前的文章中已经介绍过几个Web端和PDF相关的库,jsPDF同样是一个不错的客户端PDF引SDK,你可以通过jsPDF在客户端完成相...
- 为wps增加node.js npm创建wpsjs加载项
-
选择环境:windows764位版版本:wps官方2019个人版:一。wps安装后,可以选择关闭广告:打开WPSOffice,点击左上角“首页”图标,依次点击右上角“设置”--->“配置...
- TypeScript 1.5发布,支持大量ES6新特性
-
TypeScript1.5正式发布,此版本是VisualStudio2015更新的一部分,可以单独下载VisualStudio2013和npm,或直接从GitHub获得最新版本。值得关注的改...
- 1.5k+ 开源的高品质音乐命令行下载工具
-
大家好,我是开源探索者,持续分享开源项目,关注技术的最新动态,分享自己的经验和见解。今天为大家带来一款下载音乐的命令行工具:musicn,基于Node.js开发,可播放和下载高品质的音乐,支持咪...
- 1天搭建免费微信小程序商店卖茶(3)连载中
-
前期准备前两篇文章,分别架设好了小程序商站的后台服务端(提供小程序的数据接口,存储商品和交易信息等等),编译并且在手机上成功打开了测试版小程序,成功拉取到了服务器上的测试数据。本篇开始,为“真实”运营...
- 3200+ Cursor 用户被恶意“劫持”!贪图“便宜 API”却惨遭收割, AI 开发者们要小心了
-
整理|华卫近日,有网络安全研究人员标记出三个恶意的npm(Node.js包管理器)软件包,这些软件包的攻击目标是一款颇受欢迎的由AI驱动的源代码编辑器Cursor,且针对的是苹果mac...
- npm install常见问题
-
npm编译npminstall叮当问题来了PSD:\wp\project\newPorject\tyzhhw-mysql\code\tyzhhw_sheshi>npminstalln...
- 微软TypeScript Native预览版发布,带来10倍以上编译性能提升
-
IT之家5月23日消息,微软首席产品经理丹尼尔罗森瓦瑟(DanielRosenwasser)昨晚发文,宣布TypeScriptNative预览版(最终将演变为TypeScript7...
- 如何在 Windows 11 或 10 上安装 ASK CLI
-
ASKCLI是亚马逊为开发人员提供的一个工具,用于创建Alexa技能并随后部署和管理它们。因此,初学者和经验丰富的开发人员都可以通过使用ASKCLI简化开发Alexa技能的任务。所以...
- 如何将package.json中的每个依赖项更新到最新版本
-
技术背景在前端开发中,项目的package.json文件管理着项目的依赖信息。随着时间推移,依赖项可能会发布新的版本,包含性能优化、功能增强和安全修复等。因此,将依赖项更新到最新版本对于项目的稳定...
- 全网最全的 Windows 系统下 Node.js 安装与配置
-
各位代码江湖的“萌新大侠”们!今天详细介绍windows下node.js的安装与配置,看这篇文章就够了。一、下载安装官网下载:下载|Node.js中文网选择需要下载的版本,这是之前的...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
-
- Firefox火狐浏览器126版更新修复PDF.js漏洞
- 在Web应用中集成 PDF.js: 通过jsdelivr实现动态加载与批注的思考
- PDF文件长出“AI大脑”?网友惊呼:这操作太“黑科技”了
- 5种开源PDF解析方案(JS/Node.js)及实战教程
- 好用的JavaScript客户端PDF插件——jsPDF
- 为wps增加node.js npm创建wpsjs加载项
- TypeScript 1.5发布,支持大量ES6新特性
- 1.5k+ 开源的高品质音乐命令行下载工具
- 1天搭建免费微信小程序商店卖茶(3)连载中
- 3200+ Cursor 用户被恶意“劫持”!贪图“便宜 API”却惨遭收割, AI 开发者们要小心了
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)