>  기사  >  웹 프론트엔드  >  nginx에 vue 프로젝트 배포(자세한 튜토리얼)

nginx에 vue 프로젝트 배포(자세한 튜토리얼)

亚连
亚连원래의
2018-06-14 17:42:537104검색

vue-router는 기본적으로 해시 모드로 설정되어 있으며 URL의 해시를 사용하여 URL이 변경되면 페이지가 다시 로드되지 않습니다. 이 글에서는 주로 nginx(히스토리 모드)에 vue 프로젝트를 배포하는 방법을 소개합니다. 필요한 친구는

vue-router를 참조할 수 있습니다. 기본값은 해시 모드이며, URL이 완료될 때 URL의 해시를 사용합니다. 변경하면 페이지가 다시 로드되지 않습니다. 하지만 #으로 끝나는 경로를 해시하고 싶지 않다면 라우팅 기록 모드를 사용할 수 있습니다. 예를 들어 다음 URL을 사용하는 경우

해시 모드를 사용하는 경우 액세스는 http://localhost:8080/bank/page/count/#/가 됩니다. 라우팅에서 기록을 사용하는 경우 액세스 경로는 다음과 같습니다.

http://localhost:8080/bank/page/count 이것이 바로

라우팅 구성은 다음과 같습니다. vue-cli 프로젝트를 예로 들어보겠습니다.

src/router/의 코드 index.js는 다음과 같습니다:

import Vue from 'vue';
import Router from 'vue-router';
// import HelloWorld from '@/views/HelloWorld';

Vue.use(Router);

const router = new Router({
 mode: 'history', // 访问路径不带井号 需要使用 history模式
 base: '/bank/page', // 基础路径
 routes: [
  {
   path: '/count',
   name: 'count',
   component: resolve => require(['@/views/count'], resolve) // 使用懒加载
  }
 ]
});

그러나 이 기록 모드에는 백그라운드 구성 지원이 필요합니다. 예를 들면 다음과 같습니다.

프로젝트 홈페이지에 가면 모든 것이 정상이고 액세스할 수 있지만 페이지를 새로 고치거나 경로에 직접 액세스하면 404가 반환됩니다. 기록 모드에서는 창이 이기 때문입니다. 브라우저 주소 표시줄의 경로를 변경하기 위해 js.history를 통해서만 동적으로 작동하며 http 요청이 시작되지 않습니다. 그러나 이 주소를 브라우저에 직접 입력하면 서버에 대한 http 요청을 시작해야 하지만 이 대상은 서버에 존재하지 않으므로 404가 반환됩니다. 어떻게 해결합니까? 이제 모든 요청을 http://localhost:8080/bank/page/index.html로 전달할 수 있습니다.

1: Apache 서버의 구성은 다음과 같습니다.

1 지금 Apache를 웹 서버로 사용하는 경우 .htaccess 지원을 활성화해야 합니다.

다음을 파일에 추가합니다. 그러면 모든 것이 정상화됩니다

<IfModule mod_rewrite.c>
 RewriteEngine On
 RewriteBase /
 RewriteRule ^index\.html$ - [L]
 RewriteCond %{REQUEST_FILENAME} !-f
 RewriteCond %{REQUEST_FILENAME} !-d
 RewriteRule . /bank/page/index.html [L]
</IfModule>

위 아파치의 기능은 서버에 존재하지 않는 모든 요청을 index.html로 전달하여 다양한 URL을 통해 직접 액세스할 수 있도록 하는 것입니다.

참고:

1. RewriteRule . /bank/page/index.html [L] 이 코드는 라우팅 구성 베이스에 추가했기 때문에 앞에 추가해야 합니다. /bank/page/ 이 경로입니다. 그렇지 않으면 일치하지 않습니다.

2. vue-cli 프로젝트에서는 config/index.js: '/bank/page/'의 빌드 아래에 있는 자산PublicPath를 수정해야 합니다. 상대 경로를 사용하면

chunk 파일에서 오류가 보고됩니다. 찾을 수 없다는 것입니다.

3. Apache의 www/bank/page 디렉토리에 새 .htaccess 파일을 생성합니다. RewriteRule을 /bank/page/index.html로 수정해야 합니다. 그렇지 않으면 페이지를 새로 고칠 때 서버가 404 오류를 직접 보고합니다. .

4. httpd.conf 파일을 수정하고 rewrite_module 기능을 활성화합니다.

5. LoadModule rewrite_module libexec/apache2/mod_rewrite.so, #

6을 제거한 다음 AllowOverride None 줄을 찾아 AllowOverride All로 변경하여 .htaccess 파일을 적용합니다.

둘: nginx 서버의 구성은 다음과 같습니다. vue-cli 패키징 명령을 실행합니다.

npm run build

위와 같이 패키지하고 dist 폴더를 생성한 후 폴더에 있는 파일을 직접 복사합니다. nginx 서버 디렉터리를 사용하면 프로젝트를 열 수 있지만 홈페이지만 볼 수 있습니다. 페이지를 새로고침해도 여전히 404입니다. 이유는 위와 동일하므로 모두 점프하도록 nginx 서버를 구성해야 합니다. 경로나 폴더를 선택하고 홈페이지 index.html로 리디렉션됩니다. 이것이 바로 경로를 찾을 수 있는 방법입니다.

nginx 서버 구성은 다음과 같습니다. 1 먼저 서버에 로그인합니다.

2. /etc/usr/local/nginx/conf/ 디렉토리를 입력합니다.

명령을 실행합니다:

2-1 cd /etc/ Enter

2-2 cd /usr/ Enter

2- 3 cd loacl/ Enter

2-4 cd nginx Enter

2-5 cd conf Enter

2-6 vi nginx_v4.conf nginx 파일을 입력하고 새 프로젝트를 생성합니다.

예를 들면 다음과 같습니다. , 우리는 이제 다음과 같이 도메인 이름 주소에 액세스합니다: http://aa.xx.com/bank/page/count, 다음 구성이 필요합니다:

server {
  listen 443;   # 监听本机所有ip上的 443 端口
  listen 80;   # 监听本机所有ip上的 80 端口
  server_name aa.xx.com; # 域名地址
  access_log /data/www/logs/nginx/aa/access.log main; # 新建日志文件
  include nginx_xx.conf; 
  /* 下面是多个location 用于配置路由地址 */
  location / {
   proxy_pass http://aa/;
   include nginx_proxy.conf;
  }
  location /bank/page/ {
   try_files $uri $uri/ /bank;
  },
  /* http://aa.xx.com/bank2/page/count 有多个不同的地址 就加一个如下这个配置 */
  location /bank2/page/ {
   try_files $uri $uri/ /bank2;
  }
  error_page 500 502 503 504 /502.html;
  location = /50x.html {
   root  html;
  }
 }

try_files 명령:

구문: ​​try_files 파일 ... uri 또는 try_files 파일.. . = 코드

기본값: 없음

범위: 서버 위치

해당 기능은 파일이 순서대로 존재하는지 확인하고 처음 발견된 파일 또는 폴더를 반환하는 것입니다(후행 슬래시는 폴더). 파일이나 폴더가 하나도 없고 마지막 매개변수로 내부 리디렉션이 이루어진 경우.

마지막 매개변수만 내부 리디렉션을 유발할 수 있으며, 이전 매개변수는 내부 URI의 포인팅만 설정한다는 점에 유의해야 합니다. 마지막 매개변수는 대체 URI이며 존재해야 합니다. 그렇지 않으면 내부 500 오류가 발생합니다. 이름이 지정된 위치는 마지막 매개변수에도 사용할 수 있습니다. rewrite 지시문과 달리 fallback URI가 명명된 위치가 아닌 경우

args는 자동으로 유지되지 않습니다. args를 유지하려면 이를 명시적으로 선언해야 합니다.

위치 지시어

구문: ​​위치 [=|~|~*|^~|@] /uri/ { … }

기본값: 없음

범위: 서버

location指令是用来为匹配的URI进行配置,URI即语法中的"/uri/",可以是字符串或正则表达式。但如果要使用正则表达式,则必须指定前缀。 [@] 即是命名location,一般只用于内部重定向请求。

3. 设置成功后需要重启:nginx重启命令;在 /etc/usr/local/nginx/conf/ 目录下, cd ../ 然后进入sbin目录下 cd sbin 接着运行命令 ./nginx -s reload 重启后即可生效。

4. 在/data/www/logs/nginx/aa/目录下 新建 access.log 文件。

然后nginx保存和退出命令 :wq

直接退出的命令是 :q

5. mac系统下 自带 apache2服务器,需要对apache2作反向代理;配置如下:

进入本地mac apache2配置;

命令:cd /etc/apache2

命令:sudo vi httpd.conf

<VirtualHost *:80>
 ServerName aa.xx.com
 ProxyRequests off
 Header set Access-Control-Allow-Origin *
 <Proxy *>
   Order deny,allow
   Allow from all
 </Proxy>
 <Location /aa>
   ProxyPass http://localhost:8896/
   ProxyPassReverse http://localhost:8896/
 </Location>
 // .... 更多配置省略
</VirtualHost>

然后进入 sbin目录下 启动服务 sudo apachectl start

重启命令如下 sudo apachectl restart

6. java服务端的配置如下 (如果是vm放到开发那边的话,开发那边需要如下处理下,如果页面vm不放在开发那边的话,下面的配置可以忽略)

在项目目录下 webapp/web-inf/view/ 新建文件夹 aa 和 include文件

aa文件下 新建index.vm

如下代码:

#parse("include/common.vm")
#@frame("xx管理",true)
#css(["${version}/business/aa/aa.css"]) // 打包后的css路径,具体看自己的路径
<p id="app"></p>
#js(["${version}/business/aa/aa.js"]) // 打包后的js路径,具体看自己的路径
#end

6-2 java开发需要配置一下:

1 设置路由: /aa 设置路由到 /aa/index.vm

2 这个include/common.vm有一个地址配置,是在disconf上配置的,你加一个

地址配置到 //aa.xx.com/aa/dist 上即可

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

使用vue2.0.js实现多级联动选择器

使用mint-ui实现省市区三级联动效果

使用vue实现二级路由设置方法

위 내용은 nginx에 vue 프로젝트 배포(자세한 튜토리얼)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.