位置: IT常识 - 正文

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

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

推荐整理分享【Node.js实战】一文带你开发博客项目之联调(导入HTML、Nginx反向代理、CORS解决跨域、与前端联调)(node.js教程详细),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node.js详解,node.js教程详细,node.js基础入门,node.js gui,node js教程,node-js,node js教程,node js教程,内容如对您有帮助,希望把文章链接给更多的朋友!

个人简介

👀个人主页: 前端杂货铺 🙋‍♂️学习方向: 主攻前端方向,也会涉及到服务端 📃个人状态: 在校大学生一枚,已拿多个前端 offer(秋招) 🚀未来打算: 为中国的工业软件事业效力n年 🥇推荐学习:🍍前端面试宝典 🍉Vue2 🍋Vue3 🍓Vue2&Vue3项目实战 🥝Node.js🍒Three.js 🌕个人推广:每篇文章最下方都有加入方式,旨在交流学习&资源分享,快加入进来吧

Node.js系列文章目录内容参考链接Node.js(一)初识 Node.jsNode.js(二)Node.js——开发博客项目之接口Node.js(三)Node.js——一文带你开发博客项目(使用假数据处理)Node.js(四)Node.js——开发博客项目之MySQL基础Node.js(五)Node.js——开发博客项目之API对接MySQLNode.js(六)Node.js——开发博客项目之登录(前置知识)Node.js(七)Node.js——开发博客项目之登录(对接完毕)文章目录Node.js系列文章目录项目演示一、前言二、解决跨域1、前端页面就绪2、开启新端口3、nginx 简介4、安装使用 Nginx5、nginx 命令6、nginx 配置三、与前端联调四、CORS 解决跨域五、写在最后项目演示

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

博客项目

一、前言

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

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

二、解决跨域1、前端页面就绪

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

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

页面呈现内容对应如下:

2、开启新端口

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

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

npm install http-server

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

http-server -p 8001

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

3、nginx 简介

nginx 简介:

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

4、安装使用 Nginx

Nginx 下载地址

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

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

5、nginx 命令

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

测试配置文件格式是否正确 nginx -t启动 start nginx重启 nginx -s reload停止 nginx -s stop

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

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

6、nginx 配置

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

修改如下配置:

# 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

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

首页

详情页

作者页

三、与前端联调

为什么要进行联调?

登录功能依赖 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}

联调结果如下:

myblog

四、CORS 解决跨域

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

CORS 解决跨域简介

HTTP 协议的规范,现代浏览器都支持前端和服务端直接通讯,不用 nginx 做转发通过服务端设置 header 来实现

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

Access-Control-Allow-CredentialsAccess-Control-Allow-OriginAccess-Control-Allow-Methods

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

npm init

具体文件目录如下:

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

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

五、写在最后

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

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

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

本文链接地址:https://www.jiuchutong.com/zhishi/299318.html 转载请保留说明!

上一篇:设计模式——单例模式(《设计模式》)

下一篇:【Web 安全】XSS 攻击详解(web安全什么意思)

  • 华为mate10pro参数(华为mate10)(华为mate10pro参数详细参数表)

    华为mate10pro参数(华为mate10)(华为mate10pro参数详细参数表)

  • 手机淘宝必备工具在哪里找(手机淘宝必备工具一栏在哪里)

    手机淘宝必备工具在哪里找(手机淘宝必备工具一栏在哪里)

  • WPS怎样把单元格一分为二(wps怎样把单元格一分为二)

    WPS怎样把单元格一分为二(wps怎样把单元格一分为二)

  • 拉黑再删除和纯删除(拉黑再删除和直接删除一样吗)

    拉黑再删除和纯删除(拉黑再删除和直接删除一样吗)

  • 微博免流量怎么激活(微博免流量怎么开启)

    微博免流量怎么激活(微博免流量怎么开启)

  • 抖音里自己的评论怎么找(抖音买评论)

    抖音里自己的评论怎么找(抖音买评论)

  • 适应边框打印是什么意思(适应边框打印是不是无边框是什么意思)

    适应边框打印是什么意思(适应边框打印是不是无边框是什么意思)

  • QQ怎么修改自动回复内容(qq怎么修改自动回复的内容)

    QQ怎么修改自动回复内容(qq怎么修改自动回复的内容)

  • 取sim卡需要关机吗(手机取sim卡要关机吗)

    取sim卡需要关机吗(手机取sim卡要关机吗)

  • ipad air3多少寸(ipad air3多少英寸)

    ipad air3多少寸(ipad air3多少英寸)

  • 微信注销腾讯还会保留数据吗(微信注销腾讯还会有聊天记录吗)

    微信注销腾讯还会保留数据吗(微信注销腾讯还会有聊天记录吗)

  • 华为换华为手机如何把东西全部转移(华为换华为手机怎么一键换机)

    华为换华为手机如何把东西全部转移(华为换华为手机怎么一键换机)

  • 苹果11网络不好是怎么回事(苹果11网络不好怎么回事但信号是满的)

    苹果11网络不好是怎么回事(苹果11网络不好怎么回事但信号是满的)

  • ie浏览器兼容模式怎么调(ie浏览器兼容模式怎么开)

    ie浏览器兼容模式怎么调(ie浏览器兼容模式怎么开)

  • 光纤灯红色(光纤灯红色一直闪烁怎么回事)

    光纤灯红色(光纤灯红色一直闪烁怎么回事)

  • 小米9pro可以用4g网吗(小米9Pro可以用6a充电线吗)

    小米9pro可以用4g网吗(小米9Pro可以用6a充电线吗)

  • 手机qq怎么隐身(手机qq怎么隐身访问空间)

    手机qq怎么隐身(手机qq怎么隐身访问空间)

  • 微信二维码收款怎么关(微信二维码收款怎么联系付款人)

    微信二维码收款怎么关(微信二维码收款怎么联系付款人)

  • 苹果送达日期会提前吗(iphone送达日期)

    苹果送达日期会提前吗(iphone送达日期)

  • qq邮箱可以发多大的视频(QQ邮箱可以发多少图片)

    qq邮箱可以发多大的视频(QQ邮箱可以发多少图片)

  • 手机的ip地址会变吗(手机的ip地址会泄露个人信息吗)

    手机的ip地址会变吗(手机的ip地址会泄露个人信息吗)

  • 相册怎么制作成幻灯片(相册怎么制作成视频在电视↑播放)

    相册怎么制作成幻灯片(相册怎么制作成视频在电视↑播放)

  • bt蚂蚁下载的视频密码是多少

    bt蚂蚁下载的视频密码是多少

  • 网络安全密钥在哪里找(怎样破解wifi密码并显示出来)

    网络安全密钥在哪里找(怎样破解wifi密码并显示出来)

  • 手机时间长了卡怎么办(手机时间长了卡顿怎么解决华为)

    手机时间长了卡怎么办(手机时间长了卡顿怎么解决华为)

  • 货拉拉是必须先付款吗(货拉拉拉货用不用跟着去)

    货拉拉是必须先付款吗(货拉拉拉货用不用跟着去)

  • ps怎么把图片拉大拉小(ps怎么把图片拉直)

    ps怎么把图片拉大拉小(ps怎么把图片拉直)

  • 小米运动蓝牙耳机青春版怎么连接(小米运动蓝牙耳机mini)

    小米运动蓝牙耳机青春版怎么连接(小米运动蓝牙耳机mini)

  • 最通俗易懂的LSTM讲解,一个例子理解通透!!(最通俗易懂的电动力学教材)

    最通俗易懂的LSTM讲解,一个例子理解通透!!(最通俗易懂的电动力学教材)

  • 现金及现金等价物期末余额
  • 房屋租赁发票票样
  • 股东参与经营可以分红吗
  • 资产负债表中未交税金负数表示什么
  • 无形资产摊销年限
  • 支付宝收据在哪儿看
  • 一般纳税人固定资产怎么入账
  • 普通发票开折扣销售能冲减销售吗
  • 水利建设工程
  • 法人转钱到公户是借款还是投资款
  • 企业减免6%的税的营业范围有哪些?
  • 宣传资料设计制作
  • 应交税费应交增值税减免税款
  • 绿化养护按什么项目交增值税
  • 个体工商户如何给员工交社保
  • 扩建费用
  • 中小企业社保优惠延长政策
  • 抄报是不是在申报之后才能成功?
  • 新开的公司会计需要做什么
  • 限额领料单是一种多次使用的
  • 怎样去除快捷方式小箭头win10
  • win10专业版技巧
  • 冲减增值税进项税怎么处理
  • 在windows7的
  • Proxmox ve(PVE) 显示CPU和硬盘温度、UPS信息
  • key是什么文档
  • 股东已转让股权还可以追究出资吗
  • thinkphp操作数据库
  • 财务费用核算的内容没有
  • 若依名字的含义是什么意思
  • 斯诺多尼亚山
  • 会计政策变更累计数
  • php实现的加密解决方案
  • vue3 hooks实现
  • unet模型代码matlab
  • 14个Python处理Excel的常用操作,非常好用
  • php怎么变成txt
  • laravel enum
  • react避免子组件更新
  • 房产税的租金收入按什么计算的
  • 购货方享受现金流量吗
  • 发票行业税目怎么选
  • sql server s
  • Sqlserver 2005使用XML一次更新多条记录的方法
  • 什么是现金流量的概念?
  • 什么是现金什么是现金流
  • 营改增后个人所得税计税依据实例
  • 起征点与免征额的联系
  • 成本类账户期末如有余额在借方
  • 收到费用发票没有付款的会计分录
  • 航天信息税票
  • 以前年度少计提的工资怎么处理
  • 旅游业最新增值税政策
  • 高速etc发票如何打印
  • 资产负债表怎么看财务状况
  • 红字发票怎样记账
  • mysql在查询结果中查询
  • mac安装mysql的两种方法(含配置)
  • xp系统注册表空白怎么办
  • centos sh
  • win8.1设备管理器设置步骤
  • linux常用命令top
  • centos文件权限详解
  • jquery焦点
  • Node.js中的事件循环是什么
  • ubuntu不待机
  • 一次性批量随机抽取
  • shell自定义函数以及使用
  • CSS3 media queries结合jQuery实现响应式导航
  • js格式化输出数字
  • python怎么将数据存到数据库
  • 使用mvc模式设计的web应用程序
  • Developing for Android, III: The Rules: Performance
  • 堆栈模式都是什么意思
  • python中url
  • JavaScript中的NaN代表什么
  • 国家税务总局洛阳市分局
  • 外经证怎么核验
  • 上海纳税总额
  • 新华保险有返本金吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设