vue プロジェクトを nginx にデプロイする (詳細なチュートリアル)

亚连
リリース: 2018-06-14 17:42:53
オリジナル
7120 人が閲覧しました

vue-router はデフォルトでハッシュ モードになり、URL のハッシュを使用して完全な 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. Web サーバーとして 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>
ログイン後にコピー

上記の Apache の機能は、サーバー上に存在しないすべてのリクエストを Index.html に転送し、さまざまな URL から直接アクセスできるようにすることです。

注:

1. RewriteRule . /bank/page/index.html [L] このコードはルーティング構成ベースに追加したため、前に追加する必要があります。 /bank/page/ このパス。それ以外の場合は一致しません。

2. vue-cli プロジェクトでは、config/index.js のビルドの下にあるassetsPublicPathを変更する必要があります: '/bank/page/' 相対パスを使用すると、

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 All に変更して .htaccess ファイルを有効にします。

2: nginx サーバー上の構成は次のとおりです: vue-cli パッケージ化コマンドを実行します:

npm run build
ログイン後にコピー

上記のようにパッケージ化し、dist フォルダーを生成し、フォルダー内のファイルを直接コピーしますnginx サーバーのディレクトリに移動すると、プロジェクトは開くことができますが、ページを更新するとホームページのみが表示されます。理由は上記と同じです。したがって、nginx サーバーをすべてジャンプするように設定する必要があります。パスまたはフォルダーを指定して、ホームページのindex.htmlにリダイレクトします。これで、ルートを見つけることができます。

nginxサーバーの構成は次のとおりです: 1. まずサーバーにログインします。

2. ディレクトリ /etc/usr/local/nginx/conf/ に移動します。

次のコマンドを実行します。

2-1 cd /etc/ を入力します。

2-2 cd /usr/ を入力します。 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 ディレクティブとは異なり、フォールバック URI が名前付きの場所ではない場合、

引数は自動的に保持されません。引数を保持したい場合は、明示的に宣言する必要があります。

locationディレクティブ

構文: location [=|~|~*|^~|@] /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实现二级路由设置方法

以上がvue プロジェクトを nginx にデプロイする (詳細なチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート