
org.ocpsoft.rewrite.servlet.config.UserAgentUtil Maven / Gradle / Ivy
/* *******************************************
// Copyright 2010-2013, Anthony Hand
//
// File version 2013.08.01 (August 1, 2013)
// Updates:
// - Updated DetectMobileQuick(). Moved the 'Exclude Tablets' logic to the top of the method to fix a logic bug.
//
// File version 2013.07.13 (July 13, 2013)
// Updates:
// - Added support for Tizen: variable and DetectTizen().
// - Added support for Meego: variable and DetectMeego().
// - Added support for Windows Phone 8: variable and DetectWindowsPhone8().
// - Added a generic Windows Phone method: DetectWindowsPhone().
// - Added support for BlackBerry 10 OS: variable and DetectBlackBerry10Phone().
// - Added support for PlayStation Vita handheld: variable and DetectGamingHandheld().
// - Updated DetectTierIphone(). Added Tizen; updated the Windows Phone, BB10, and PS Vita support.
// - Updated DetectWindowsMobile(). Uses generic DetectWindowsPhone() method rather than WP7.
// - Updated DetectSmartphone(). Uses the detectTierIphone() method.
// - Updated DetectSonyMylo() with more efficient code.
// - Removed DetectGarminNuvifone() from DetectTierIphone(). How many are left in market in 2013? It is detected as a RichCSS Tier device.
// - Removed the deviceXoom variable. It was unused.
// - Added detection support for the Obigo mobile browser to DetectMobileQuick().
//
//
//
// LICENSE INFORMATION
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
// either express or implied. See the License for the specific
// language governing permissions and limitations under the License.
//
//
// ABOUT THIS PROJECT
// Project Owner: Anthony Hand
// Email: [email protected]
// Web Site: http://www.mobileesp.com
// Source Files: http://code.google.com/p/mobileesp/
//
// Versions of this code are available for:
// PHP, JavaScript, Java, ASP.NET (C#), and Ruby
//
// *******************************************
*/
package org.ocpsoft.rewrite.servlet.config;
/**
* The DetectSmartPhone class encapsulates information about a browser's connection to your web site. You can use it to
* find out whether the browser asking for your site's content is probably running on a mobile device. The methods were
* written so you can be as granular as you want. For example, enquiring whether it's as specific as an iPod Touch or as
* general as a smartphone class device. The object's methods return true, or false.
*/
public class UserAgentUtil
{
// User-Agent and Accept HTTP request headers
private String userAgent = "";
private String httpAccept = "";
// Let's store values for quickly accessing the same info multiple times.
public boolean initCompleted = false;
public boolean isWebkit = false; // Stores the result of DetectWebkit()
public boolean isMobilePhone = false; // Stores the result of DetectMobileQuick()
public boolean isIphone = false; // Stores the result of DetectIphone()
public boolean isAndroid = false; // Stores the result of DetectAndroid()
public boolean isAndroidPhone = false; // Stores the result of DetectAndroidPhone()
public boolean isTierTablet = false; // Stores the result of DetectTierTablet()
public boolean isTierIphone = false; // Stores the result of DetectTierIphone()
public boolean isTierRichCss = false; // Stores the result of DetectTierRichCss()
public boolean isTierGenericMobile = false; // Stores the result of DetectTierOtherPhones()
// Initialize some initial smartphone string variables.
public static final String engineWebKit = "webkit";
public static final String deviceIphone = "iphone";
public static final String deviceIpod = "ipod";
public static final String deviceIpad = "ipad";
public static final String deviceMacPpc = "macintosh"; // Used for disambiguation
public static final String deviceAndroid = "android";
public static final String deviceGoogleTV = "googletv";
public static final String deviceHtcFlyer = "htc_flyer"; // HTC Flyer
public static final String deviceWinPhone7 = "windows phone os 7";
public static final String deviceWinPhone8 = "windows phone 8";
public static final String deviceWinMob = "windows ce";
public static final String deviceWindows = "windows";
public static final String deviceIeMob = "iemobile";
public static final String devicePpc = "ppc"; // Stands for PocketPC
public static final String enginePie = "wm5 pie"; // An old Windows Mobile
public static final String deviceBB = "blackberry";
public static final String deviceBB10 = "bb10"; // For the new BB 10 OS
public static final String vndRIM = "vnd.rim"; // Detectable when BB devices emulate IE or Firefox
public static final String deviceBBStorm = "blackberry95"; // Storm 1 and 2
public static final String deviceBBBold = "blackberry97"; // Bold 97x0 (non-touch)
public static final String deviceBBBoldTouch = "blackberry 99"; // Bold 99x0 (touchscreen)
public static final String deviceBBTour = "blackberry96"; // Tour
public static final String deviceBBCurve = "blackberry89"; // Curve 2
public static final String deviceBBCurveTouch = "blackberry 938"; // Curve Touch 9380
public static final String deviceBBTorch = "blackberry 98"; // Torch
public static final String deviceBBPlaybook = "playbook"; // PlayBook tablet
public static final String deviceSymbian = "symbian";
public static final String deviceS60 = "series60";
public static final String deviceS70 = "series70";
public static final String deviceS80 = "series80";
public static final String deviceS90 = "series90";
public static final String devicePalm = "palm";
public static final String deviceWebOS = "webos"; // For Palm's line of WebOS devices
public static final String deviceWebOShp = "hpwos"; // For HP's line of WebOS devices
public static final String engineBlazer = "blazer"; // Old Palm
public static final String engineXiino = "xiino"; // Another old Palm
public static final String deviceNuvifone = "nuvifone"; // Garmin Nuvifone
public static final String deviceBada = "bada"; // Samsung's Bada OS
public static final String deviceTizen = "tizen"; // Tizen OS
public static final String deviceMeego = "meego"; // Meego OS
public static final String deviceKindle = "kindle"; // Amazon Kindle, eInk one
public static final String engineSilk = "silk-accelerated"; // Amazon's accelerated Silk browser for Kindle Fire
// Initialize variables for mobile-specific content.
public static final String vndwap = "vnd.wap";
public static final String wml = "wml";
// Initialize variables for other random devices and mobile browsers.
public static final String deviceTablet = "tablet"; // Generic term for slate and tablet devices
public static final String deviceBrew = "brew";
public static final String deviceDanger = "danger";
public static final String deviceHiptop = "hiptop";
public static final String devicePlaystation = "playstation";
public static final String devicePlaystationVita = "vita";
public static final String deviceNintendoDs = "nitro";
public static final String deviceNintendo = "nintendo";
public static final String deviceWii = "wii";
public static final String deviceXbox = "xbox";
public static final String deviceArchos = "archos";
public static final String engineOpera = "opera"; // Popular browser
public static final String engineNetfront = "netfront"; // Common embedded OS browser
public static final String engineUpBrowser = "up.browser"; // common on some phones
public static final String engineOpenWeb = "openweb"; // Transcoding by OpenWave server
public static final String deviceMidp = "midp"; // a mobile Java technology
public static final String uplink = "up.link";
public static final String engineTelecaQ = "teleca q"; // a modern feature phone browser
public static final String engineObigo = "obigo"; // W 10 is a modern feature phone browser
public static final String devicePda = "pda"; // some devices report themselves as PDAs
public static final String mini = "mini"; // Some mobile browsers put "mini" in their names.
public static final String mobile = "mobile"; // Some mobile browsers put "mobile" in their user agent strings.
public static final String mobi = "mobi"; // Some mobile browsers put "mobi" in their user agent strings.
// Use Maemo, Tablet, and Linux to test for Nokia"s Internet Tablets.
public static final String maemo = "maemo";
public static final String linux = "linux";
public static final String qtembedded = "qt embedded"; // for Sony Mylo
public static final String mylocom2 = "com2"; // for Sony Mylo also
// In some UserAgents, the only clue is the manufacturer.
public static final String manuSonyEricsson = "sonyericsson";
public static final String manuericsson = "ericsson";
public static final String manuSamsung1 = "sec-sgh";
public static final String manuSony = "sony";
public static final String manuHtc = "htc";
// In some UserAgents, the only clue is the operator.
public static final String svcDocomo = "docomo";
public static final String svcKddi = "kddi";
public static final String svcVodafone = "vodafone";
// Disambiguation strings.
public static final String disUpdate = "update"; // pda vs. update
/**
* Initialize the userAgent and httpAccept variables
*
* @param userAgent the User-Agent header
* @param httpAccept the Accept header
*/
public UserAgentUtil(String userAgent, String httpAccept)
{
if (userAgent != null) {
this.userAgent = userAgent.toLowerCase();
}
if (httpAccept != null) {
this.httpAccept = httpAccept.toLowerCase();
}
// Intialize key stored values.
initDeviceScan();
}
/**
* Return the lower case HTTP_USER_AGENT
*
* @return userAgent
*/
public String getUserAgent()
{
return userAgent;
}
/**
* Return the lower case HTTP_ACCEPT
*
* @return httpAccept
*/
public String getHttpAccept()
{
return httpAccept;
}
/**
* Return whether the device is an Iphone or iPod Touch
*
* @return isIphone
*/
public boolean getIsIphone()
{
return isIphone;
}
/**
* Return whether the device is in the Tablet Tier.
*
* @return isTierTablet
*/
public boolean getIsTierTablet()
{
return isTierTablet;
}
/**
* Return whether the device is in the Iphone Tier.
*
* @return isTierIphone
*/
public boolean getIsTierIphone()
{
return isTierIphone;
}
/**
* Return whether the device is in the 'Rich CSS' tier of mobile devices.
*
* @return isTierRichCss
*/
public boolean getIsTierRichCss()
{
return isTierRichCss;
}
/**
* Return whether the device is a generic, less-capable mobile device.
*
* @return isTierGenericMobile
*/
public boolean getIsTierGenericMobile()
{
return isTierGenericMobile;
}
/**
* Initialize Key Stored Values.
*/
public void initDeviceScan()
{
// Save these properties to speed processing
this.isWebkit = detectWebkit();
this.isIphone = detectIphone();
this.isAndroid = detectAndroid();
this.isAndroidPhone = detectAndroidPhone();
// Generally, these tiers are the most useful for web development
this.isMobilePhone = detectMobileQuick();
this.isTierTablet = detectTierTablet();
this.isTierIphone = detectTierIphone();
// Optional: Comment these out if you NEVER use them
this.isTierRichCss = detectTierRichCss();
this.isTierGenericMobile = detectTierOtherPhones();
this.initCompleted = true;
}
/**
* Detects if the current device is an iPhone.
*
* @return detection of an iPhone
*/
public boolean detectIphone()
{
if ((this.initCompleted == true) ||
(this.isIphone == true))
return this.isIphone;
// The iPad and iPod touch say they're an iPhone! So let's disambiguate.
if (userAgent.indexOf(deviceIphone) != -1 &&
!detectIpad() &&
!detectIpod()) {
return true;
}
return false;
}
/**
* Detects if the current device is an iPod Touch.
*
* @return detection of an iPod Touch
*/
public boolean detectIpod()
{
if (userAgent.indexOf(deviceIpod) != -1) {
return true;
}
return false;
}
/**
* Detects if the current device is an iPad tablet.
*
* @return detection of an iPad
*/
public boolean detectIpad()
{
if (userAgent.indexOf(deviceIpad) != -1
&& detectWebkit()) {
return true;
}
return false;
}
/**
* Detects if the current device is an iPhone or iPod Touch.
*
* @return detection of an iPhone or iPod Touch
*/
public boolean detectIphoneOrIpod()
{
// We repeat the searches here because some iPods may report themselves as an iPhone, which would be okay.
if (userAgent.indexOf(deviceIphone) != -1
|| userAgent.indexOf(deviceIpod) != -1) {
return true;
}
return false;
}
/**
* Detects *any* iOS device: iPhone, iPod Touch, iPad.
*
* @return detection of an Apple iOS device
*/
public boolean detectIos()
{
if (detectIphoneOrIpod() || detectIpad()) {
return true;
}
return false;
}
/**
* Detects *any* Android OS-based device: phone, tablet, and multi-media player. Also detects Google TV.
*
* @return detection of an Android device
*/
public boolean detectAndroid()
{
if ((this.initCompleted == true) ||
(this.isAndroid == true))
return this.isAndroid;
if ((userAgent.indexOf(deviceAndroid) != -1) ||
detectGoogleTV())
return true;
// Special check for the HTC Flyer 7" tablet. It should report here.
if (userAgent.indexOf(deviceHtcFlyer) != -1)
return true;
return false;
}
/**
* Detects if the current device is a (small-ish) Android OS-based device used for calling and/or multi-media (like a
* Samsung Galaxy Player). Google says these devices will have 'Android' AND 'mobile' in user agent. Ignores tablets
* (Honeycomb and later).
*
* @return detection of an Android phone
*/
public boolean detectAndroidPhone()
{
if ((this.initCompleted == true) ||
(this.isAndroidPhone == true))
return this.isAndroidPhone;
if (detectAndroid() && (userAgent.indexOf(mobile) != -1))
return true;
// Special check for Android phones with Opera Mobile. They should report here.
if (detectOperaAndroidPhone())
return true;
// Special check for the HTC Flyer 7" tablet. It should report here.
if (userAgent.indexOf(deviceHtcFlyer) != -1)
return true;
return false;
}
/**
* Detects if the current device is a (self-reported) Android tablet. Google says these devices will have 'Android'
* and NOT 'mobile' in their user agent.
*
* @return detection of an Android tablet
*/
public boolean detectAndroidTablet()
{
// First, let's make sure we're on an Android device.
if (!detectAndroid())
return false;
// Special check for Opera Android Phones. They should NOT report here.
if (detectOperaMobile())
return false;
// Special check for the HTC Flyer 7" tablet. It should NOT report here.
if (userAgent.indexOf(deviceHtcFlyer) != -1)
return false;
// Otherwise, if it's Android and does NOT have 'mobile' in it, Google says it's a tablet.
if ((userAgent.indexOf(mobile) > -1))
return false;
else
return true;
}
/**
* Detects if the current device is an Android OS-based device and the browser is based on WebKit.
*
* @return detection of an Android WebKit browser
*/
public boolean detectAndroidWebKit()
{
if (detectAndroid() && detectWebkit()) {
return true;
}
return false;
}
/**
* Detects if the current device is a GoogleTV.
*
* @return detection of GoogleTV
*/
public boolean detectGoogleTV()
{
if (userAgent.indexOf(deviceGoogleTV) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is based on WebKit.
*
* @return detection of a WebKit browser
*/
public boolean detectWebkit()
{
if ((this.initCompleted == true) ||
(this.isWebkit == true))
return this.isWebkit;
if (userAgent.indexOf(engineWebKit) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is EITHER a Windows Phone 7.x OR 8 device
*
* @return detection of Windows Phone 7.x OR 8
*/
public boolean detectWindowsPhone()
{
if (detectWindowsPhone7() || detectWindowsPhone8()) {
return true;
}
return false;
}
/**
* Detects a Windows Phone 7.x device (in mobile browsing mode).
*
* @return detection of Windows Phone 7
*/
public boolean detectWindowsPhone7()
{
if (userAgent.indexOf(deviceWinPhone7) != -1) {
return true;
}
return false;
}
/**
* Detects a Windows Phone 8 device (in mobile browsing mode).
*
* @return detection of Windows Phone 8
*/
public boolean detectWindowsPhone8()
{
if (userAgent.indexOf(deviceWinPhone8) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is a Windows Mobile device. Excludes Windows Phone 7.x and 8 devices. Focuses on
* Windows Mobile 6.xx and earlier.
*
* @return detection of Windows Mobile
*/
public boolean detectWindowsMobile()
{
if (detectWindowsPhone()) {
return false;
}
// Most devices use 'Windows CE', but some report 'iemobile'
// and some older ones report as 'PIE' for Pocket IE.
// We also look for instances of HTC and Windows for many of their WinMo devices.
if (userAgent.indexOf(deviceWinMob) != -1
|| userAgent.indexOf(deviceWinMob) != -1
|| userAgent.indexOf(deviceIeMob) != -1
|| userAgent.indexOf(enginePie) != -1
|| (userAgent.indexOf(manuHtc) != -1 && userAgent.indexOf(deviceWindows) != -1)
|| (detectWapWml() && userAgent.indexOf(deviceWindows) != -1)) {
return true;
}
// Test for Windows Mobile PPC but not old Macintosh PowerPC.
if (userAgent.indexOf(devicePpc) != -1 &&
!(userAgent.indexOf(deviceMacPpc) != -1))
return true;
return false;
}
/**
* Detects if the current browser is any BlackBerry. Includes BB10 OS, but excludes the PlayBook.
*
* @return detection of Blackberry
*/
public boolean detectBlackBerry()
{
if (userAgent.indexOf(deviceBB) != -1 ||
httpAccept.indexOf(vndRIM) != -1)
return true;
if (detectBlackBerry10Phone())
return true;
return false;
}
/**
* Detects if the current browser is a BlackBerry 10 OS phone. Excludes tablets.
*
* @return detection of a Blackberry 10 device
*/
public boolean detectBlackBerry10Phone()
{
if (userAgent.indexOf(deviceBB10) != -1 &&
userAgent.indexOf(mobile) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is on a BlackBerry tablet device. Example: PlayBook
*
* @return detection of a Blackberry Tablet
*/
public boolean detectBlackBerryTablet()
{
if (userAgent.indexOf(deviceBBPlaybook) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is a BlackBerry device AND uses a WebKit-based browser. These are signatures for
* the new BlackBerry OS 6. Examples: Torch. Includes the Playbook.
*
* @return detection of a Blackberry device with WebKit browser
*/
public boolean detectBlackBerryWebKit()
{
if (detectBlackBerry() && detectWebkit())
return true;
return false;
}
/**
* Detects if the current browser is a BlackBerry Touch device, such as the Storm, Torch, and Bold Touch. Excludes
* the Playbook.
*
* @return detection of a Blackberry touchscreen device
*/
public boolean detectBlackBerryTouch()
{
if (detectBlackBerry() &&
(userAgent.indexOf(deviceBBStorm) != -1 ||
userAgent.indexOf(deviceBBTorch) != -1 ||
userAgent.indexOf(deviceBBBoldTouch) != -1 ||
userAgent.indexOf(deviceBBCurveTouch) != -1)) {
return true;
}
return false;
}
/**
* Detects if the current browser is a BlackBerry device AND has a more capable recent browser. Excludes the
* Playbook. Examples, Storm, Bold, Tour, Curve2 Excludes the new BlackBerry OS 6 and 7 browser!!
*
* @return detection of a Blackberry device with a better browser
*/
public boolean detectBlackBerryHigh()
{
// Disambiguate for BlackBerry OS 6 or 7 (WebKit) browser
if (detectBlackBerryWebKit())
return false;
if (detectBlackBerry()) {
if (detectBlackBerryTouch()
|| userAgent.indexOf(deviceBBBold) != -1
|| userAgent.indexOf(deviceBBTour) != -1
|| userAgent.indexOf(deviceBBCurve) != -1) {
return true;
}
else {
return false;
}
}
else {
return false;
}
}
/**
* Detects if the current browser is a BlackBerry device AND has an older, less capable browser. Examples: Pearl,
* 8800, Curve1
*
* @return detection of a Blackberry device with a poorer browser
*/
public boolean detectBlackBerryLow()
{
if (detectBlackBerry()) {
// Assume that if it's not in the High tier, then it's Low
if (detectBlackBerryHigh()
|| detectBlackBerryWebKit()) {
return false;
}
else {
return true;
}
}
else {
return false;
}
}
/**
* Detects if the current browser is the Symbian S60 Open Source Browser.
*
* @return detection of Symbian S60 Browser
*/
public boolean detectS60OssBrowser()
{
// First, test for WebKit, then make sure it's either Symbian or S60.
if (detectWebkit()
&& (userAgent.indexOf(deviceSymbian) != -1
|| userAgent.indexOf(deviceS60) != -1)) {
return true;
}
return false;
}
/**
*
* Detects if the current device is any Symbian OS-based device, including older S60, Series 70, Series 80, Series
* 90, and UIQ, or other browsers running on these devices.
*
* @return detection of SymbianOS
*/
public boolean detectSymbianOS()
{
if (userAgent.indexOf(deviceSymbian) != -1
|| userAgent.indexOf(deviceS60) != -1
|| userAgent.indexOf(deviceS70) != -1
|| userAgent.indexOf(deviceS80) != -1
|| userAgent.indexOf(deviceS90) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is on a PalmOS device.
*
* @return detection of a PalmOS device
*/
public boolean detectPalmOS()
{
// Make sure it's not WebOS first
if (detectPalmWebOS())
return false;
// Most devices nowadays report as 'Palm', but some older ones reported as Blazer or Xiino.
if (userAgent.indexOf(devicePalm) != -1
|| userAgent.indexOf(engineBlazer) != -1
|| userAgent.indexOf(engineXiino) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is on a Palm device running the new WebOS.
*
* @return detection of a Palm WebOS device
*/
public boolean detectPalmWebOS()
{
if (userAgent.indexOf(deviceWebOS) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is on an HP tablet running WebOS.
*
* @return detection of an HP WebOS tablet
*/
public boolean detectWebOSTablet()
{
if (userAgent.indexOf(deviceWebOShp) != -1 &&
userAgent.indexOf(deviceTablet) != -1) {
return true;
}
return false;
}
/**
* Detects Opera Mobile or Opera Mini.
*
* @return detection of an Opera browser for a mobile device
*/
public boolean detectOperaMobile()
{
if (userAgent.indexOf(engineOpera) != -1
&& (userAgent.indexOf(mini) != -1
|| userAgent.indexOf(mobi) != -1)) {
return true;
}
return false;
}
/**
* Detects Opera Mobile on an Android phone.
*
* @return detection of an Opera browser on an Android phone
*/
public boolean detectOperaAndroidPhone()
{
if (userAgent.indexOf(engineOpera) != -1
&& (userAgent.indexOf(deviceAndroid) != -1
&& userAgent.indexOf(mobi) != -1)) {
return true;
}
return false;
}
/**
* Detects Opera Mobile on an Android tablet.
*
* @return detection of an Opera browser on an Android tablet
*/
public boolean detectOperaAndroidTablet()
{
if (userAgent.indexOf(engineOpera) != -1
&& (userAgent.indexOf(deviceAndroid) != -1
&& userAgent.indexOf(deviceTablet) != -1)) {
return true;
}
return false;
}
/**
* Detects if the current device is an Amazon Kindle (eInk devices only). Note: For the Kindle Fire, use the normal
* Android methods.
*
* @return detection of a Kindle
*/
public boolean detectKindle()
{
if (userAgent.indexOf(deviceKindle) != -1 &&
!detectAndroid()) {
return true;
}
return false;
}
/**
* Detects if the current Amazon device is using the Silk Browser. Note: Typically used by the the Kindle Fire.
*
* @return detection of an Amazon Kindle Fire in Silk mode.
*/
public boolean detectAmazonSilk()
{
if (userAgent.indexOf(engineSilk) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is a Garmin Nuvifone.
*
* @return detection of a Garmin Nuvifone
*/
public boolean detectGarminNuvifone()
{
if (userAgent.indexOf(deviceNuvifone) != -1) {
return true;
}
return false;
}
/**
* Detects a device running the Bada smartphone OS from Samsung.
*
* @return detection of a Bada device
*/
public boolean detectBada()
{
if (userAgent.indexOf(deviceBada) != -1) {
return true;
}
return false;
}
/**
* Detects a device running the Tizen smartphone OS.
*
* @return detection of a Tizen device
*/
public boolean detectTizen()
{
if (userAgent.indexOf(deviceTizen) != -1) {
return true;
}
return false;
}
/**
* Detects a device running the Meego OS.
*
* @return detection of a Meego device
*/
public boolean detectMeego()
{
if (userAgent.indexOf(deviceMeego) != -1) {
return true;
}
return false;
}
/**
* Detects the Danger Hiptop device.
*
* @return detection of a Danger Hiptop
*/
public boolean detectDangerHiptop()
{
if (userAgent.indexOf(deviceDanger) != -1
|| userAgent.indexOf(deviceHiptop) != -1) {
return true;
}
return false;
}
/**
* Detects if the current browser is a Sony Mylo device.
*
* @return detection of a Sony Mylo device
*/
public boolean detectSonyMylo()
{
if (userAgent.indexOf(manuSony) != -1
&& (userAgent.indexOf(qtembedded) != -1
|| userAgent.indexOf(mylocom2) != -1)) {
return true;
}
return false;
}
/**
* Detects if the current device is on one of the Maemo-based Nokia Internet Tablets.
*
* @return detection of a Maemo OS tablet
*/
public boolean detectMaemoTablet()
{
if (userAgent.indexOf(maemo) != -1) {
return true;
}
else if (userAgent.indexOf(linux) != -1
&& userAgent.indexOf(deviceTablet) != -1
&& !detectWebOSTablet()
&& !detectAndroid()) {
return true;
}
return false;
}
/**
* Detects if the current device is an Archos media player/Internet tablet.
*
* @return detection of an Archos media player
*/
public boolean detectArchos()
{
if (userAgent.indexOf(deviceArchos) != -1) {
return true;
}
return false;
}
/**
* Detects if the current device is an Internet-capable game console. Includes many handheld consoles.
*
* @return detection of any Game Console
*/
public boolean detectGameConsole()
{
if (detectSonyPlaystation()
|| detectNintendo()
|| detectXbox()) {
return true;
}
return false;
}
/**
* Detects if the current device is a Sony Playstation.
*
* @return detection of Sony Playstation
*/
public boolean detectSonyPlaystation()
{
if (userAgent.indexOf(devicePlaystation) != -1) {
return true;
}
return false;
}
/**
* Detects if the current device is a handheld gaming device with a touchscreen and modern iPhone-class browser.
* Includes the Playstation Vita.
*
* @return detection of a handheld gaming device
*/
public boolean detectGamingHandheld()
{
if ((userAgent.indexOf(devicePlaystation) != -1) &&
(userAgent.indexOf(devicePlaystationVita) != -1)) {
return true;
}
return false;
}
/**
* Detects if the current device is a Nintendo game device.
*
* @return detection of Nintendo
*/
public boolean detectNintendo()
{
if (userAgent.indexOf(deviceNintendo) != -1
|| userAgent.indexOf(deviceWii) != -1
|| userAgent.indexOf(deviceNintendoDs) != -1) {
return true;
}
return false;
}
/**
* Detects if the current device is a Microsoft Xbox.
*
* @return detection of Xbox
*/
public boolean detectXbox()
{
if (userAgent.indexOf(deviceXbox) != -1) {
return true;
}
return false;
}
/**
* Detects whether the device is a Brew-powered device.
*
* @return detection of a Brew device
*/
public boolean detectBrewDevice()
{
if (userAgent.indexOf(deviceBrew) != -1) {
return true;
}
return false;
}
/**
* Detects whether the device supports WAP or WML.
*
* @return detection of a WAP- or WML-capable device
*/
public boolean detectWapWml()
{
if (httpAccept.indexOf(vndwap) != -1
|| httpAccept.indexOf(wml) != -1) {
return true;
}
return false;
}
/**
* Detects if the current device supports MIDP, a mobile Java technology.
*
* @return detection of a MIDP mobile Java-capable device
*/
public boolean detectMidpCapable()
{
if (userAgent.indexOf(deviceMidp) != -1
|| httpAccept.indexOf(deviceMidp) != -1) {
return true;
}
return false;
}
// *****************************
// Device Classes
// *****************************
/**
* Check to see whether the device is any device in the 'smartphone' category.
*
* @return detection of a general smartphone device
*/
public boolean detectSmartphone()
{
// Exclude duplicates from TierIphone
return (detectTierIphone()
|| detectS60OssBrowser()
|| detectSymbianOS()
|| detectWindowsMobile()
|| detectBlackBerry()
|| detectPalmOS());
}
/**
* Detects if the current device is a mobile device. This method catches most of the popular modern devices. Excludes
* Apple iPads and other modern tablets.
*
* @return detection of any mobile device using the quicker method
*/
public boolean detectMobileQuick()
{
// Let's exclude tablets
if (detectTierTablet())
return false;
if ((initCompleted == true) ||
(isMobilePhone == true))
return isMobilePhone;
// Most mobile browsing is done on smartphones
if (detectSmartphone())
return true;
if (detectWapWml()
|| detectBrewDevice()
|| detectOperaMobile())
return true;
if ((userAgent.indexOf(engineObigo) != -1)
|| (userAgent.indexOf(engineNetfront) != -1)
|| (userAgent.indexOf(engineUpBrowser) != -1)
|| (userAgent.indexOf(engineOpenWeb) != -1))
return true;
if (detectDangerHiptop()
|| detectMidpCapable()
|| detectMaemoTablet()
|| detectArchos())
return true;
if ((userAgent.indexOf(devicePda) != -1) &&
(userAgent.indexOf(disUpdate) < 0)) // no index found
return true;
if (userAgent.indexOf(mobile) != -1)
return true;
// We also look for Kindle devices
if (detectKindle()
|| detectAmazonSilk())
return true;
return false;
}
/**
* The longer and more thorough way to detect for a mobile device. Will probably detect most feature phones,
* smartphone-class devices, Internet Tablets, Internet-enabled game consoles, etc. This ought to catch a lot of the
* more obscure and older devices, also -- but no promises on thoroughness!
*
* @return detection of any mobile device using the more thorough method
*/
public boolean detectMobileLong()
{
if (detectMobileQuick()
|| detectGameConsole()
|| detectSonyMylo()) {
return true;
}
// detect older phones from certain manufacturers and operators.
if (userAgent.indexOf(uplink) != -1)
return true;
if (userAgent.indexOf(manuSonyEricsson) != -1)
return true;
if (userAgent.indexOf(manuericsson) != -1)
return true;
if (userAgent.indexOf(manuSamsung1) != -1)
return true;
if (userAgent.indexOf(svcDocomo) != -1)
return true;
if (userAgent.indexOf(svcKddi) != -1)
return true;
if (userAgent.indexOf(svcVodafone) != -1)
return true;
return false;
}
// *****************************
// For Mobile Web Site Design
// *****************************
/**
* The quick way to detect for a tier of devices. This method detects for the new generation of HTML 5 capable,
* larger screen tablets. Includes iPad, Android (e.g., Xoom), BB Playbook, WebOS, etc.
*
* @return detection of any device in the Tablet Tier
*/
public boolean detectTierTablet()
{
if ((this.initCompleted == true) ||
(this.isTierTablet == true))
return this.isTierTablet;
if (detectIpad()
|| detectAndroidTablet()
|| detectBlackBerryTablet()
|| detectWebOSTablet()) {
return true;
}
return false;
}
/**
* The quick way to detect for a tier of devices. This method detects for devices which can display iPhone-optimized
* web content. Includes iPhone, iPod Touch, Android, Windows Phone 7 and 8, BB10, WebOS, Playstation Vita, etc.
*
* @return detection of any device in the iPhone/Android/Windows Phone/BlackBerry/WebOS Tier
*/
public boolean detectTierIphone()
{
if ((this.initCompleted == true) ||
(this.isTierIphone == true))
return this.isTierIphone;
if (detectIphoneOrIpod()
|| detectAndroidPhone()
|| detectWindowsPhone()
|| detectBlackBerry10Phone()
|| (detectBlackBerryWebKit()
&& detectBlackBerryTouch())
|| detectPalmWebOS()
|| detectBada()
|| detectTizen()
|| detectGamingHandheld()) {
return true;
}
return false;
}
/**
* The quick way to detect for a tier of devices. This method detects for devices which are likely to be capable of
* viewing CSS content optimized for the iPhone, but may not necessarily support JavaScript. Excludes all iPhone Tier
* devices.
*
* @return detection of any device in the 'Rich CSS' Tier
*/
public boolean detectTierRichCss()
{
if ((this.initCompleted == true) ||
(this.isTierRichCss == true))
return this.isTierRichCss;
boolean result = false;
// The following devices are explicitly ok.
// Note: 'High' BlackBerry devices ONLY
if (detectMobileQuick()) {
// Exclude iPhone Tier and e-Ink Kindle devices.
if (!detectTierIphone() && !detectKindle()) {
// The following devices are explicitly ok.
// Note: 'High' BlackBerry devices ONLY
// Older Windows 'Mobile' isn't good enough for iPhone Tier.
if (detectWebkit()
|| detectS60OssBrowser()
|| detectBlackBerryHigh()
|| detectWindowsMobile()
|| userAgent.indexOf(engineTelecaQ) != -1) {
result = true;
}
}
}
return result;
}
/**
* The quick way to detect for a tier of devices. This method detects for all other types of phones, but excludes the
* iPhone and RichCSS Tier devices.
*
* @return detection of a mobile device in the less capable tier
*/
public boolean detectTierOtherPhones()
{
if ((this.initCompleted == true) ||
(this.isTierGenericMobile == true))
return this.isTierGenericMobile;
// Exclude devices in the other 2 categories
if (detectMobileLong()
&& !detectTierIphone()
&& !detectTierRichCss())
return true;
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy