前端项目部署

视频教程:前端项目部署

1、本地的服务器部署(node环境)

service.js

js 复制代码
const express = require('express')
const app = express()
const history = require('connect-history-api-fallback')
const { createProxyMiddleware } = require('http-proxy-middleware')

// 中间件设置静态资源目录
app.use(history())

// 解决刷新404的问题:方法二 - 设置中间件
app.use(express.static(__dirname + '/public'))

// 解决刷新404的问题:方法一 - 使用统配
// app.get('*', (req, res) => {
//   res.sendFile(__dirname + '/public/index.html')
// })


// 解决前端部署以后,ajax 发送不成功的问题
/**
 * 关于 ajax 发送失败原因:
 * vue项目中,vue.config.js 或者 vite.config.js 配置了代理,这个代理在开发环境中可以用,是由脚手架提供的,
 * 但是打包完了以后,打包出来的是 html、css、js 纯文件,没有脚手架了,也就没有代理服务器对接口进行转发了,
 * 那 ajax 访问的地址也就是错误的
 */
app.use(
  '/dev',
  createProxyMiddleware({
    target: 'http://sph-api.atguigu.cn',
    changeOrigin: true,
    pathRewrite: { '^/dev' : '' }
  })
)

app.listen(3000, () => {
  console.log('服务启动成功。。。')
})

将打包出来的文件放到 node 环境下,指定的静态资源目录下,访问的时候,出现两个问题:

1、页面刷新 404

解决办法:

1)配置 vue 路由模式,将 history 模式改为 hash 模式,但是这种模式,地址栏比较丑,一般网站不会使用这种模式

2)node 环境修改,使用

js 复制代码
 app.get('*', (req, res) => {
   res.sendFile(__dirname + '/public/index.html')
 })

3)node 环境修改 - 使用 connect-history-api-fallback 中间件

js 复制代码
const history = require('connect-history-api-fallback')
app.use(history())
2、ajax 请求失效了

出现这种情况的原因是:开发环境中,由脚手架提供了代理服务器,由代理服务器将接口进行转发。

而在生产环境中,使用的是打包出来的 html、css、js 这种纯文件,没有脚手架了,也就没有代理服务器对接口进行转发了,所以 ajax 访问的地址是错误的了。

vite.config.js

js 复制代码
server: {
  proxy: {
      [env.VITE_APP_BASE_API]: {
        // 获取数据的服务器地址
        target: env.VITE_SERVE,
        // 是否允许跨域
        changeOrigin: true,
        // 路径重写
        rewrite: (path) => path.replace(/^\/api/, '')
      },
    }
  },

解决办法:

1)使用 http-proxy-middleware 中间件

service.js

js 复制代码
const { createProxyMiddleware } = require('http-proxy-middleware')
app.use(
  '/dev',
  createProxyMiddleware({
    target: 'http://sph-api.atguigu.cn',
    changeOrigin: true,
    pathRewrite: { '^/dev' : '' }
  })
)

如何解决?

2、nginx 服务器部署

  • 将打包出来的文件,放到对应的目录
  • 修改 nginx.config 文件
    nginx.config
js 复制代码
...
location / {
	root	D:\dist		# root 指向打包的文件所在的目录
	index	index.html 	index.htm	# 默认访问的文件
	try_files	$uri/ $url/ /index.html;	# 解决刷新 404(没有办法匹配资源时,匹配 index.html)
}

location /dev/ {
	# 设置代理目标
	proxy_pass	http://sph-api.atguigu.cn/;	# 解决 ajax 地址错误的问题
}

3、云服务器部署

相关推荐
Qrun27 分钟前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp28 分钟前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.1 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl3 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫5 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友5 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理7 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻7 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front8 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰8 小时前
纯flex布局来写瀑布流
前端·javascript·css