全栈开发实战:使用Node.js和React构建完整的应用
一、全栈开发环境配置与架构设计
1.1 技术栈选择与开发环境搭建
在开始全栈开发前,我们需要配置完整的开发环境。建议使用Node.js 18 LTS版本(长期支持版)和React 18的组合,这两个版本截至2023年Q3的npm下载量分别达到4200万/周和1700万/周,具有最佳生态支持。
// 验证Node.js环境
node -v
// 输出应显示v18.x.x
// 创建项目目录结构
├── server/ # Node.js后端
│ ├── models/ # 数据库模型
│ ├── routes/ # API路由
│ └── app.js # 主入口文件
└── client/ # React前端
├── src/
│ ├── api/ # API请求模块
│ └── components/ # React组件
推荐使用Visual Studio Code配合以下扩展:ESLint(代码规范检查)、Prettier(代码格式化)、REST Client(API调试)。后端建议安装nodemon实现热重载:
npm install -g nodemon
// package.json配置
"scripts": {
"dev": "nodemon app.js"
}
1.2 全栈架构设计模式
采用分层架构设计,后端遵循MVC(Model-View-Controller)模式,前端采用Container-Presentational组件模式。数据库选择MongoDB Atlas云服务,其免费层提供512MB存储空间,满足中小型应用需求。
// 典型API响应结构
{
"success": true,
"data": {...},
"error": null
}
二、Node.js后端开发实践
2.1 构建RESTful API核心模块
使用Express.js框架搭建API服务,配置基础中间件:
const express = require('express');
const app = express();
// 关键中间件配置
app.use(express.json()); // 解析JSON请求体
app.use(cors()); // 跨域支持
app.use(helmet()); // 安全防护
// MongoDB连接
mongoose.connect(process.env.MONGODB_URI, {
useNewUrlParser: true,
useUnifiedTopology: true
});
定义用户模型时,需遵循数据验证最佳实践:
const userSchema = new mongoose.Schema({
username: {
type: String,
required: true,
unique: true,
minlength: 3,
maxlength: 30
},
password: {
type: String,
required: true,
select: false // 默认不返回密码字段
}
});
2.2 实现JWT认证与授权
采用JSON Web Token(JWT)实现认证系统,使用bcryptjs进行密码哈希处理:
// 生成密码哈希
const salt = await bcrypt.genSalt(10);
const hash = await bcrypt.hash(password, salt);
// 生成JWT令牌
const token = jwt.sign(
{ userId: user._id },
process.env.JWT_SECRET,
{ expiresIn: '7d' }
);
配置权限中间件保护路由:
const authMiddleware = async (req, res, next) => {
try {
const token = req.header('Authorization').replace('Bearer ', '');
const decoded = jwt.verify(token, process.env.JWT_SECRET);
req.user = await User.findById(decoded.userId);
next();
} catch (error) {
res.status(401).send({ error: '认证失败' });
}
};
三、React前端开发关键技术
3.1 组件化开发与状态管理
使用函数组件和Hooks实现响应式UI,推荐采用zustand进行轻量级状态管理:
// 创建store
import create from 'zustand';
const useStore = create((set) => ({
user: null,
login: (userData) => set({ user: userData }),
logout: () => set({ user: null })
}));
// 组件中使用
function UserProfile() {
const { user } = useStore();
return
{user?.name};
}
3.2 API交互与错误处理
封装axios实例实现统一错误处理:
const api = axios.create({
baseURL: process.env.REACT_APP_API_URL,
timeout: 10000
});
// 请求拦截器
api.interceptors.request.use(config => {
const token = localStorage.getItem('token');
if (token) {
config.headers.Authorization = `Bearer ${token}`;
}
return config;
});
// 响应拦截器
api.interceptors.response.use(
response => response.data,
error => {
if (error.response?.status === 401) {
window.location = '/login';
}
return Promise.reject(error);
}
);
四、应用部署与性能优化
4.1 生产环境部署策略
采用Docker容器化部署方案,配置Nginx反向代理:
# Dockerfile.prod
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production
COPY . .
CMD ["node", "server/app.js"]
使用PM2进行进程管理,配置集群模式提升性能:
pm2 start app.js -i max --name "api-server"
4.2 性能监控与优化指标
配置Lighthouse进行性能审计,建议目标指标:
- 首次内容渲染(FCP)< 1.5s
- 可交互时间(TTI)< 3s
- API响应时间 < 300ms
// 启用gzip压缩
app.use(compression());
// 缓存控制中间件
app.use((req, res, next) => {
res.set('Cache-Control', 'public, max-age=31536000');
next();
});
Node.js, React, 全栈开发, RESTful API, MongoDB, JWT认证, 前端优化, Docker部署