Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jenssegers/agent
👮 A PHP desktop/mobile user agent parser with support for Laravel, based on Mobiledetect
https://github.com/jenssegers/agent
accept-language browser mobile-detect platform robot user-agent
Last synced: 3 days ago
JSON representation
👮 A PHP desktop/mobile user agent parser with support for Laravel, based on Mobiledetect
- Host: GitHub
- URL: https://github.com/jenssegers/agent
- Owner: jenssegers
- License: mit
- Created: 2013-08-10T09:19:59.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2024-08-05T12:34:44.000Z (6 months ago)
- Last Synced: 2025-01-16T01:09:46.033Z (10 days ago)
- Topics: accept-language, browser, mobile-detect, platform, robot, user-agent
- Language: PHP
- Homepage: https://jenssegers.com
- Size: 227 KB
- Stars: 4,572
- Watchers: 89
- Forks: 478
- Open Issues: 82
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
- my-awesome-starred - agent - A PHP desktop/mobile user agent parser with support for Laravel, based on Mobiledetect (PHP)
- awesome-php - Agent - A PHP desktop/mobile user agent parser, based on Mobiledetect. (Table of Contents / Strings)
- awesome-php-cn - Agent - 一个PHP桌面/移动用户代理解析器,基于Mobiledetect. (目录 / 字符串 Strings)
- awesome-projects - Agent - A PHP desktop/mobile user agent parser, based on Mobiledetect. (PHP / Strings)
- awesome-php - Agent - A PHP desktop/mobile user agent parser, based on Mobiledetect. (Table of Contents / Strings)
README
Agent
=====[![Latest Stable Version](http://img.shields.io/packagist/v/jenssegers/agent.svg)](https://packagist.org/packages/jenssegers/agent) [![Total Downloads](http://img.shields.io/packagist/dm/jenssegers/agent.svg)](https://packagist.org/packages/jenssegers/agent) [![Build Status](http://img.shields.io/travis/jenssegers/agent.svg)](https://travis-ci.org/jenssegers/agent) [![Coverage Status](http://img.shields.io/coveralls/jenssegers/agent.svg)](https://coveralls.io/r/jenssegers/agent) [![Donate](https://img.shields.io/badge/donate-paypal-blue.svg)](https://www.paypal.me/jenssegers)
A PHP desktop/mobile user agent parser with support for Laravel, based on [Mobile Detect](https://github.com/serbanghita/Mobile-Detect) with desktop support and additional functionality.
Installation
------------Install using composer:
```bash
composer require jenssegers/agent
```Laravel (optional)
------------------Add the service provider in `config/app.php`:
```php
Jenssegers\Agent\AgentServiceProvider::class,
```And add the Agent alias to `config/app.php`:
```php
'Agent' => Jenssegers\Agent\Facades\Agent::class,
```Basic Usage
-----------Start by creating an `Agent` instance (or use the `Agent` Facade if you are using Laravel):
```php
use Jenssegers\Agent\Agent;$agent = new Agent();
```If you want to parse user agents other than the current request in CLI scripts for example, you can use the `setUserAgent` and `setHttpHeaders` methods:
```php
$agent->setUserAgent('Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/537.13+ (KHTML, like Gecko) Version/5.1.7 Safari/534.57.2');
$agent->setHttpHeaders($headers);
```All of the original [Mobile Detect](https://github.com/serbanghita/Mobile-Detect) methods are still available, check out some original examples at https://github.com/serbanghita/Mobile-Detect/wiki/Code-examples
### Is?
Check for a certain property in the user agent.
```php
$agent->is('Windows');
$agent->is('Firefox');
$agent->is('iPhone');
$agent->is('OS X');
```### Magic is-method
Magic method that does the same as the previous `is()` method:
```php
$agent->isAndroidOS();
$agent->isNexus();
$agent->isSafari();
```### Mobile detection
Check for mobile device:
```php
$agent->isMobile();
$agent->isTablet();
```### Match user agent
Search the user agent with a regular expression:
```php
$agent->match('regexp');
```Additional Functionality
------------------------### Accept languages
Get the browser's accept languages. Example:
```php
$languages = $agent->languages();
// ['nl-nl', 'nl', 'en-us', 'en']
```### Device name
Get the device name, if mobile. (iPhone, Nexus, AsusTablet, ...)
```php
$device = $agent->device();
```### Operating system name
Get the operating system. (Ubuntu, Windows, OS X, ...)
```php
$platform = $agent->platform();
```### Browser name
Get the browser name. (Chrome, IE, Safari, Firefox, ...)
```php
$browser = $agent->browser();
```### Desktop detection
Check if the user is using a desktop device.
```php
$agent->isDesktop();
```*This checks if a user is not a mobile device, tablet or robot.*
### Phone detection
Check if the user is using a phone device.
```php
$agent->isPhone();
```### Robot detection
Check if the user is a robot. This uses [jaybizzle/crawler-detect](https://github.com/JayBizzle/Crawler-Detect) to do the actual robot detection.
```php
$agent->isRobot();
```### Robot name
Get the robot name.
```php
$robot = $agent->robot();
```### Browser/platform version
MobileDetect recently added a `version` method that can get the version number for components. To get the browser or platform version you can use:
```php
$browser = $agent->browser();
$version = $agent->version($browser);$platform = $agent->platform();
$version = $agent->version($platform);
```*Note, the version method is still in beta, so it might not return the correct result.*
## License
Laravel User Agent is licensed under [The MIT License (MIT)](LICENSE).
## Security contact information
To report a security vulnerability, follow [these steps](https://tidelift.com/security).