web-dev-qa-db-ja.com

ブラウザの種類とそのバージョンを検出する方法

railsでブラウザーの種類とそのバージョンを検出する方法特定のブラウザのバージョンを確認し、必要でないブラウザバージョンの場合は、ユーザーにアップグレードを依頼するよりもチェックしたいのですが、以下のコマンドを使用しますが、標準のパターンに従っていないため、使用できません。

request.env['HTTP_USER_AGENT'] 

Chrome out put is below
Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/534.16 (KHTML, like Gecko) Chrome/10.0.648.205 Safari/534.16
Safari out put is below
Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/533.21.1 (KHTML, like Gecko) Version/5.0.5 Safari/533.21.1
FireFox out put is below
Mozilla/5.0 (Windows NT 5.1; rv:2.0) Gecko/20100101 Firefox/4.0
Opera out put is below
Opera/9.80 (Windows NT 5.1; U; en) Presto/2.8.131 Version/11.10
Internet Explorer out put is below
Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; .NET CLR 2.0.50727)
28
Syed Raza

ブラウザの宝石を試してください。非常にシンプルで目的を解決できます。

あなたは宝石を見つけることができます ここ 非常に使いやすいです。

26

注:一部の検索エンジンでは、これを侵入の一種と見なすように注意してください(Google HTTP USER AGENTを参照)

 if request.env['HTTP_USER_AGENT'] =~ /[^\(]*[^\)]Chrome\//

またはFirefoxの場合

if request.env['HTTP_USER_AGENT'] =~ /[^\(]*[^\)]*[^\t]Firefox\//

これを確認すると、必要なものがすべて手に入ります browser Gem

browsers_detection_gem

ここにすべてのブラウザを検出できるメソッドがあります

def browser_detection
  result = request.env['HTTP_USER_AGENT']
  browser_compatible = ''
  if result =~ /Safari/
    unless result =~ /Chrome/
      version = result.split('Version/')[1].split(' ').first.split('.').first
      browser_compatible = 'Application is not functional for Safari version\'s '+version if version.to_i < 5
    else
      version = result.split('Chrome/')[1].split(' ').first.split('.').first
      browser_compatible = 'Application is not functional for Chrome version\'s '+version if version.to_i < 10
    end
  elsif result =~ /Firefox/
    version = result.split('Firefox/')[1].split('.').first
    browser_compatible = 'Application is not functional for Firefox version\'s '+version if version.to_i < 5
  elsif result =~ /Opera/
    version = result.split('Version/')[1].split('.').first
    browser_compatible = 'Application is not functional for Opera version\'s '+version if version.to_i < 11
  elsif result =~ /MSIE/
    version = result.split('MSIE')[1].split(' ').first
    browser_compatible = 'Application is not functional for Microsoft Internet Explorer version\'s '+version if version.to_i < 9
  end
  browser_compatible
end
27
TH Afridi

seragent gemもあります:

<% user_agent = UserAgent.parse(request.env["HTTP_USER_AGENT"]) %>
App: <%= user_agent.application %> # Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:22.0)
Browser: <%= user_agent.browser %> # Firefox
Version: <%= user_agent.version %> # 22.0
Platform: <%= user_agent.platform %> # Macintosh
Mobile: <%= user_agent.mobile? %> # False
OS: <%= user_agent.os %> # OS X 10.8
9
Chris Edwards

あなたがすることは実際にはそれを行う方法です。これで、正規表現を使用してユーザーエージェント情報を処理し、Firefox、Chrome、または他の任意のブラウザやバージョンでの一致を探すことができます。

3
Spyros

これはフロントエンドソリューションですが、フレックスボックスなど、必要な特定の機能を確認することをお勧めします。 Modernizr のようなものを使用するか、単純なJavaScriptチェックで実行できます( https://stackoverflow.com/a/27047981/179311 )。

if(!("flexWrap" in document.documentElement.style)) {
    // IE 10, Chrome 20 and Firefox 27 and anything older will hit this.
    alert('your browser is out of date');
    // maybe this is preferred
    // window.location = '/browser-unsupported'
}
0
bradlis7