【Node.js实战】一文带你开发博客项目之联调(导入HTML、Nginx反向代理、CORS解决跨域、与前端联调)

简介: 【Node.js实战】一文带你开发博客项目之联调(导入HTML、Nginx反向代理、CORS解决跨域、与前端联调)

项目演示

这是一个前后端分离的 myblog 博客项目,具体内容请观看如下视频~~

https://www.bilibili.com/video/BV1TW4y1V7Jz?t=32.0

博客项目

一、前言

前面我们基本实现了登录的功能,并且各个接口也已基本配置完毕。

下面我们来进行对博客项目的联调工作,导入相应的 HTML,进行 Nginx 配置解决跨域 以及使用 CORS 解决跨域等操作。

二、解决跨域

1、前端页面就绪

对于页面有需求的可以通过文章最下面的方式自行获取~~

首先我们新建一个文件夹(名为 html-test),里面存放我们的页面(.html 文件),文件内容如下:

bb7a79b16c0a4e4394bd9cda1af8544a.png

页面呈现内容对应如下:

bbf744bb8a704f98935b2c7f141e29bb.png

08d20fddc14f416ca3a3405c54c57bd7.png

09a9883560e045ff9a773e4289477504.png

1164e7997e764d8c89d13fa767b40ae6.png

b1845cc75c3a4cad9ec080d33641f724.png

4948ea1a73854fd882aaf38ed15e4e38.png

bf04943f06f8459c977223527faf7426.png

2、开启新端口

接下来,我们来开启一个新端口(前端端口)

首先在 html-test 文件目录下安装 http-server:

npm install http-server

安装成功之后,创建我们的新端口为 8001(注:8000 为后端端口,8001 为前端端口)

http-server -p 8001

但此时,前后端并不能互通,因为 8000 端口 和 8001 端口是有跨域的(8001 端口无法访问 8000 端口的 list 内容)…

6ab78b58e9694afb910af8fd7ad2e107.png

3、nginx 简介

nginx 简介:

  • 高性能的 web 服务器,开源免费
  • 一般用于做静态服务、负载均衡
  • 反向代理
  • 948b35cef7074f5a9ccc625fb189fc93.png

4、安装使用 Nginx

Nginx 下载地址

大家可以下载这个比较稳定的版本

13d5a7caf22e4c70a1d21cf36675a3ef.png

下载完成之后,我们打开这个 nginx.exe 文件(注意:会闪一下命令框,之后就消失了,但进程中已经开启了)

4b74ac9e7b07459d8c4f04a79f6d91d2.png

5、nginx 命令

简单介绍一下 nginx 的几个常用命令


测试配置文件格式是否正确 nginx -t

启动 start nginx

重启 nginx -s reload

停止 nginx -s stop

我们打开命令行(win+r,之后cmd回车),输入 nginx -t 测试配置文件格式(successful => 很顺利~)

be3a189eb3354423bce170b336f261a1.png

6、nginx 配置

我们使用编译器打开 conf 文件夹下的 nginx.conf

676a444aac734702b9a42b46fc5bde9a.png

aa47718b21d745af9828daaa70b05e28.png

修改如下配置:

