位置: 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安全什么意思)

  • 为啥星巴克横着排队麦当劳竖着排队?(星巴克为什么有些是杯子)

    为啥星巴克横着排队麦当劳竖着排队?(星巴克为什么有些是杯子)

  • 网易云一起听怎么添加歌(网易云一起听怎么发朋友圈)

    网易云一起听怎么添加歌(网易云一起听怎么发朋友圈)

  • 华为手机拆电池技巧(华为手机拆电池可以用电源)

    华为手机拆电池技巧(华为手机拆电池可以用电源)

  • 信息化与智能化的区别(信息化与智能化时代对环境设计产生哪些影响)

    信息化与智能化的区别(信息化与智能化时代对环境设计产生哪些影响)

  • 家用wifi能查到浏览记录吗(家用wifi能查到用户访问的网站吗)

    家用wifi能查到浏览记录吗(家用wifi能查到用户访问的网站吗)

  • 淘宝订单看不到备注(淘宝订单看不到自动确认收货时间)

    淘宝订单看不到备注(淘宝订单看不到自动确认收货时间)

  • 电信停机后充值,多久恢复网络(电信停机后充值,多久恢复正常使用)

    电信停机后充值,多久恢复网络(电信停机后充值,多久恢复正常使用)

  • 荣耀20pro屏幕刷新率多少HZ(荣耀20pro刷机教程)

    荣耀20pro屏幕刷新率多少HZ(荣耀20pro刷机教程)

  • cat5e是千兆网线吗(cat5e网线支持千兆吗)

    cat5e是千兆网线吗(cat5e网线支持千兆吗)

  • 家里搜不到无线网名字(家里搜不到wi-fi)

    家里搜不到无线网名字(家里搜不到wi-fi)

  • honor 9x pro是什么手机

    honor 9x pro是什么手机

  • nova65g和mate305g对比(华为nova65g和mate305g哪个好)

    nova65g和mate305g对比(华为nova65g和mate305g哪个好)

  • 第一代iphone发布时间(第一代iphone发布后,微软的反应)

    第一代iphone发布时间(第一代iphone发布后,微软的反应)

  • 优酷季卡是几个月(优酷季卡是几个月动车可以带花露水吗)

    优酷季卡是几个月(优酷季卡是几个月动车可以带花露水吗)

  • vivoy5s是什么时候上市的(vivoy5s是什么时候出的)

    vivoy5s是什么时候上市的(vivoy5s是什么时候出的)

  • 通话异常结束什么原因(通话异常结束什么原因微信)

    通话异常结束什么原因(通话异常结束什么原因微信)

  • 华为p30自带美颜吗(华为p30美颜设置)

    华为p30自带美颜吗(华为p30美颜设置)

  • iphonex的基带是高通的吗(苹果x系列基带)

    iphonex的基带是高通的吗(苹果x系列基带)

  • oppo手机安装包在哪里(oppo手机安装包与系统不兼容)

    oppo手机安装包在哪里(oppo手机安装包与系统不兼容)

  • 抖音水彩滤镜道具在哪里?(抖音色彩涟漪滤镜)

    抖音水彩滤镜道具在哪里?(抖音色彩涟漪滤镜)

  • 苹果手机通讯录怎么导入到华为手机(苹果手机通讯录联系人重复怎样处理)

    苹果手机通讯录怎么导入到华为手机(苹果手机通讯录联系人重复怎样处理)

  • wps循环引用如何关(wps循环引用警告一个或多个公式包含循环引用)

    wps循环引用如何关(wps循环引用警告一个或多个公式包含循环引用)

  • airpods是什么意思(AirPods是什么意思 AirPods怎么读?)

    airpods是什么意思(AirPods是什么意思 AirPods怎么读?)

  • 怎么开vt(雷电模拟器怎么开vt)

    怎么开vt(雷电模拟器怎么开vt)

  • 如何阻止windows更新驱动程序(如何阻止windows10升级到11)

    如何阻止windows更新驱动程序(如何阻止windows10升级到11)

  • pow.exe是什么意思 什么进程 pow进程查询(pow是什么意思中文翻译)

    pow.exe是什么意思 什么进程 pow进程查询(pow是什么意思中文翻译)

  • linux系统下安装dovecot方法(linux安装linux)

    linux系统下安装dovecot方法(linux安装linux)

  • 【React-Hooks进阶】useState回调函数的参数 / useEffect发送网络请求/ useRef / useContext(react hook详解)

    【React-Hooks进阶】useState回调函数的参数 / useEffect发送网络请求/ useRef / useContext(react hook详解)

  • 继续教育专项扣除金额
  • 其他应付款是不是长期负债
  • 企业所得税前扣除是什么意思
  • 应交税费科目核算
  • 定期存款准备金是什么
  • 化妆品的成本利润是多少
  • 不同税率的增值税如何报税
  • 增值税检查调整科目已经删除
  • 销售固定资产可以开专票吗
  • 除工资外其他收入需要个税吗
  • 企业房产使用税
  • 慰问金怎么入账科目
  • 季度缴纳所得税如何做账
  • 合伙企业分配比例税法规定
  • 资产减值损失是什么类科目
  • 什么情况下征收车船税
  • 顶账物品都有哪些
  • 长期待摊费用发生当月摊还是次月摊
  • win11windows安全中心打不开
  • windows11加密
  • 从税法角度看,商誉计税基础
  • 专项基金是什么
  • 预付账款为负数能转为应付账款吗
  • 不附追索权的票据包括
  • psr.exe是什么意思
  • 工地安装监控哪个部门管
  • 交接目录excel
  • mplugin.exe是什么
  • vue3自定义指令
  • 归属性质
  • 分期收款销售商品,收到本期货款50万元
  • 以前年度的销售退回,冲减哪年的
  • uniapp简介
  • 固定资产家具用具包括什么
  • 补交去年增值税怎么做账
  • 长期待摊费用装修款如何摊销
  • 小规模纳税人开普票要交税吗
  • 劳动仲裁支付的个人款项怎么做账
  • 短期投资的入账成本
  • css的flex:1
  • 网站用masonry瀑布流无限加载重叠解决方法
  • dedecms安装步骤
  • 盘盈固定资产如何处理
  • 累计净值是怎么计算的
  • 提交表单数据有哪几种方法,php如何获取表单提交的数据
  • MSSQLSERVER不同版本设置开启远程连接(sa配置)
  • 清空表sql语句
  • 电影卡购买
  • 个人所得税率怎么退
  • 已执行新金融准则 本期金额
  • 交耕地占用税如何交
  • 关于餐饮行业
  • 管理费用和销售费用属于什么科目
  • 二级分支机构不具有主体生产经营职能?
  • 事业单位固定资产入账标准最新规定
  • 公司食堂招待客户,客户付了钱怎么入账
  • 施工企业内部管理制度
  • SQL Server中通过reverse取某个最后一次出现的符号后面的内容(字符串反转)
  • sql server如何使用
  • win8.1技巧
  • win10win8
  • 新买的笔记本电脑需要做什么
  • js倒计时结束操作
  • vi和vim的关系
  • 置顶聊天折叠怎么开启
  • td nowrap css nowrap使用说明于注意事项
  • pcs可以使用什么在任何地方以各种速率与网络保持联络
  • 详解JavaScript对W3C DOM模版的支持情况
  • js输出表格
  • Android-SQLite商业化数据库操作
  • python中的字符串可变吗
  • 从安卓设备导入
  • javascript缓存
  • 23种设计模式全解
  • javascript 类型
  • 事务所是干什么的会计
  • 百旺怎么导出数据
  • 税务核销
  • 个体户需要报个税的综合所得吗
  • 河北税务云办税厅官方
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设