|  Download PHP Browser DetectionA PHP library to detect browser, OS, platform and device type by User-Agent parsing.\
This library focused on high performance and low memory usage HTTP client parsing.\
Uses a simple and fast algorithm to accurately detect more than 165 browser types and over 60 OS types.\
For most commonly browsers parsing process took less than 0.0005 second even on low-level shared hosting.\
In the case of rare User-Agents recognized time is less than 0.0008 second for the same conditioned hosting environment.\
The library supports only really actual Browsers and OS without support for outdated environments that are actually not used now.\
Newest MacOS Monterey and Windows 11 User-Agents detection included.\
Works by use only one library file and without any third-party libraries dependency. RequirementsThis library requires PHP 5.3 or higher. Manual installation
Simply upload library file `BrowserDetection.php` (placed in the `src` directory) to your project;
Connect PHP library file by using `require_once`:
 <?php
require_once('BrowserDetection.php');
?>
 Installation by using ComposerInstall this library using Composer: `
composer require foroco/php-browser-detection
` Update library package by running a command: `
composer update foroco/php-browser-detection
` The first step requires the Composer autoloader: <?php
require ('vendor/autoload.php');
// If you use PHP in Windows OS use another path style:
// require ('vendor\autoload.php');
?>
 UsageThe library will try to get environment data from the HTTP_USER_AGENTheader sent by the HTTP client.
Library PHP ClassBrowserDetectioncontains four public methods which return Array or JSON string of recognized data fromHTTP_USER_AGENT: 
`getAll();`
`getOS();`
`getBrowser();`
`getDevice();`
 First argument should contain User-Agent string from the HTTP_USER_AGENTheader or your custom User-Agent string.\
Second argument (optional) may contain 'JSON' if you want to get returned result as JSON format. <?php
$Browser = new foroco\BrowserDetection();
$useragent = $_SERVER['HTTP_USER_AGENT'];
// Get all possible environment data (array):
$result = $Browser->getAll($useragent);
// Get OS data (array):
$result = $Browser->getOS($useragent);
// Get Browser data (array):
$result = $Browser->getBrowser($useragent);
// Get Device type data (array):
$result = $Browser->getDevice($useragent);
/*
Also methods may returned result as JSON string
Just use second argument of methods as 'JSON'
*/
// Get all possible environment data (JSON):
$result = $Browser->getAll($useragent, 'JSON');
print_r($result);
// ... etc
?>
 The library class BrowserDetectionalso contains special methodsetTouchSupport()(optional, available from version 1.1).\
This method is necessary to detect mobile browsers inDesktop Modecondition (Android and iOS).\
ForDesktop ModedetectionsetTouchSupport()method should call if browser supports Touch events.\
Touch events detection is performed by client-side JavaScript code in the target browser. Example: if (('ontouchstart' in window) || window.DocumentTouch && document instanceof DocumentTouch) {
// Touch Event detected
}
 Description for returned variablesOS Type (os_type)\
Returns type of operating system (OS).\
All possible values:
* desktop
* mobile
* mixed
* unknown OS Family (os_family)\
Returns operating system (OS) family orunknownin cases of unable OS family recognition.\
Example:windows,linux,unixetc. OS Name (os_name)\
Returns operating system (OS) name orunknownin cases of unable OS name recognition.\
Example:Windows,Android,macOS,iOSetc. OS Version (os_version)\
Returns operating system (OS) version or0in cases of unable OS version recognition.\
May contains numeric, string or mixed types OS versions.\
In case of numeric OS version (e.g.Android) contains major and minor version parts values, e.g.4.4,8.1,10etc.\
In case of string OS version (e.g.macOS) contains string version name values, e.g.Mavericks,Mojave,Catalinaetc.\
ForWindowsmay contains mixed version types values:10,Vista,XPetc. OS Title (os_title)\
Returns operating system (OS) title which contains OS name and OS version together.\
Also returnsunknownif OS name is not recognized. Device Type (device_type)\
Returns device type based on some User-Agent data.\
All possible values:
* desktop
* mobile
* tv
* console
* mediaplayer
* car
* watch
* unknown Browser Name (browser_name)\
Returns browser name orunknownin cases of unable browser name recognition.\
Example:Chrome,Firefox,UC Browser,Huawei Browser,Vivaldietc. Browser Version (browser_version)\
Returns browser version number or0in cases of unable browser version recognition.\
Always contains numeric values (integer or float numbers).\
Returns float number (e.g.3.5,10.5,13.1) for some browsers which should contains both major and minor browser version parts (Safari,Vivaldi,PaleMoonetc).\
Returns only major decimal browser version (e.g.15,37,81) for other browsers which has a lot of major versions (Chrome,Firefox,Operaetc). Browser Title (browser_title)\
Returns browser title which contains browser name and browser version together.\
Also returnsunknownif browser name is not recognized. Browser Chrome Original (browser_chrome_original)\
Returns1number if browser recognized as original Google Chrome browser or returns0if it's not. Browser Firefox Original (browser_firefox_original)\
Returns1number if browser recognized as original Mozilla Firefox browser or returns0if it's not. Browser Safari Original (browser_safari_original)\
Returns1number if browser recognized as original Apple Safari browser or returns0if it's not. Browser Chromium Version (browser_chromium_version)\
Returns Chromium major engine version number if browser based on Chromium engine or returns0if it's not. Browser Gecko Version (browser_gecko_version)\
Returns Gecko major engine version number if browser based on Gecko engine or returns0if it's not. Browser WebKit Version (browser_webkit_version)\
Returns WebKit version engine number if browser based on WebKit engine or returns0if it's not.\
Always float number value. Browser Android Webview (browser_android_webview)\
Returns1number if Android Webview mode detected or returns0if it's not. Browser iOS Webview (browser_ios_webview)\
Returns1number if iOS Webview mode detected or returns0if it's not. Browser Desktop Mode (browser_desktop_mode)\
Returns1number if mobile browser works inDesktop Modeor returns0if it's not detected.\setTouchSupport()method should call forDesktop Modedetection if browser supports Touch events. 64 Bits Mode (64bits_mode)\
Returns1number if operating system (OS) and browser work together in 64-bit mode or returns0if 64-bit mode not detected.\
Available only forgetAll();andgetOS();methods. Usage ExamplesSee follow examples to understand library usage use cases. Detect AllTo detect all possible environment data use: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.4150.0 Iron Safari/537.36';
$result = $Browser->getAll($useragent);
print_r($result);
?>
 Returns: Array
