Node.js和MySQL编写接口并进行请求

Node.js和MySQL编写接口并进行请求

一、安装Node.js:首先,确保你的计算机上已经安装了Node.js。你可以从Node.js官方网站(https://nodejs.org)下载并安装适合你操作系统的版本。

二、新建 server 文件夹作为项目根目录,并在项目根目录中运行如下的命令,初始化包管理配置文件:

npm init -y

三、安装必要的依赖

express

Express是一个简洁、灵活且易于使用的Web应用程序框架,非常适合构建各种规模的Web应用程序和API。(**注意:**在新版本的Express中,某些功能已经被弃用或更改。因此,建议查阅官方文档(https://expressjs.com/)以获取最新的使用方法和API参考。)

  1. 安装Express:在项目目录中运行以下命令,安装Express模块:

    npm install express

  2. 引入Express模块:在你的Node.js代码中,引入Express模块:

    const express = require('express');

  3. 创建Express应用程序:使用express()函数创建一个Express应用程序实例。以下是一个示例:

    const app = express();

  4. 定义路由和处理函数:使用app.get()、app.post()等方法定义路由,并为每个路由指定相应的处理函数。以下是一个示例:

javascript 复制代码
app.get('/', (req, res) => {
  res.send('Hello, World!');
});

这个示例中的路由是根路径(/),当客户端发起GET请求时,将返回Hello, World!作为响应。

  1. 启动服务器:使用app.listen()方法来启动服务器并监听指定的端口。以下是一个示例:

    app.listen(3000, () => {
    console.log('服务器已启动,监听端口3000');
    });

cors(https://www.npmjs.com/package/cors)

CORS(跨来源资源共享)是一种解决跨域访问的机制,允许在一个域中的Web应用程序向另一个域的服务器发送AJAX请求。

  1. 安装cors:在项目目录中运行以下命令,安装cors模块:

    npm install cors

  2. 引入cors模块:在你的Node.js代码中,引入cors模块:

javascript 复制代码
const cors = require('cors');
  1. 配置CORS中间件:在Express应用程序中,使用app.use()方法来配置cors中间件,以允许或限制特定来源的跨域访问。以下是一个示例:
javascript 复制代码
app.use(cors());
这里使用了默认的cors配置,将允许所有来源的跨域请求。你也可以根据需要进行自定义配置,例如指定允许的来源、允许的HTTP方法等。
  1. 使用CORS:在路由处理函数中,你可以通过res.header()方法来设置CORS相关的响应头。以下是一个示例:
javascript 复制代码
app.get('/data', (req, res) => {
  res.header('Access-Control-Allow-Origin', 'http://example.com');
  res.header('Access-Control-Allow-Methods', 'GET, POST');
  res.header('Access-Control-Allow-Headers', 'Content-Type');

  // 执行操作,例如返回数据给客户端

  res.json({
    message: '数据获取成功',
    data: {
      // 数据内容
    }
  });
});
body-parser(https://www.npmjs.com/package/body-parser)

body-parser是一个Node.js中间件,用于解析HTTP请求的请求体,以便从POST、PUT和PATCH等请求中获取请求参数。它将请求体解析为JavaScript对象,以便在处理程序中使用。

  1. 安装body-parser:在项目目录中运行以下命令,安装body-parser模块:

    npm install body-parser

  2. 引入body-parser模块:在你的Node.js代码中,引入body-parser模块:

javascript 复制代码
const bodyParser = require('body-parser');
  1. 配置body-parser中间件:在Express应用程序中,使用app.use()方法来配置body-parser中间件,以便在每个请求中都能够访问请求体的内容。以下是一个示例:
javascript 复制代码
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());

这里使用了两个body-parser的中间件:urlencoded和json。urlencoded用于解析application/x-www-form-urlencoded格式的请求体,而json用于解析application/json格式的请求体。

  1. 使用解析后的请求体:在路由处理函数中,你可以通过req.body来访问解析后的请求体数据。以下是一个示例:
javascript 复制代码
app.post('/users', (req, res) => {
  const { name, email } = req.body;

  // 执行操作,例如将用户数据保存到数据库

  res.json({
    message: '用户创建成功',
    user: {
      name,
      email
    }
  });
});
mysql
  1. 安装MySQL:首先,确保你的计算机上已经安装了MySQL数据库。你可以从MySQL官方网站(https://dev.mysql.com/downloads/installer/)下载并安装适合你操作系统的版本。也可以使用vscode依赖mysql

  2. 安装依赖

    npm install mysql

  3. 创建数据库连接:在你的Node.js代码中,创建一个MySQL数据库连接,并配置连接参数。以下是一个简单的示例:

    const mysql = require('mysql');

    const connection = mysql.createConnection({
    host: 'localhost',
    user: 'your_username',
    password: 'your_password',
    database: 'your_database'
    });

    connection.connect((err) => {
    if (err) {
    console.error('数据库连接失败:', err);
    } else {
    console.log('数据库连接成功');
    }
    });

  4. 创建API路由和处理函数:在你的Node.js代码中,创建Express应用程序,并定义API路由和相应的处理函数。以下是一个简单的示例:

    const express = require('express');
    const app = express();

    // 获取所有用户
    app.get('/users', (req, res) => {
    const query = 'SELECT * FROM users';

    connection.query(query, (err, results) => {
    if (err) {
    console.error('查询失败:', err);
    res.status(500).json({
    error: '服务器内部错误'
    });
    } else {
    res.json(results);
    }
    });
    });

    // 启动服务器
    app.listen(3000, () => {
    console.log('API服务器已启动,监听端口3000');
    });

  5. 启动服务器并测试接口:在项目目录中运行以下命令,启动你的API服务器:

    node index.js

  6. 使用API请求工具(例如Postman)或浏览器,访问http://localhost:3000/users,你应该能够看到返回的用户数据。

四、具体代码

js 复制代码
const express = require('express')
const cors = require('cors')
const bodyParser = require('body-parser')

const app = express()
app.use(cors()) // 使用cors中间件


// 解析请求体,使我们能够访问POST请求的数据
app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json())

// 创建数据库链接
const connection = mysql.createConnection({
  host: '127.0.0.1',
  user: '用户名',
  password: '密码',
  database: '数据库名'
})
connection.connect()
function initDate () {
  var dt = new Date()
  var y = dt.getFullYear()
  var mt = dt.getMonth() + 1
  var day = dt.getDate()
  var h = dt.getHours() //获取时
  var m = dt.getMinutes() //获取分
  var s = dt.getSeconds() //获取秒
  if (mt < 10) {
    mt = '0' + mt
  }
  if (day < 10) {
    day = '0' + day
  }
  if (h < 10) {
    h = '0' + h
  }
  if (m < 10) {
    m = '0' + m
  }
  if (s < 10) {
    s = '0' + s
  }
  return y + '-' + mt + '-' + day + ' ' + h + ':' + m + ':' + s
}
app.post('/submit', (req, res) => {
  const data = req.body
  const user_name = data.name
  const email = data.email
  const message = data.message
  const create_time = initDate()
  console.log(create_time, 'create_time')
  connection.query(
    `insert into message_log (create_time, user_name, email,remark) values ('${create_time}','${user_name}','${email}','${message}');`,
    function (err, rows, fields) {
        console.log(err, rows, fields)
      if (err == null) {
        res.json({
          status: 200
        })
      } else {
        res.json({
          status: 500,
          err, rows, fields
        })
      }
    }
  )
})

// 启动服务器
app.listen(3000, () => {
  console.log('服务器已启动,监听端口3000')
})
相关推荐
GIS小小研究僧26 分钟前
PostGIS笔记:PostgreSQL 数据库与用户 基础操作
数据库·笔记·postgresql
翻滚吧键盘1 小时前
记录一个连不上docker中的mysql的问题
mysql·docker·容器
许苑向上1 小时前
MVCC底层原理实现
java·数据库·mvcc原理
boonya5 小时前
Yearning开源MySQL SQL审核平台
数据库·mysql·开源
YIYONIKY6 小时前
Node.js下载安装及环境配置
node.js
CPU NULL7 小时前
新版IDEA创建数据库表
java·数据库·spring boot·sql·学习·mysql·intellij-idea
J不A秃V头A7 小时前
MySQL 中开启二进制日志(Binlog)
数据库·mysql
V+zmm1013410 小时前
食堂订餐小程序ssm+论文源码调试讲解
java·数据库·微信小程序·小程序·毕业设计
lingllllove10 小时前
解决MySQL删除/var/lib/mysql下的所有文件后无法启动的问题
数据库·mysql·adb
Zda天天爱打卡11 小时前
【趣学SQL】第四章:高级 SQL 功能 4.1 触发器与存储过程——数据库的“自动机器人“和“万能工具箱“
数据库·sql·oracle