亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

學習筆記:Maven構造版本號的方法解決瀏覽器緩存問題

2019-11-14 15:17:37
字體:
來源:轉載
供稿:網友

需要解決的問題

  在做WEB系統開發時,為了提高性能會利用瀏覽器的緩存功能,其實即使不顯式的申明緩存,現代的瀏覽器都會對靜態文件(js、CSS、圖片之類)緩存。但也正因為這個問題導致一個問題,就是資源的緩存邏輯有時出現問題后服務器的最新版本文件無法更新客戶端的緩存。

  這個問題會給用戶產生許多的困擾,當然首先是測試人員會很頭痛,一些看起來沒有修復的bug為什么開發要說做好了?這種時候我會無奈的說:ctrl+f5刷新一下。但這畢竟不是解決問題的方法。

思路與方法考慮

思路

  之前沒有著手處理過這樣的問題,只是知道緩存可以通過時間戳、版本戳的方式來解決。說白了就是讓link的url不一樣瀏覽器自然會下載最新版本,想想這不是挺容易的事情嘛。項目緊也就沒當回事,等有時間了再來解決這個問題。

  好了,最近有時間了開始解決。找了許多的方法,發現這確實是簡單的加一個版本號/時間戳就能解決:

<link rel="stylesheet" type="text/css" href="/css/common.css?ver=${sysVersion}" />

上面代碼中在資源后面加了一個?ver=${sysVersion}

注:項目中使用的是velocity,所以${sysVersion}是指velocity中的變量。

新的問題

  但一個新問題產生,我們是使用hudsun+maven來進行構造并自動發布及部署到web服務器上。那么我們如何在maven構造時打上一個版本戳呢?

方法

  1. 通過某種方法生成一個版本號寫入到文件,系統啟動時加載此版本號,這樣velocity就能夠使用這個版本號從而解決緩存更新的問題。這種就是單一的統一版本號方法。
  2. 通過前端的編譯工具,grunt、F.I.S這類工具來完成,特別是F.I.S可以實現md5戳的模式,直接針對單個資源進行版本更新,這樣就比較精確也最大化了緩存的作用。

最后還是選擇了第一種方法,因為集成前端編譯工具的方法我沒有搞定T_T,原因:

1、F.I.S需要基于Node.js,這個又要配置許多東西,有點麻煩,當我自己搭建環境就反復了許多天,后來發現是網絡墻原因。

2、另外由于項目做的不是很規范,所以F.I.S生成時需要改動比較多的代碼,這個是我這種懶人不太愿意做的

 

于是先用簡單的方法解決之,最后經過1天的配置也確實完成了。

采用最簡單的單一版本號

單一的版本號一下子就簡化了解決問題的難度,只要想辦法在發布時生成一個版本號即可,那就不管是時間、數字或者其他什么,所有的資源都引用此版本號即可。找到了一個maven的插件:maven-svn-revision-number-plugin,這個插件可以獲取svn的版本號用作build號,這樣的好處就是只要有代碼提交就會有新版本產生。插件的代碼如下:

          <plugin>              <groupId>com.google.code.maven-svn-revision-number-plugin</groupId>              <artifactId>maven-svn-revision-number-plugin</artifactId>              <version>1.7</version>              <configuration>                  <verbose>true</verbose>                  <entries>                      <entry>                          <PRefix>prefix</prefix><!-- 版本戳的前綴-->                          <depth>empty</depth>                      </entry>                  </entries>              </configuration>              <executions>                  <execution>                      <phase>validate</phase><!-- 生命周期階段-->                      <goals>                          <goal>revision</goal>                      </goals>                  </execution>              </executions>              <dependencies>                  <dependency>                    <groupId>org.tmatesoft.svnkit</groupId><!-- 由于使用的是svn1.8版本,所以需要依賴這個插件-->                    <artifactId>svnkit</artifactId>                    <version>1.8.9</version>                  </dependency>              </dependencies>          </plugin>  

這個插件的作用是在maven構造時獲取最新的svn版本號,然后利用maven的resources的filtering來在各個配置文件中作用變量使用。這樣就實現了構造時將版本號寫入文件。

