关于web前端通过js获取后端mysql数据库数据的一个方法

关于web前端通过js获取后端mysql数据库数据的一个方法

问题引入

关于html的教程很多,关于mysql的教程也很多,那么怎么让html展示mysql的数据呢?

一言以蔽之

前端通过js向后端发起一个http请求,后端响应这个请求并返回数据

实现

js代码

复制代码
   // 使用 fetch 发起 GET 请求
    fetch('http://127.0.0.1:3000/api/login', {
        method: 'POST',
        headers: {
            'Content-type': 'application/json'
        },
        body: JSON.stringify(data) //data是传递给后端的数据
    })
    .then(response => {
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        return response.json();
    })
    .then(data => {
        // 处理从服务器获取到的数据
        console.log(data);
        if(data.status == false){
            Error.innerHTML = "username not exists or password wrong";
        }
        else{
            alert("success!");
        }
    })
    .catch(error => {
        // 处理请求错误
        console.error('Error:', error);
    });

后端nodejs代码

复制代码
//登陆
app.post('/api/login', (req, res) => {
    const data = req.body;
    //这个pool是创建的mysql连接池,这里没展出来,不懂可以百度如何创建
    pool.query('select * from users where username = ?',[data.username], (error,results) => {
        if (error) {
            console.error('Error querying database:', error);
            res.status(500).send('Internal Server Error');
            return;
        }
        console.log(results);
        if(results.length == 0){
            res.json({status: false});
        }
        else{
            if(results[0].password != data.password){
                res.json({status: false});
            }
            else{
                res.json({status: true,id:results[0].id});
            }
        }
    })
});

逻辑解释

前端js使用fetch方法向后端发送一个http请求,请求里面可以携带一些数据,然后后端nodejs通过前端发来的http信息来访问服务端数据库响应请求,并返回数据给前端。

什么是nodejs?

你可以把它理解成一个运行在服务器端的脚本,负责响应请求,就像饭店的厨师,而js就像前台负责给顾客点菜的人

nodejs怎么运行?

这个网上教程很多,得现在服务器端安装一下node,npm啥的(好像是一起的)

说明

向后端发送请求的方法不止这一个,但是这个还算比较简洁

有什么问题可以直接私信我

相关推荐
864记忆2 分钟前
Qt创建连接注意事项
数据库·qt·nginx
华仔啊16 分钟前
JavaScript 如何准确判断数据类型?5 种方法深度对比
前端·javascript
花哥码天下17 分钟前
apifox登录后设置token到环境变量
java·后端
小小bugbug26 分钟前
mysql查询的原始返回顺序与limit分页优化
mysql·adb
毕设十刻35 分钟前
基于Vue的迅读网上书城22f4d(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
程序员小寒35 分钟前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
开发语言·前端·javascript·面试
薛定谔的猫19821 小时前
Langchain(十二)LangGraph 实战入门:用流程图思维构建 LLM 工作流
数据库·microsoft
爱健身的小刘同学1 小时前
Vue 3 + Leaflet 地图可视化
前端·javascript·vue.js
hashiqimiya1 小时前
springboot事务触发滚动与不滚蛋
java·spring boot·后端
神秘的猪头1 小时前
Ajax 数据请求:从零开始掌握异步通信
前端·javascript