曾自己借助阿里云和hexo搭了個站點(diǎn),現(xiàn)已廢棄,過往寫的博客暫挪到此處。
title: 關(guān)于UserAgent解析的一點(diǎn)事
date: 2016-12-09 13:02:56
tags:
- 技術(shù)
- Javascript
- 瀏覽器
- TODO
1. ? 可以解析什么數(shù)據(jù)?
browserengineosdevicecpu
2. ?想全面解析,可能么?
幾乎不可能。
尤其是設(shè)備,全球設(shè)備太多,除了手機(jī),平板眾多,甚至包括智能電視,可穿戴設(shè)備,等等。就算有全球所有設(shè)備的useragent的庫,需要?dú)w納總結(jié),也不是十天半個月可以解析完的。
有一個針對browser的庫,可能不全 https://www.whatismybrowser.com/developers/tools/user-agent-parser/browse
3. ?網(wǎng)上的輪子
https://github.com/faisalman/ua-parser-js/blob/master/src/ua-parser.js
和百度前端團(tuán)隊(duì)的
https://github.com/fex-team/userAgent/blob/master/node_modules/useragent_base.js
https://github.com/fex-team/userAgent/blob/master/node_modules/useragent.js
對比
百度前端團(tuán)隊(duì)的
- 1)百度有大量的if else語句,完全不想看
問題:將if else語句用一張map(一個對象)代替,更易閱讀,但是多了很多遍歷,有無必要? - 2)百度是針對每個不同的類型,比如device,是針對每個設(shè)備,都指定了對應(yīng)的正則。然后在這一張map里,以此去尋找?;蛘呤峭ㄟ^if else語句去尋找。
而 faisalman的代碼是通過將正則分類,去匹配,然后簡單的處理匹配后的結(jié)果,或者不必處理,即可得到最后我們想要的信息。兩個問題
- 1)某些情況下依然不得不通過窮舉的方式得到信息,比如獲取device。他沒有這樣的大量代碼,是因?yàn)樗緵]有去得到這樣詳盡的信息。
- 2)正則分類,那么前期需要對userAgent有大量的分析,才能分類。一個巨大的正則數(shù)組,同上面我提到的map是類似的,一個正則是對象中的一項(xiàng)。userAgent應(yīng)該來說不會修改,同一設(shè)備,同一操作系統(tǒng),同一瀏覽器,所對應(yīng)的userAgent應(yīng)該不會變,userAgent只會增加,新的設(shè)備,新的瀏覽器,所以有新的類型的userAgent。所以,這樣的map似乎足夠,不必?fù)?dān)心后期維護(hù)修改的問題。
- 3)現(xiàn)在還可以分類,正則匹配之后簡單處理就能得到對應(yīng)的信息,以后還能保持么?會不會還是需要大量的窮舉和遍歷。其實(shí)現(xiàn)在已經(jīng)有需要擁有大量數(shù)據(jù)的map了,前文說的device。
- 4)他的代碼中,正則分類 與 這類正則得到的信息和信息處理,分別位于數(shù)組的奇數(shù)和偶數(shù)位置。閱讀上會別扭,因?yàn)槠鏀?shù)和偶數(shù)位置上并不是同一種東西,破壞了我心目中對數(shù)組的印象,可以用對象遍歷。但是用對象是不是有些麻煩?遍歷數(shù)組比遍歷對象更方便,并且數(shù)組之間的對應(yīng)關(guān)系比較清晰,可以按順序?qū)?yīng)(由于用到了正則的分組,每個分組對應(yīng)所想獲取的不同信息,比如name和version),而對象,必須指定,所以又多了些對應(yīng)關(guān)系,雖說可能更清晰,但實(shí)際更復(fù)雜了。這樣有無必要?
4.? 問題:為什么這倆輪子不約而同的不檢測PC端的設(shè)備,只有移動端有設(shè)備?
- 1)沒有必要,因?yàn)樵赑C端,瀏覽器的安裝由操作系統(tǒng)決定,不同設(shè)備的PC,操作系統(tǒng)也就那些。而在移動端,尤其是安卓,不同設(shè)備對應(yīng)不同公司有不同的操作系統(tǒng)。
- 2)也不可靠,比如雙系統(tǒng)。在這種情況下,獲取不到確切的設(shè)備。
- 3)是不是在PC瀏覽器就沒有權(quán)限獲取設(shè)備,或者就不會去獲取設(shè)備?而在移動端都會去獲取設(shè)備?否則怎會有2)的問題。畢竟userAgent是瀏覽器提供的。(疑問,擱置,不能再深究下去了)