resources的代碼:

      <resources>        <resource>            <directory>src/main/resources</directory>            <includes>                <include>**.properties</include><!-- 只對properties文件進行處理-->            </includes>            <filtering>true</filtering><!-- 表示開啟變量嵌入 -->        </resource>        <resource>            <directory>src/main/resources</directory>                <excludes>                    <exclude>**.properties</exclude>                </excludes>            <filtering>false</filtering>        </resource>              </resources>

因為使用properties文件作為載體,所以上述的設置目的就是找到properties文件然后寫入版本號,我建了一個build_version.properties文件,里面寫了一個設置項:

build.version=${prefix.committedRevision}
${prefix.committedRevision}就可以獲取maven-svn-revision-number-plugin插件生成的版本號。

這樣設置好了后,使用Maven install就可以看到效果了,構造后在target目錄找到build_version.properties文件查看內容:
build.version=114912

此時就變成了一個數字。

 

在此看一看maven-svn-revision-number-plugin插件中會產生哪些變量:

[INFO] --- maven-svn-revision-number-plugin:1.7:revision (default) @ zrtc ---[INFO] inspecting E:/workspace/web[INFO]   prefix = prefix[INFO]   depth = empty[INFO]   report unversioned = true[INFO]   report ignored = false[INFO]   report out-of-date = false[INFO]  collecting status information[INFO]       114969 114912 E:/workspace/web[INFO]  setting properties[INFO]   prefix.repository = [INFO]   prefix.path = [INFO]   prefix.revision = 114969[INFO]   prefix.mixedRevisions = false[INFO]   prefix.committedRevision = 114912[INFO]   prefix.committedDate = 2015-10-23 09:03:39 +0800 (Fri, 23 Oct 2015)[INFO]   prefix.status = [INFO]   prefix.specialStatus = 

可以看到插件有幾個變量,其中我使用了committedRevision,這個就是項目svn目錄最后一次提交的版本。revision 則是svn最新的版本號。在其他文件使用時需要加上prefix.這個前綴,這是在配置文件中定義過的,可以看上面的配置內容。

<prefix>prefix</prefix><!-- 版本戳的前綴-->

這個前綴自己取名就可以了。

 

自此功能完成,解決了資源版本更新的問題??纯礊g覽器前端頁面源代碼:

<link rel="stylesheet" href="/css/h_login.css?ver=114912" type="text/css">

 

未來的目標

  最近因為解決前端客戶端資源更新的問題也看到了一些更好的方法,比如F.I.S這種前端工程構建工具。在了解的過程中知道了一個前端工程化的概念,有些大,但確實是未來的一種發展趨勢。在B/S開發越來越深入的階段,瀏覽器+服務器的這種開發平臺已經證明了其優越性,移動互聯網、云計算都已經體現了這種發展趨勢。而瀏覽器是最近10年人們用的最多的軟件了吧?而且瀏覽器已經證明了其無所不能,基于HTML+CSS就可以實現無數美秒的界面,原先常見的商業系統都也搬到了B/S架構下。可見HTML是多么牛逼的開發平臺。

  站在這個時代如果還不能做點和時代相關的事情是不是感覺有點過時?所以在未來要思考一下前端系統的模塊化,最終實現工程化。

 

 


上一篇:006TheFuctionsInJAVA