# server 的 listen 改为 8080
    server {
        listen       8080;
        server_name  localhost;
# 注释掉这几行内容
#        location / {
#            root   html;
#            index  index.html index.htm;
#        }
# 新增的内容(proxy_pass:代理,proxy_set_header Host $host; 配置负载均衡)
    location / {
      proxy_pass http://localhost:8001;
    }
    location /api/ {
      proxy_pass http://localhost:8000;
      proxy_set_header Host $host;
    }

之后我们保存,并在命令行输入 nginx -t 查看是否成功(successful => 很顺利~)

nginx -t

7f88650467b14e6cb49ccf00dfabbbeb.png

此时,我们打开 8080 端口网页

首页

815efe0465da42c38f2d86d633fd8f40.png

详情页

b1f61982563d4e0792d881b27add04cf.png

作者页

4f11173353fe4596b49979441ea4e873.png

三、与前端联调

为什么要进行联调?

  • 登录功能依赖 cookie,必须用浏览器来联调
  • cookie 跨域不共享,前端和 server 端必须同域
  • 需要用到 nignx 做代理,让后端端同域

接下来,修改一下 .router/blog.js 文件的内容

blog.js

我们设置一下管理员的判断,进行强制查询。之后把获取博客、新建博客、更新博客的返回值修改一下

// 获取博客列表 GET 请求
if (method === 'GET' && req.path === '/api/blog/list') {
    // 博客的作者,req.query 用在 GET 请求中
    let author = req.query.author || ''
    // 博客的关键字
    const keyword = req.query.keyword || ''
    if (req.query.isadmin) {
        // 管理员界面
        const loginCheckResult = loginCheck(req)
        if (loginCheckResult) {
            // 未登录
            return loginCheckResult
        }
        // 强制查询自己的博客
        author = req.session.username
    }
    // 查询的结果
    const result = getList(author, keyword)
    return result.then(listData => {
        return new SuccessModel(listData)
    })
}
......
// 修改获取博客详情、新建博客、更新博客里面的内容如下
if (loginCheckResult) {
    return loginCheckResult
}

联调结果如下:

https://www.bilibili.com/video/BV16d4y1j7uE?t=1.1

myblog


四、CORS 解决跨域

除了使用 nginx 反向代理解决跨域,其实我们还可以使用 CORS 来解决跨越的问题


CORS 解决跨域简介


HTTP 协议的规范,现代浏览器都支持

前端和服务端直接通讯,不用 nginx 做转发

通过服务端设置 header 来实现

设置响应头(允许传入 cookie、允许网页来源、允许的请求类型)


Access-Control-Allow-Credentials

Access-Control-Allow-Origin

Access-Control-Allow-Methods

创建 cros-http-test 文件夹,终端键入 npm init,初始化文件

npm init

具体文件目录如下:

cb057d027f464485ad7544fcfcdd26af.png

app.js

在这里我们设置对应响应头,用来解决跨域

const http = require('http')
const server = http.createServer((req, res) => {
    console.log('req url method: ', req.url, req.method)
    // 允许跨域传递参数
    res.setHeader('Access-Control-Allow-Credentials', true)
    // 允许跨域的 origin,* 代表所有的(需谨慎使用)
    res.setHeader('Access-Control-Allow-Origin', '*')
    // 允许的 method (请求类型)
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE')
    res.writeHead(200, {'Content-Type': 'application/json'})
    res.end(
        JSON.stringify({ errno: 0, msg: 'CORS nodejs' })
    )
})
server.listen(8000)
console.log('OK')

在终端运行 app.js

90a8be7deb5241d8b24a550d4cd13b9e.png

e0116a9a9a1e4ef8a5ffc8c680e34880.png

若不设置这三个响应头,则会出现跨域的报错(如果看到类似如下错误,则表示出现跨域辽…)

933f00ba8fca4ba8839bf151f5178e65.png

五、写在最后

至此,我们完成了HTML页面的导入,使用 nginx 解决了跨域的问题,并成功完成了与前端联调的工作。继续跟进学习吧!


后续会对该项目进行多次重构【多种框架(express,koa)和数据库(mysql,sequelize,mongodb)】


如果你需要该项目的 源码,请通过本篇文章最下面的方式 加入 进来~~

45fc82a82c6542bdb2ff4986377d8db3.png

相关文章
|
7月前
|
JavaScript 前端开发 API
|
8月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
461 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
7月前
|
前端开发 JavaScript 数据可视化
58K star!这个让网页动起来的JS库,前端工程师直呼真香!
Anime.js 是一款轻量级但功能强大的JavaScript动画引擎,它能够以最简单的方式为网页元素添加令人惊艳的动效。这个项目在GitHub上已经获得58,000+星标,被广泛应用于电商页面、数据可视化、游戏开发等场景。
286 8
|
8月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
7440 23
|
7月前
|
JavaScript 安全 前端开发
关于Node.js,一定要学这个10+万Star项目 !!
一篇关于Node.js的宝藏项目——Node.js Best Practices。该项目在GitHub上已有102k Star,汇集了100+条最佳实践,涵盖架构、安全、性能等多方面。每条实践不仅有简明说明和详细解释,还附带代码示例及资源链接。文中通过三个实战案例(利用CPU多核、避免阻塞事件循环、使用中间件处理错误)展示了其实际应用价值,并推荐了几条对前端转Node.js开发者特别有用的最佳实践。强烈建议每位Node.js开发者学习此项目,理解“怎么做”与“为什么要这么做”,以提升开发能力。
268 3
|
9月前
|
移动开发 前端开发 JavaScript
HTML5实现好看的博客网站模板源码
HTML5实现的精美博客网站模板,适用于个人博客、简历等多种场景。代码简洁规范,页面干净整洁,内置首页、列表、文章等通用模板,支持多种风格切换,兼容性强,易于扩展和修改,附带完整注释,适合初学者上手。提供源码下载及在线预览,方便直接使用或二次开发。
395 1
HTML5实现好看的博客网站模板源码
|
9月前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
472 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
9月前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
498 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
8月前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
4月前
|
JavaScript Unix Linux
nvm与node.js的安装指南
通过以上步骤,你可以在各种操作系统上成功安装NVM和Node.js,从而在不同的项目中灵活切换Node.js版本。这种灵活性对于管理不同项目的环境依赖而言是非常重要的。
1076 11

热门文章

最新文章

下一篇
oss云网关配置