Vue H5 History 部署IIS上404問題

来源:http://www.cnblogs.com/jianxuanbing/archive/2017/05/06/6816371.html
-Advertisement-
Play Games

背景簡介 使用 時,預設的地址並不美觀,以 進行分割,例如: 。 為了訪問地址能像正常的 一樣,例如: 。 按照官網介紹,使用 history 模式。但是卻產生了問題。 問題 因為我們的應用是單頁客戶端應用,當用戶在瀏覽器直接訪問 時,刷新頁面的時候,會返回404錯誤。 問題原因 服務端URL匹配不 ...


背景簡介

vue使用vue-router時,預設的地址並不美觀,以#進行分割,例如:http://www.xxx.com/#/main
為了訪問地址能像正常的url一樣,例如:http://www.xxx.com/user/id
按照官網介紹,使用 history 模式。但是卻產生了問題。

問題

因為我們的應用是單頁客戶端應用,當用戶在瀏覽器直接訪問http://www.xxx.com/user/id時,刷新頁面的時候,會返回404錯誤。

問題原因

服務端URL匹配不到相應的路由資源

解決方案

官網提供的解決方案只支持Apache伺服器以及Nginx伺服器配置,然而IIS的解決方案並沒有給出

  • 方案一

    可通過給IIS站點設置虛擬目錄的方式可解決該問題,但是這方式路由比較多的時候比較麻煩。
    添加虛擬目錄

  • 方案二

    1、下載Web平臺安裝程式(https://www.microsoft.com/web/downloads/
    2、如果已經安裝過Web平臺安裝程式,可以在IIS站點看到該程式
    查看Web平臺安裝程式
    3、查找Url重寫工具2.0併進行安裝
    查找Url重寫工具2.0
    4、安裝完畢後,重新打開IIS控制台,進入相應站點,就可以看到URL重寫該功能模塊
    查看URL重寫工具
    5、添加規則,並選擇入站規則-空白規則
    添加規則
    完成規則

總結

Url重寫設置
匹配的URL:請求的URL選擇與模式匹配,模式中填寫*,使用選項選擇通配符;即表示所有的網站都通過此模式進行檢查匹配。
條件:是下麵的條件選項,我們選擇不是文件,邏輯分組為全部匹配。
操作:重寫到index.html(根據情況,設置為自己的單頁面應用首頁)。

以上操作是設置我們的頁面請求為先檢查有沒有該文件,沒有該文件全部重寫到首頁,從而能夠使用自定義路由。然後在vue程式中設置/index.html路徑為起始頁,並且定義404頁面。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我們這裡所說的devicePixelRatio其實指的是window.devicePixelRatio, 被所有WebKit瀏覽器以及Opera所支持。 概念 devicePixelRatio ,它是設備上物理像素和設備獨立像素( device-independent pixels (dips) ) ...
  • 不管是左是右,反正就是一邊寬度固定,一邊寬度自適應。 博客園的很多主題也是這樣設計的,我的博客也是右側固定寬度,左側自適應屏幕的佈局方式。 html代碼: 實現方式方式有如下幾種: 1.固定寬度區浮動,自適應區不設寬度而設置 margin 我們以右側寬度固定,左側寬度自適應為例: css代碼: 實現 ...
  • window.onload事件處理函數在頁面載入完畢後調用。 問題是有時我們給window.onload事件處理函數綁定不止一個函數,並且有一些函數函數帶有參數的。 下麵是兩個參數函數,其中一個有參數,另一個沒有參數。 一、以前的做法是直接綁定。 二、addLoadEvent()函數 綁定不帶參數的 ...
  • wx.getUserInfo(OBJECT) 微信官方的這個獲取用戶信息的方法,需要對介面返回的加密數據( encryptedData )進行對稱解密。 ...
  • 六、使用下拉列表框進行多選 1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 5 <title>使用下拉列表框進行多選</title> 6 ...
  • 例題一枚:在input框中輸入內容,會相應的顯示在下麵的div中的不同做法: js:原生DOM操作 指點迷津:getElementById獲取DOM節點,innerHTML:設置或者獲取節點內部的所有HTML代碼; 這裡需要註意獲取到input裡面的節點內容需要獲取value值。 這裡使用的是inn ...
  • ECMAScript語言類型對應於使用ECMAScript語言的ECMAScript程式員直接操作的值。ECMAScript語言類型有以下幾種Undefined,Null,Boolean,String,Symbol,Number和Object。ECMAScript語言值是以ECMAScript語言類 ...
  • html頁面上的元素都可以看成是框組成的,框通過三種定位機制排列在一起就過程了我們看到的頁面.而框就是盒模型. 盒模型 1.頁面上的每個元素可以看成一個矩形框,每個框由元素的內容,內邊距,邊框和外邊距組成。 2.如果在元素上添加背景,則背景是邊框, 內邊距和內容組成的區域. 3.在css中width ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...