mirror of
https://github.com/lubuntu-team/lubuntu.me.git
synced 2025-02-24 16:51:07 +00:00
116 lines
3.2 KiB
Markdown
116 lines
3.2 KiB
Markdown
# PHP User Agent Parser
|
|
|
|
[data:image/s3,"s3://crabby-images/38c04/38c04f7acc01e29d1cd6c2b837785f24aaf15620" alt="Latest Stable Version"](https://packagist.org/packages/donatj/phpuseragentparser) [data:image/s3,"s3://crabby-images/1ac7f/1ac7fc79b906b9da28bcb6278c6adaea331ce003" alt="Total Downloads"](https://packagist.org/packages/donatj/phpuseragentparser) [data:image/s3,"s3://crabby-images/421b7/421b7d22931cf06c8ca80b696116bb069ae43223" alt="Latest Unstable Version"](https://packagist.org/packages/donatj/phpuseragentparser) [data:image/s3,"s3://crabby-images/f4ab3/f4ab33122cf2ddca6f212d3c2b90a12b1280123e" alt="License"](https://packagist.org/packages/donatj/phpuseragentparser)
|
|
[data:image/s3,"s3://crabby-images/67378/6737820f09b2b4ba6b408b061537704a974d2bd2" alt="Build Status"](https://travis-ci.org/donatj/PhpUserAgent)
|
|
[data:image/s3,"s3://crabby-images/6be32/6be3254c5d9bfe3d62bfdb7394d6731dd47d87ed" alt="HHVM Status"](http://hhvm.h4cc.de/package/donatj/phpuseragentparser)
|
|
|
|
## What It Is
|
|
|
|
A simple, streamlined PHP user-agent parser!
|
|
|
|
Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
|
|
|
|
|
|
## Why Use This
|
|
|
|
You have your choice in user-agent parsers. This one detects **all modern browsers** in a very light, quick, understandable fashion.
|
|
It is less than 200 lines of code, and consists of just three regular expressions!
|
|
It can also correctly identify exotic versions of IE others fail on.
|
|
|
|
It offers 100% unit test coverage, is installable via Composer, and is very easy to use.
|
|
|
|
## What It Does Not Do
|
|
|
|
### OS Versions
|
|
|
|
User-agent strings **are not** a reliable source of OS Version!
|
|
|
|
- Many agents simply don't send the information.
|
|
- Others provide varying levels of accuracy.
|
|
- Parsing Windows versions alone almost nearly doubles the size of the code.
|
|
|
|
I'm much more interested in keeping this thing *tiny* and accurate than adding niché features and would rather focus on things that can be **done well**.
|
|
|
|
All that said, there is the start of a [branch to do it](https://github.com/donatj/PhpUserAgent/tree/os_version_detection) I created for a client if you want to poke it, I update it from time to time, but frankly if you need to *reliably detect OS Version*, using user-agent isn't the way to do it. I'd go with JavaScript.
|
|
|
|
## Requirements
|
|
|
|
- PHP 5.3.0+
|
|
|
|
## Installing
|
|
|
|
PHP User Agent is available through Packagist via Composer.
|
|
|
|
```json
|
|
{
|
|
"require": {
|
|
"donatj/phpuseragentparser": "*"
|
|
}
|
|
}
|
|
```
|
|
|
|
## Sample Usage
|
|
|
|
```php
|
|
$ua_info = parse_user_agent();
|
|
/*
|
|
array(
|
|
'platform' => '[Detected Platform]',
|
|
'browser' => '[Detected Browser]',
|
|
'version' => '[Detected Browser Version]',
|
|
);
|
|
*/
|
|
```
|
|
|
|
## Currently Detected Platforms
|
|
|
|
- Desktop
|
|
- Windows
|
|
- Linux
|
|
- Macintosh
|
|
- Chrome OS
|
|
- Mobile
|
|
- Android
|
|
- iPhone
|
|
- iPad / iPod Touch
|
|
- Windows Phone OS
|
|
- Kindle
|
|
- Kindle Fire
|
|
- BlackBerry
|
|
- Playbook
|
|
- Tizen
|
|
- Console
|
|
- Nintendo 3DS
|
|
- New Nintendo 3DS
|
|
- Nintendo Wii
|
|
- Nintendo WiiU
|
|
- PlayStation 3
|
|
- PlayStation 4
|
|
- PlayStation Vita
|
|
- Xbox 360
|
|
- Xbox One
|
|
|
|
## Currently Detected Browsers
|
|
|
|
- Android Browser
|
|
- BlackBerry Browser
|
|
- Camino
|
|
- Kindle / Silk
|
|
- Firefox / Iceweasel
|
|
- Safari
|
|
- Internet Explorer
|
|
- IEMobile
|
|
- Chrome
|
|
- Opera
|
|
- Midori
|
|
- Vivaldi
|
|
- TizenBrowser
|
|
- UC Browser
|
|
- Lynx
|
|
- Wget
|
|
- Curl
|
|
|
|
|
|
|
|
More information is available at [Donat Studios](http://donatstudios.com/PHP-Parser-HTTP_USER_AGENT).
|