解決網站部分用戶訪問browserconfig.xml文件返回404的問題

問題描述

 部分用戶訪問網站時,檢測日誌出現url(http://www.xxx.cn/browserconfig.xml)這個返回404.網上一搜才知道,這是ie11的磁貼(https://msdn.microsoft.com/library/dn455106(v=vs.85).aspx)配置文件。當用戶固定站點時,IE11 會查找名爲 browserconfig.xml 的包含獨立通知文件(磁貼架構文件)的 URL 的文件,並讓 Windows 以指定的時間間隔獲取該文件。因爲我們網站沒有配置所以,部分固定了站點的用戶訪問網站時,ie11獲取不到磁貼配置文件,所以返回了404.

解決辦法

 1、很簡單,那就是配置browserconfig.xml文件,並放到站點根目錄下,並且通過頁面 <head> 部分中的圖元元素<meta name="msapplication-config" content="browserconfig.xml" />指向這個文件。在這裏注意改配置文件名稱要用默認的browserconfig,不然IE仍然找不到。
 2、如何配置?https://msdn.microsoft.com/library/dn455106(v=vs.85).aspx ,官方文檔介紹了三種方法配置。分別是(http://samples.msdn.microsoft.com/iedevcenter/PinnedSites/default.html):
 直接在heade裏通過定義元數據的方式(http://www.buildmypinnedsite.com/)
 第二是通過配置xml的方式(這種方式最好,尤其要做動態網站的)
 第三種是通過js來調用動態磁貼架構文件

注意事項

 雖然對着官方文檔配置很簡單,但是還是有一些小問題要注意的。
  1. header裏面通過meta定義的元數據名稱一定要是ie11默認的名稱。
  2. 由於ie磁貼只是針對win8,win8.1,win10用戶,所以在配置完測試的時候還是有些坑的。用windows默認IE打開網址。

    這裏寫圖片描述

  3. 成功後的圖片

    這裏寫圖片描述

網站元數據

推薦閱讀 http://blog.csdn.net/freshlover/article/details/25322839
http://www.haorooms.com/post/html_meta_ds
移動端viewport標籤

    <meta name="viewport"  
    content="  
        height = [pixel_value | device-height] ,  
        width = [pixel_value | device-width ] ,  
        initial-scale = float_value ,  
        minimum-scale = float_value ,  
        maximum-scale = float_value ,  
        user-scalable = [yes | no] ,  
        target-densitydpi = [dpi_value | device-dpi | high-dpi | medium-dpi | low-dpi]  
    "  
    />  

含義如下:
width

控制 viewport 的大小,可以指定的一個值或者特殊的值,如 device-width 爲設備的寬度(單位爲縮放爲 100% 時的 CSS 的像素)。
height

和 width 相對應,指定視窗的高度。

target-densitydpi

一個屏幕像素密度是由屏幕分辨率決定的,通常定義爲每英寸點的數量(dpi)。Android支持三種屏幕像素密度:低像素密度,中像素密度,高像素密度。一個低像素密度的屏幕每英寸上的像素點更少,而一個高像素密度的屏幕每英寸上的像素點更多。Android Browser和WebView默認屏幕爲中像素密度。

下面是 target-densitydpi 屬性的 取值範圍

device-dpi –使用設備原本的 dpi 作爲目標 dp。 不會發生默認縮放。
high-dpi – 使用hdpi 作爲目標 dpi。 中等像素密度和低像素密度設備相應縮小。
medium-dpi – 使用mdpi作爲目標 dpi。 高像素密度設備相應放大, 像素密度設備相應縮小。 這是默認的target density.
low-dpi -使用mdpi作爲目標 dpi。中等像素密度和高像素密度設備相應放大。
<value> – 指定一個具體的dpi 值作爲target dpi. 這個值的範圍必須在70–400之間。

爲了防止Android Browser和WebView 根據不同屏幕的像素密度對你的頁面進行縮放,你可以將viewport的target-densitydpi 設置爲 device-dpi。當你這麼做了,頁面將不會縮放。相反,頁面會根據當前屏幕的像素密度進行展示。在這種情形下,你還需要將viewport的width定義爲與設備的width匹配,這樣你的頁面就可以和屏幕相適應。

initial-scale

初始縮放。即頁面初始縮放程度。這是一個浮點值,是頁面大小的一個乘數。例如,如果你設置初始縮放爲“1.0”,那麼,web頁面在展現的時候就會以target density分辨率的1:1來展現。如果你設置爲“2.0”,那麼這個頁面就會放大爲2倍。

maximum-scale

最大縮放。即允許的最大縮放程度。這也是一個浮點值,用以指出頁面大小與屏幕大小相比的最大乘數。例如,如果你將這個值設置爲“2.0”,那麼這個頁面與target size相比,最多能放大2倍。

user-scalable

用戶調整縮放。即用戶是否能改變頁面縮放程度。如果設置爲yes則是允許用戶對其進行改變,反之爲no。默認值是yes。如果你將其設置爲no,那麼minimum-scale 和 maximum-scale都將被忽略,因爲根本不可能縮放。

所有的縮放值都必須在0.01–10的範圍之內。

例:

(設置屏幕寬度爲設備寬度,禁止用戶手動調整縮放)

 <meta name="viewport" content="width=device-width,user-scalable=no" />

(設置屏幕密度爲高頻,中頻,低頻自動縮放,禁止用戶手動調整縮放)

<meta name="viewport" content="width=device-width,target-densitydpi=high-dpi,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>

另外,iOS 7.1的Safari爲meta標籤新增minimal-ui屬性,在網頁加載時默認隱藏地址欄與導航欄

    <meta name="viewport" content="minimal-ui">  

此時點擊頂欄區域便能切換爲顯示地址欄、導航欄,再點擊頁面主體區域則又使之隱藏。

發佈了29 篇原創文章 · 獲贊 78 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章