/mobileesp

MobileESP

Primary LanguageC#Apache License 2.0Apache-2.0

#MobileESP License

Platform Platform Platform Platform Platform Platform

At last, a dead simple way for web site publishers to detect visitors on mobile web sites!

MobileESP is free, open source and lightweight. MobileESP has a simple API for detecting mobile devices. The API returns the simple Boolean result of TRUE if the device is the specified type, or FALSE if it isn't. For example, want to know if your visitor is on an iPhone, Android or Windows Phone device? Simply use the method DetectTierIphone(). It's that easy.

Visit the MobileESP web site for tons more information: www.MobileESP.org.

##Core Principles MobileESP believes in making it dead easy for a website publisher to detect mobile visitors. As a result, the API follows the DetectXXX() pattern and returns a simple Boolean (true or false) for the type of mobile device or platform desired. The API DetectXXX() methods are consistent by design across supported platforms.

In addition, a second core principle is that the code is easy for the user to read and understand. Therefore, we believe it's easier for the user to change, update or extend the library, if desired.

The code is also purposefully written to be modular so that it is not only easier to maintain, but also easier to extend.

##Server-Side Platforms

API Documentation

MobileESP started with PHP (and JavaScript) and has been extended by the community to a bunch of other platforms:

  • PHP
  • Java
  • ASP.NET (C#)
  • Python
  • C++

Also available in separate repositories:

  • Ruby: This project was ported by Martin, who separately maintains the Ruby codebase on GitHub.
  • Classic ASP (VBscript): This project was ported by Miguel Barrero, who separately maintains the codebase on BitBucket.

##Client-Side Platforms

JavaScript API Documentation

MobileESP is also available for JavaScript to be run in the browser. Support for client-side JavaScript processing on phones is very poor to completely non-existent. Though much better on modern smartphones, JavaScript is still not quite at the desktop level. Generally speaking, JavaScript is probably reliable only for distinguishing between devices among modern smartphones and tablets. So if you want to know whether your visitor is one of these devices, the JavaScript probably works fine: iPhone, Android, Windows Phone, and BlackBerry 10+. A few other modern smartphone OSes such as Sailfish and Ubuntu are also expected to perform well.

A server-side library is recommended for pretty much everything else: from older smartphone OSes to all feature phones, plus smart TVs, gaming devices, and ereaders.

##Live Demo Anthony updates the live demo pages when he updates the library. The live demo pages show the results of each of the API calls. Point your mobile device browser to the parent demo page: http://www.hand-interactive.com/detect/

##Useragent Test Strings The MobileESP project tests the PHP and JavaScript live demos with the included spreadsheet of useragent strings. This set of useragent strings isn't meant to be exhaustive, but rather to feature a wide variety of strings to verify that each of the DetectXXX() methods work as expected. Feel free to use this list of useragent strings on your own project, as well.

##Backstory This project maintains and extends the original code created in 2008 by Anthony Hand of Hand Interactive (http://www.hand-interactive.com). Anthony was working on a web site project for a client and wanted an easy way to customize some of the content for smartphones, especially that era's flagship iPhone, Symbian, and BlackBerry devices. However, commonly used Grep-style algorithms at the time were dumb, blunt force tools treating all devices as equal. Thus the PHP and JavaScript libraries were originally born.

NOTE: The MobileESP project was previously hosted on the Google Code web site. Because Google closed down that site and there had been many user requests, MobileESP is now hosted with GitHub.

##Next Step... Anthony has a few items in the backlog and expects to make a minor update to the core MobileESP libraries by the end of April 2015.

The Ruby and Classic ASP (VBScript) libraries haven't been updated in years. Would anyone be interested in updating them?

##License Apache v2.0. More info and the link to the Apache v2.0 license page in each code file.

##Important Caveat The MobileESP project code is lightweight and ideal for many web sites. However, this project is not meant to replace other projects offering greater specificity and control, such as WURFL or HandsetDetection.com.

##Donations Yes, usage of the MobileESP code is FREE, so no worries about that. But a donation to the cause helps provide motivation for Anthony to frequently update the code and continue to enhance the cross-platform APIs. And get new phones to do new tests with!

Donation Info