由于提供完整的二手商城系统源代码和文档需要很大的篇幅,以下是一个简化的Node.js二手商城系统的核心功能示例,包括用户注册、登录、商品列表展示和购买流程。
// 引入必要的模块
const express = require('express');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
// 创建Express应用
const app = express();
// 连接MongoDB数据库
mongoose.connect('mongodb://localhost:27017/secondhandshop', { useNewUrlParser: true });
// 使用body-parser中间件来解析JSON和urlencoded数据
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
// 创建用户模型
const User = mongoose.model('User', new mongoose.Schema({
name: String,
email: String,
password: String
}));
// 创建商品模型
const Product = mongoose.model('Product', new mongoose.Schema({
title: String,
description: String,
price: Number,
seller: { type: mongoose.Types.ObjectId, ref: 'User' }
}));
// 用户注册接口
app.post('/register', async (req, res) => {
const user = new User(req.body);
await user.save();
res.send('User registered successfully');
});
// 用户登录接口
app.post('/login', async (req, res) => {
const user = await User.findOne({ email: req.body.email });
if (user && user.comparePassword(req.body.password)) {
res.send('Login successful');
} else {
res.status(401).send('Login failed');
}
});
// 获取商品列表接口
app.get('/products', async (req, res) => {
const products = await Product.find();
res.json(products);
});
// 购买商品接口(简化示例,未包含支付逻辑)
app.post('/purchase', async (req, res) => {
const product = await Product.findById(req.body.productId);
// 假设用户已经验证并且存在于req.user中
const seller = await User.findById(product.seller);
seller.balance += product.price;
seller.save();
res.send('Purchase completed');
});
// 监听3000端口
app.listen(3000, () => {
console.log('Server running on port 3000');
});
这个示例展示了如何使用Node.js和Mongoose来创建一个简单的二手商城系统的后端。它包括用户注册、登录、商品列表展示和购买流程的核心功能。注意,示例中的购买接口仅用于展示流程,并未包含真实的支付逻辑。在实际应用中,你需要集成支付网关和其他安全措施。