(
    [os_type] => desktop
    [os_family] => windows
    [os_name] => Windows
    [os_version] => 7
    [os_title] => Windows 7
    [device_type] => desktop
    [browser_name] => Iron
    [browser_version] => 80
    [browser_title] => Iron 80
    [browser_chrome_original] => 0
    [browser_firefox_original] => 0
    [browser_safari_original] => 0
    [browser_chromium_version] => 80
    [browser_gecko_version] => 0
    [browser_webkit_version] => 0
    [browser_android_webview] => 0
    [browser_ios_webview] => 0
    [browser_desktop_mode] => 0
    [64bits_mode] => 1
)
 OS DetectionTo parse only OS data use: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (Linux; arm_64; Android 9; LLD-L31) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.136 YaBrowser/20.2.4.153.00 Mobile Safari/537.36';
$result = $Browser->getOS($useragent);
print_r($result);
?>
 Returns: Array
(
    [os_type] => mobile
    [os_family] => android
    [os_name] => Android
    [os_version] => 9
    [os_title] => Android 9
    [64bits_mode] => 1
)
 Browser DetectionTo parse only browser data use: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (iPad; CPU OS 9_3_4 like Mac OS X) AppleWebKit/601.1 (KHTML, like Gecko) CriOS/80.0.3987.122 Mobile/13G35 Safari/601.1.46';
$result = $Browser->getBrowser($useragent);
print_r($result);
?>
 Returns: Array
(
    [browser_name] => Chrome
    [browser_version] => 80
    [browser_title] => Chrome 80
    [browser_chrome_original] => 1
    [browser_firefox_original] => 0
    [browser_safari_original] => 0
    [browser_chromium_version] => 80
    [browser_gecko_version] => 0
    [browser_webkit_version] => 0
    [browser_android_webview] => 0
    [browser_ios_webview] => 0
    [browser_desktop_mode] => 0
)
 Device DetectionTo parse only device type data use: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (SMART-TV; Linux; Tizen 5.0) AppleWebKit/537.36 (KHTML, like Gecko) SamsungBrowser/2.2 Chrome/63.0.3239.84 TV Safari/537.36';
$result = $Browser->getDevice($useragent);
print_r($result);
?>
 Returns: Array
(
    [device_type] => tv
)
 Desktop Mode DetectionTo detect if mobile browser works in Desktop Modeuse: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36';
$Browser->setTouchSupport(); // Call if Touch events detected in browser by JavaScript code ('ontouchstart' in window)
$result = $Browser->getAll($useragent);
print_r($result);
?>
 Returns: Array
(
    [os_type] => mobile
    [os_family] => android
    [os_name] => Android
    [os_version] => 0
    [os_title] => Android
    [device_type] => mobile
    [browser_name] => Chrome
    [browser_version] => 81
    [browser_title] => Chrome 81
    [browser_chrome_original] => 1
    [browser_firefox_original] => 0
    [browser_safari_original] => 0
    [browser_chromium_version] => 81
    [browser_gecko_version] => 0
    [browser_webkit_version] => 0
    [browser_android_webview] => 0
    [browser_ios_webview] => 0
    [browser_desktop_mode] => 1
    [64bits_mode] => 0
)
 Detect All (JSON)To pasre all possible environment data and returns JSON format string: <?php
$Browser = new foroco\BrowserDetection();
$useragent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 6_0 like Mac OS X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Mobile Safari/537.36';
$result = $Browser->getAll($useragent);
print_r($result);
?>
 Returns: {"os_type":"mobile","os_family":"macintosh","os_name":"iOS","os_version":6,"os_title":"iOS 6","device_type":"mobile","browser_name":"Chrome","browser_version":78,"browser_title":"Chrome 78","browser_chrome_original":1,"browser_firefox_original":0,"browser_safari_original":0,"browser_chromium_version":78,"browser_gecko_version":0,"browser_webkit_version":0,"browser_android_webview":0,"browser_ios_webview":0,"browser_desktop_mode":0,"64bits_mode":0}
 Benchmarking TestBenchmarking was performed on a low-level shared hosting.\
Test server configuration: RedHat Linux + LiteSpeed + PHP Extension.\
Test conditions based on collection of random ~446000 non repeated real life User-Agent strings. User-Agent recognition performance in PHP 7.3 (requests per second): getAll: ~ 31000 rps
getOS: ~ 120000 rps
getBrowser: ~ 43000 rps
getDevice: ~ 70000 rps
 LicenseThe MIT License (MIT) Copyright (c) 2020-2021 Artem Murugov Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
the Software, and to permit persons to whom the Software is furnished to do so,
subject to the following conditions: The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |