由于提供的代码已经是一个完整的应用程序,以下是一些关键部分的代码示例,展示了如何使用Node.js和MySQL创建一个简单的旅游景点分享网站的后端。
- 数据库模型定义(
models/place.js
):
const { Sequelize, DataTypes } = require('sequelize');
const sequelize = new Sequelize('database', 'username', 'password', {
host: 'localhost',
dialect: 'mysql'
});
const Place = sequelize.define('Place', {
name: DataTypes.STRING,
location: DataTypes.GEOMETRY,
description: DataTypes.TEXT
});
// 同步模型到数据库
sequelize.sync({ force: true }).then(() => {
console.log('Model synchronized successfully.');
});
module.exports = Place;
- 景点控制器(
controllers/placeController.js
):
const { Place } = require('../models');
// 创建景点
const createPlace = (req, res) => {
const placeData = {
name: req.body.name,
location: { type: 'Point', coordinates: [req.body.longitude, req.body.latitude] },
description: req.body.description
};
Place.create(placeData)
.then(place => res.json(place))
.catch(err => res.status(400).json('Error creating place.'));
};
// 获取所有景点
const getAllPlaces = (req, res) => {
Place.findAll()
.then(places => res.json(places))
.catch(err => res.status(500).json('Error fetching places.'));
};
module.exports = {
createPlace,
getAllPlaces
};
- 使用Express框架设置API路由(
routes/index.js
):
const express = require('express');
const placeController = require('../controllers/placeController');
const router = express.Router();
// 添加景点
router.post('/places', placeController.createPlace);
// 获取所有景点
router.get('/places', placeController.getAllPlaces);
module.exports = router;
- 初始化Express服务器并使用上述定义的路由(
app.js
):
const express = require('express');
const sequelize = require('./models/index');
const routes = require('./routes');
const app = express();
// 中间件
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
// 路由中间件
app.use('/api', routes);
// 启动服务器
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
});
// 同步数据库
sequelize.sync();
这些代码片段展示了如何使用Node.js和MySQL创建一个简单的API来管理旅游景点数据。它们涵盖了创建模型、定义控制器、设置路由和启动服务器的关键步骤。实际的应用程序还需要处理如身份验证、访问控制、错误处理等方面,但这已经超出了问题描述的范围。