当前位置: 首页 > news >正文

微信小程序与本地MySQL数据库通信

微信小程序与本地MySQL数据库通信

因为本地MySQL服务器没有域名,也没有进行相应的请求操作封装,因此微信小程序没办法和数据库通信。

但是对于开发人员来说,没有数据库,那还能干撒?虽然我尝试过用json-server,但是其功能效果令我深深折服,立刻扔进垃圾桶了。

所以逼迫我使用Node.js搭建HTTPS服务器,间接实现和MySQL服务器的通信。

一、搭建HTTP服务器

1.1 首先安装好Node.js
https://nodejs.org/en

打开上面网址你就可以看到下载按钮了,下载exe安装包后直接安装即可。

1.2 创建服务器的专属文件夹

在磁盘的任何位置随便创建一个吧(建议不要在C盘),比如我创建的文件夹路径:

D:\Software\LocalHTTPMysql
1.3 安装依赖项

打开控制台,进入上面创建的文件夹目录,然后依次运行以下命令:

  • 初始化服务器
npm init -y
  • 安装Express框架,用于快速创建HTTP服务器
npm install express --save
  • 安装nodemon监控文件修改
npm install nodemon -g
  • 安装mysql的软件包
npm install mysql --save

上述这些依赖的安装速度可能并不快,因此需要读者有足够的耐心等待。

1.4 创建服务器

在刚才的目录下创建一个后缀为.js的文件,用来存放服务器代码,代码内容如下:

const express = require('express');
const bodyParser = require('body-parser');
const app = express();
const mysql = require('mysql');app.use(bodyParser.json()); // 解析JSON请求体// 创建数据库连接池
const pool  = mysql.createPool({host: 'localhost',user: 'root',password: 'Wrmmxf2wmzmfx1',database: 'mysql'
});// 处理GET请求的根路径,查询数据库并返回结果,显然为了请求的通用性,则我的查询语句由小程序端完整生成,服务端只负责查询语句的中转
app.get('/', (req, res) => {pool.query(req.query.query, (error, results, fields) => {if (error) {console.error(error);return res.status(500).send('Internal Server Error');}res.json(results); // 返回查询结果});
});// 处理POST请求,用于数据写入
app.post('/', (req, res) => {const { table, columns, values } = req.body; // 从请求体获取数据// 构建SQL插入语句const placeholders = columns.map(() => '?'); // 原数组映射为新数组,新数组的每个元素均为问号,使用问号作为占位符const sql = `INSERT INTO \`${table}\` (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;// 执行SQL插入语句pool.query(sql, values, (error, results, fields) => {// 返回插入错误的信息if (error) {console.error(error);return res.status(500).send('Database error');}//   返回提示信息res.status(201).json({ message: 'Data inserted successfully', insertId: results.insertId });});});// 启动服务器监听3000端口,并打印启动信息
app.listen(3000, () => {console.log('Server running at http://127.0.0.1:3000');
});

对于数据库的查询,由于查询语句复杂多样,灵活多变如果放在服务端进行处理,我个人觉得不太方便。

因此,查询语句我放在了微信小程序的后端生成,然后发起HTTP请求时,直接传到中转服务器,中转服务器直接传给MySQL服务器,最后中转服务器将数据库返回的结果直接返回到微信小程序后端即可。

对于数据库的写入,语句则比较单一,可以在服务器端完成。

发起写入请求时,我们将必要的参数(表名、插入字段,字段数据)传递给中转服务器即可,服务器能够自动完成相关语句的拼接。

1.5 启动服务器

在刚才的目录下执行以下命令完成启动:

node XXX.js

前面是命令,后面是服务器文件名,像这样:

D:\Software\LocalHTTPMysql>node server.js
Server running at http://127.0.0.1:3000

http://127.0.0.1:3000将作为请求的域名

二、微信后端发起通信请求

2.1 数据库查询
wx.request({url: 'http://127.0.0.1:3000/',method: "get",data: {query: "Your Selection Statement"},success: function (res) {console.log(res.data)}});

上面是完成查询操作的代码,query是查询语句,读者自行根据前端功能完成语句的生成。

res.data是数据库返回的数据

2.2 数据库写入
wx.request({url: 'http://127.0.0.1:3000/', method: "post",data: {table: "insert_test",columns: ["name", "age"],values: ["李华", 21]},success: function (res) {console.log(res.data)}});

此时请求体不太一样,我们给出了要插入的表名,字段名和数据。读者也应该如此完成数据的组织。

三、错误处理

3.1 域名不合法错误

我们的小程序在此阶段并不打算公开,因此不需要域名校验,直接给关掉即可:

在这里插入图片描述

3.2 数据库连接不上错误

有时可能出现如下报错:

Error: ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol

此时,请你先用以下命令登录数据库:

mysql -u 用户名 -p;

接着输入密码完成登录。

然后,使用以下命令切换到你要使用的表名:

use xxx;

xxx是表名

最后一步,运行如下命令打开权限,你只需更改用户名用户名的密码那两个参数即可。

alter user '用户名'@'localhost' identified with mysql_native_password by '用户的密码';

接着输入密码完成登录。

然后,使用以下命令切换到你要使用的表名:

use xxx;

xxx是表名

最后一步,运行如下命令打开权限,你只需更改用户名用户名的密码那两个参数即可。

alter user '用户名'@'localhost' identified with mysql_native_password by '用户的密码';

相关文章:

  • 2024.7.17 ABAP面试题目总结
  • Hadoop-34 HBase 安装部署 单节点配置 hbase-env hbase-site 超详细图文 附带配置文件
  • .NET Framework、.NET Core 、 .NET 5、.NET 6和.NET 7 和.NET8 简介及区别
  • 3D问界—MAYA制作铁丝栅栏(透明贴图法)
  • 用Python轻松批量生成Word合同:解放双手,喝口咖啡就搞定!☕
  • 【Karapathy大神build-nanogpt】Take Away Notes
  • Android 12系统源码_存储(二)StorageManager类介绍
  • MySQL数据库慢查询日志、SQL分析、数据库诊断
  • 1.厦门面试
  • 学习Python的IDE功能--(一)入门导览
  • uniapp小程序上传pdf文件
  • 好玩的调度技术-场景编辑器
  • Linux内核编译安装 - Deepin,Debian系
  • llama-index,uncharted and llama2:7b run locally to generate Index
  • C语言从头学35——struct结构
  • php的引用
  • JavaScript-如何实现克隆(clone)函数
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • isset在php5.6-和php7.0+的一些差异
  • Linux gpio口使用方法
  • mysql常用命令汇总
  • Nacos系列:Nacos的Java SDK使用
  • PHP那些事儿
  • python学习笔记 - ThreadLocal
  • 分享自己折腾多时的一套 vue 组件 --we-vue
  • 海量大数据大屏分析展示一步到位:DataWorks数据服务+MaxCompute Lightning对接DataV最佳实践...
  • 简单基于spring的redis配置(单机和集群模式)
  • 力扣(LeetCode)21
  • 数据科学 第 3 章 11 字符串处理
  • 王永庆:技术创新改变教育未来
  • [Shell 脚本] 备份网站文件至OSS服务(纯shell脚本无sdk) ...
  • gunicorn工作原理
  • ​力扣解法汇总946-验证栈序列
  • ‌前端列表展示1000条大量数据时,后端通常需要进行一定的处理。‌
  • #define 用法
  • (14)Hive调优——合并小文件
  • (附程序)AD采集中的10种经典软件滤波程序优缺点分析
  • (附源码)c#+winform实现远程开机(广域网可用)
  • (南京观海微电子)——示波器使用介绍
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • (原创) cocos2dx使用Curl连接网络(客户端)
  • (转)Linux下编译安装log4cxx
  • (转)MVC3 类型“System.Web.Mvc.ModelClientValidationRule”同时存在
  • (状压dp)uva 10817 Headmaster's Headache
  • (自用)网络编程
  • . ./ bash dash source 这五种执行shell脚本方式 区别
  • .NET Core 项目指定SDK版本
  • .NET开源项目介绍及资源推荐:数据持久层
  • .sh 的运行
  • /bin/bash^M: bad interpreter: No such file ordirectory
  • @ 代码随想录算法训练营第8周(C语言)|Day57(动态规划)
  • [ SNOI 2013 ] Quare
  • [ vulhub漏洞复现篇 ] Apache Flink目录遍历(CVE-2020-17519)
  • [2016.7 day.5] T2
  • [2021ICPC济南 L] Strange Series (Bell 数 多项式exp)