0

0

phpEnv如何部署Vue项目 phpEnv前后端分离配置方法

煙雲

煙雲

发布时间:2026-04-22 15:17:23

|

111人浏览过

|

来源于php中文网

原创

Vue在phpEnv部署需据路由模式选择方案:一、hash模式直接放dist至www目录;二、history模式需配.htaccess重写;三、前后端分离用Nginx反向代理;四、同域跨子路径需PHP加CORS头。

phpenv如何部署vue项目 phpenv前后端分离配置方法 - php中文网

如果您在phpEnv环境中部署Vue项目时遇到静态资源无法加载、路由404或接口跨域失败等问题,则可能是由于Web服务器未正确识别Vue构建产物或未适配History模式。以下是针对phpEnv环境的多种部署与配置方法:

一、将Vue构建产物直接放入phpEnv网站根目录

该方法适用于Vue使用默认hash路由模式,无需重写规则,部署最简捷。phpEnv默认网站根目录为 D:\phpenv\www(Windows)或 /opt/phpenv/www(Linux/macOS),所有静态文件必须置于该路径下可被直接访问。

1、在Vue项目根目录执行 npm run buildyarn build,生成 dist 文件夹。

2、打开 dist 文件夹,全选其中所有文件(含 index.html、js/、css/、assets/ 等子目录)。

立即学习PHP免费学习笔记(深入)”;

3、将其粘贴至 phpEnv 的默认网站根目录,例如:D:\phpenv\www\my-vue-app\

4、启动phpEnv的Apache与MySQL服务,在浏览器中访问 http://localhost/my-vue-app/,确认 index.html 正常加载且页面交互可用。

二、配置Apache支持Vue History路由模式

当Vue Router启用 history 模式时,直接访问 /user/profile 会触发Apache 404错误,因该路径实际不存在物理文件。需通过 .htaccess 启用URL重写,将所有非资源请求回退至 index.html 处理。

1、确保 phpEnv 中 Apache 已启用 mod_rewrite 模块(默认已开启)。

2、在 Vue 部署目录(如 D:\phpenv\www\my-vue-app\)下新建文件,命名为 .htaccess

3、用文本编辑器打开 .htaccess,写入以下内容:

RewriteEngine On
RewriteBase /my-vue-app/
RewriteRule ^index\.html$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /my-vue-app/index.html [L]

4、保存文件,重启 phpEnv 的 Apache 服务。

Codiga
Codiga

可自定义的静态代码分析检测工具

下载

5、刷新浏览器访问 http://localhost/my-vue-app/user/profile,验证路由跳转不再报404。

三、通过phpEnv内置Nginx反向代理实现前后端分离

该方案将Vue前端静态资源与PHP后端API完全解耦:前端由Nginx直接托管,后端PHP服务运行于独立端口(如9001),Nginx负责将 /api/ 路径请求代理至后端,避免跨域问题。

1、将Vue构建产物放入独立目录,例如:D:\phpenv\nginx\html\frontend\

2、修改 phpEnv Nginx 配置文件 D:\phpenv\nginx\conf\nginx.conf,在 http 块内添加 server 配置:

server {
  listen 80;
  server_name localhost;
  root D:/phpenv/nginx/html/frontend;
  index index.html;
  location / {
    try_files $uri $uri/ /index.html;
  }
  location /api/ {
    proxy_pass http://127.0.0.1:9001/;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
  }
}

3、启动PHP后端服务(如使用 php -S 127.0.0.1:9001 -t D:/phpenv/www/api/),确保接口可通过 http://127.0.0.1:9001/login 访问。

4、重启 phpEnv 的 Nginx 服务,访问 http://localhost/ 加载前端,并检查浏览器开发者工具 Network 标签页中 /api/ 请求是否返回200。

四、解决Vue调用PHP接口时的跨域问题(不使用代理)

若选择将Vue与PHP共置于同一域名但不同子路径(如前端 /,后端 /api/),需在PHP接口入口处统一注入CORS响应头,使浏览器允许前端脚本读取响应内容。

1、在PHP后端所有接口文件顶部(或统一中间件中)添加如下代码:

<?php
header('Access-Control-Allow-Origin: http://localhost');
header('Access-Control-Allow-Methods: GET, POST, OPTIONS, PUT, DELETE');
header('Access-Control-Allow-Headers: Content-Type, Authorization, X-Requested-With');
header('Access-Control-Allow-Credentials: true');
if ($_SERVER['REQUEST_METHOD'] === 'OPTIONS') {
  exit(0);
}
// 后续业务逻辑...

2、确保Vue中 axios 请求 baseURL 设置为 '/api/'(相对路径),而非 'http://localhost:8000/api/'

3、重启phpEnv的Apache服务,清除浏览器缓存后重新访问页面,检查控制台是否仍有 CORS 错误提示。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

通义千问
通义千问

阿里巴巴推出的全能AI助手

Claude
Claude

Anthropic发布的与ChatGPT竞争的聊天机器人

Cursor
Cursor

一个新的IDE,使用AI来帮助您重构、理解、调试和编写代码。

Hermes Agent
Hermes Agent

一位与您共同成长的Agent

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python是前端还是后端
python是前端还是后端

Python属于前端也属于后端,其灵活性和丰富的生态系统使得开发人员能够在不同的领域中灵活运用。本专题为大家提供python相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.08.11

前端和后端的区别
前端和后端的区别

前端关注的是用户界面的设计和交互,而后端则注重数据处理和逻辑控制。想了解更多前端后端的相关内容,可以阅读本专题下面的文章。

617

2024.03.19

后端的主要工作内容介绍
后端的主要工作内容介绍

后端是应用程序的服务端部分,负责核心任务,如数据库交互、业务逻辑处理和响应客户端请求。想了解更多后端的相关内容,可以阅读本专题下面的文章。

737

2024.03.19

php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

3344

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

2079

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1597

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1310

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1777

2023.10.23

phpEnv 多版本 PHP 切换与管理
phpEnv 多版本 PHP 切换与管理

系统讲解 phpEnv 的多版本 PHP 管理能力,涵盖 PHP 5.6、7.4、8.0、8.1、8.2、8.3 等多版本的下载安装与共存配置、不同站点绑定不同 PHP 版本的方法、php.ini 常用参数(内存限制/上传大小/时区/错误显示)的独立调整、PHP 扩展(Redis/Swoole/Xdebug/imagick)的安装与启用,帮助开发者灵活应对多项目多版本的开发需求。

0

2026.04.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Xdebug手册
Xdebug手册

共0课时 | 0人学习

如何安装 Composer
如何安装 Composer

共1课时 | 26人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送