Node.js + Express + Springboot实现前后端分离架构

本文介绍了如何使用Node.js和Express搭建前端服务器,通过http-proxy-middleware处理跨域问题,实现与SpringBoot后端的分离部署。详细步骤包括创建Node.js应用、部署前端代码和后端应用。
摘要由CSDN通过智能技术生成

架构说明

前后端分离架构,很多团队都是通过”代理转发”浏览器发往后端的rest请求来解决跨域问题,可以用nginx或者node.js模块http-proxy-middleware实现代理。以下是部署架构,在此架构中你把node换成nginx依然成立。

 

Nodejs前端服务器的职责:

  1. 作为静态文件服务器,当用户访问网站的时候,将index.html以及其引入的js、css、fonts以及图片返回给用户
  2. 负责将客户端发来的ajax请求转发给后台服务器

用nginx部署前后端分离较为简单,所在这里介绍用nodejs作为前后端分离中间层的部署demo。

首先,需要安装 MongoDB 数据库和 Node.js 运行环境。 然后,创建一个新的文件夹,命名为 myapp,进入该文件夹,打开终端窗口,输入以下命令,初始化项目: ``` npm init ``` 按照提示输入项目信息,初始化完成后,输入以下命令安装 Express 和 Mongoose 模块: ``` npm install express mongoose --save ``` 接下来,创建一个名为 server.js 的文件,输入以下代码: ```javascript const express = require('express'); const mongoose = require('mongoose'); const bodyParser = require('body-parser'); const app = express(); // 配置 bodyParser 解析 POST 请求的数据 app.use(bodyParser.urlencoded({ extended: true })); app.use(bodyParser.json()); // 连接 MongoDB 数据库 mongoose.connect('mongodb://localhost/myapp', { useNewUrlParser: true, useUnifiedTopology: true }) .then(() => console.log('MongoDB Connected...')) .catch(err => console.log(err)); // 定义用户模型 const UserSchema = new mongoose.Schema({ email: String, password: String }); const User = mongoose.model('User', UserSchema); // 注册接口 app.post('/signup', (req, res) => { const { email, password } = req.body; // 检查是否已存在该用户 User.findOne({ email }) .then(user => { if (user) { return res.status(400).json({ msg: '该用户已存在' }); } // 创建新用户 const newUser = new User({ email, password }); newUser.save() .then(user => res.json(user)) .catch(err => console.log(err)); }); }); // 登录接口 app.post('/login', (req, res) => { const { email, password } = req.body; // 检查用户是否存在 User.findOne({ email }) .then(user => { if (!user) { return res.status(404).json({ msg: '该用户不存在' }); } // 验证密码是否正确 if (user.password !== password) { return res.status(400).json({ msg: '密码错误' }); } // 登录成功 res.json({ msg: '登录成功' }); }); }); const port = process.env.PORT || 5000; app.listen(port, () => console.log(`Server started on port ${port}`)); ``` 以上代码实现了一个简单的注册和登录接口,使用了 Express、Mongoose 和 BodyParser 模块。 最后,输入以下命令启动服务器: ``` node server.js ``` 访问 http://localhost:5000 就可以测试接口了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值