下一篇:005TheObjectInJAVA

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
性色av一区二区三区| 久久精品国产2020观看福利| 国产91精品最新在线播放| 亚洲精品美女网站| 2023亚洲男人天堂| 性色av一区二区咪爱| 欧美色xxxx| 亚洲国产91精品在线观看| 亚洲综合在线中文字幕| 奇米成人av国产一区二区三区| 国产精品男人爽免费视频1| 日韩精品免费综合视频在线播放| 欧美人与性动交| 97在线免费视频| 日韩欧美一区二区在线| 欧美在线精品免播放器视频| 国产精品午夜国产小视频| 性欧美亚洲xxxx乳在线观看| 日韩大陆毛片av| 国产精品夜间视频香蕉| 色综合五月天导航| 国产精品美女无圣光视频| 97精品国产aⅴ7777| 在线观看欧美成人| 91av国产在线| 日韩欧美在线字幕| 国产成人福利网站| 日韩欧美a级成人黄色| 中文字幕av一区二区| 高清欧美一区二区三区| www.国产精品一二区| 中文日韩在线观看| 日韩成人在线视频网站| 成人免费自拍视频| 国产精品日韩在线一区| 国产99视频精品免视看7| 亚洲精选在线观看| 久久久久亚洲精品成人网小说| 最近2019中文字幕在线高清| 久久国产精品久久久| 国产噜噜噜噜久久久久久久久| 色综合影院在线| 日本久久久久久久久| 亚洲第五色综合网| 久久99久久久久久久噜噜| 久久全球大尺度高清视频| 97欧美精品一区二区三区| 欧美精品激情视频| 国产精品一区二区久久精品| 国产日韩欧美在线播放| 亚洲白拍色综合图区| 国产成人+综合亚洲+天堂| 国产精品美女主播在线观看纯欲| 91av在线免费观看视频| 久久久亚洲网站| 午夜精品久久久久久99热软件| 成人免费在线网址| 亚洲资源在线看| 深夜成人在线观看| 在线视频日韩精品| 欧美成人亚洲成人日韩成人| www.精品av.com| 国产欧美在线观看| 久久久久久久久久久久久久久久久久av| 亚洲欧美精品在线| 欧美国产日本高清在线| 国产丝袜视频一区| 欧美国产精品日韩| 国产一区av在线| 亚洲理论片在线观看| 国产综合福利在线| 亚洲精品永久免费| 久久久亚洲网站| 欧美性开放视频| 九色精品免费永久在线| 亚洲综合第一页| 色偷偷9999www| 伊人成人开心激情综合网| 91tv亚洲精品香蕉国产一区7ujn| 伊人男人综合视频网| 国精产品一区一区三区有限在线| 亚洲色图15p| 亚洲欧美另类中文字幕| 亚洲人成绝费网站色www| 在线观看日韩av| 国产精品欧美在线| 中文字幕一区电影| 欧美精品一区二区三区国产精品| 欧美午夜精品久久久久久久| 欧美尤物巨大精品爽| 日韩视频免费在线| 日韩亚洲第一页| 欧美人与性动交| 热门国产精品亚洲第一区在线| 亚洲精品一区二三区不卡| 97在线视频免费观看| 精品亚洲一区二区三区在线播放| 亚洲人永久免费| 国内精品在线一区| 色中色综合影院手机版在线观看| 一本色道久久88综合日韩精品| 久久久www成人免费精品张筱雨| 欧美激情一区二区三区在线视频观看| 亚洲精品国产精品久久清纯直播| 欧美午夜片在线免费观看| 亚洲色图校园春色| 91久久精品视频| 国产精品视频在线观看| 国产精品6699| 久久这里有精品视频| 国产视频999| 久久精品国产电影| 亚洲精品自拍第一页| 98午夜经典影视| 欧美激情在线有限公司| 国产精品久久久久久婷婷天堂| 国产国语videosex另类| 亚洲国产精品嫩草影院久久| 欧美日韩在线观看视频小说| 国产精品吹潮在线观看| 中文字幕日韩精品有码视频| 久久精品国产精品| 久久艹在线视频| 538国产精品视频一区二区| 91国偷自产一区二区三区的观看方式| 91久久久久久久| 国产精品偷伦一区二区| 亚洲精品欧美一区二区三区| 国产精品高清免费在线观看| 色av中文字幕一区| 亚洲欧美日韩另类| 伊人久久精品视频| 国产精品精品久久久久久| 911国产网站尤物在线观看| 成人欧美一区二区三区黑人孕妇| 日韩视频在线免费| 在线观看国产精品日韩av| 55夜色66夜色国产精品视频| 久久久久久久久电影| 亚洲成人激情在线| 国产精品丝袜久久久久久不卡| 国产欧美欧洲在线观看| 国产视频福利一区| 国产在线999| 欧美午夜激情小视频| 国产午夜精品一区二区三区| 国产精品一区二区久久国产| 欧美激情视频在线观看| 中文字幕亚洲图片| 欧美日韩国产一区中文午夜| 欧美精品久久久久久久| 久久夜色精品亚洲噜噜国产mv| 欧美高清电影在线看| 久久久久北条麻妃免费看| 超碰日本道色综合久久综合| 亚洲一区二区三区乱码aⅴ| 91免费版网站入口| 欧美性精品220| 国语自产精品视频在线看一大j8| 久久久久国色av免费观看性色| 国产做受69高潮| 久久人人爽人人爽爽久久| 欧美福利视频网站| 日韩中文字幕在线免费观看|