Using the BitLy API to shorten urls

I was asked to place Twitter messages with product links when new products were added to a webshop. I’ve used my own Twitter class for posting the first test Tweet then I went looking for a shorten url a service to shorten the product links.

There are many url shorten services available on the internet, one of these services is Bitly.
The reasons why I’ve chosen Bitly:
– Urls don’t expire after a period of time.
– Bitly provides a click url summary (although Google Analytics can be used for this instead)
– Urls are short in length so i could use the remaining Tweet length for a small product description.
– And more important, they provide an easy to use API.
– Authentication does not require a password, we can use our API key instead.

Before we can connect to the API, we need a Bitly account, the account can be created at http://bit.ly/ to obtain a free API key.

The communication process is quite simple:
– Authenticate with your Bitly username and API key
– Call the right Bitly API url with the correct parameters for the action we want to perform
– Process the result

Below are some snippets of my Bitly class:

class BitLy
{
	/**
	 * Version of the bit ly api
	 * @var string
	 */
	private $sApiVersion = '2.0.1';

	/**
	 * Url of the api
	 * @var string
	 */
	private $sApiUrl = 'http://api.bit.ly/';

	/**
	 * username
	 * @var string
	 */
	private $sUsername;

	/**
	 * apikey
	 * @var string
	 */
	private $sApiKey;

	/**
	 * Set username and apikey
	 *
	 * @param string $sUsername
	 * @param string $sApiKey
	 * @return void
	 */
	public function  __construct($sUsername, $sApiKey) {
		$this->setUsername($sUsername);
		$this->setApiKey($sApiKey);
	}

	...

	/**
	 * shorten
	 *
	 * @param string $sLongUrl
	 * @return object with shortend url and hash
	 */
	public function shorten($sLongUrl)
	{
		return $this->process('shorten', urlencode($sLongUrl));
	}

	/**
	 * expand
	 *
	 * @param string $sShortUrl
	 * @return object with original url
	 */
	public function expand($sShortUrl)
	{
		return $this->process('expand', urlencode($sShortUrl));
	}

	...

	/**
	 * process, checks the action and returns the result
	 *
	 * @param string $sAction
	 * @param string $sParam
	 */
	private function process($sAction, $sUrlToParse)
	{
		// Check the url, if no http is present, add it
		if(strstr($sUrlToParse, 'http://') === false) {
			$sUrlToParse = 'http://'.$sUrlToParse;
		}

		// Compose action url
		$sParam = ($sAction == 'shorten') ? 'longUrl='.$sUrlToParse : 'shortUrl='.$sUrlToParse;
		$sActionUrl = $this->sApiUrl.$sAction.'?version='.$this->sApiVersion.'&'.$sParam.'&login='.$this->sUsername.'&apiKey='.$this->sApiKey.'&format=xml';

		// Get data
		libxml_use_internal_errors(true);
		$oData = simplexml_load_file($sActionUrl);
		if(!$oData) {
			throw new Exception('Api returned an invalid response!');
		}

		// Check for errors
		if($oData->statusCode == 'ERROR') {
			throw new Exception($oData->errorCode.': '.$oData->errorMessage);
		}

		// Build result object
		$oResult				= new stdClass();
		$oResult->requestedUrl	= $sUrlToParse;
		$oResult->resultUrl	= (string)$oData->results->nodeKeyVal->shortUrl;
		$oResult->hash		= (string)$oData->results->nodeKeyVal->hash;

		return $oResult;
	}

The reason why I build a result object is because of the fact that the server where the class is deployed doesn’t support JSON but JSON is also available as return format.

Furthermore, generated urls can be saved to our Bitly account history by adding an additional parameter to the url (history = 1). Another nice option of the API is to shorten the URL to a keyword, this can be achieved by sending the (keyword=your keyword) parameter along.

The complete API manual can be found at Google Code which also describes how to get click statistics of the shortened links.

Comments

3,431 responses to “Using the BitLy API to shorten urls”

  1. ArthurLap Avatar
    ArthurLap

    Paw Trust Meds: discount pet meds – Paw Trust Meds

  2. Gabrielnes Avatar
    Gabrielnes

    https://pawtrustmeds.shop/# discount pet meds

  3. Michaelves Avatar
    Michaelves

    Paw Trust Meds: pet drugs online – vet pharmacy online

  4. WilliamSip Avatar
    WilliamSip

    http://globalindiapharmacy.com/# Global India Pharmacy

  5. AndrewHoozy Avatar
    AndrewHoozy

    Global India Pharmacy: indian pharmacy online – indian pharmacy paypal

  6. Gabrielnes Avatar
    Gabrielnes

    https://pawtrustmeds.shop/# pet pharmacy online

  7. Michaelves Avatar
    Michaelves

    Global India Pharmacy: top 10 pharmacies in india – best online pharmacy india

  8. AndrewHoozy Avatar
    AndrewHoozy

    buy prescription drugs from india: reputable indian pharmacies – Global India Pharmacy

  9. ArthurLap Avatar
    ArthurLap

    pet meds for dogs: vet pharmacy online – Paw Trust Meds

  10. Michaelves Avatar
    Michaelves

    online pharmacy india: buy prescription drugs from india – Global India Pharmacy

  11. AndrewHoozy Avatar
    AndrewHoozy

    п»їlegitimate online pharmacies india: online pharmacy india – india pharmacy

  12. WilliamSip Avatar
    WilliamSip

    https://pawtrustmeds.com/# dog prescriptions online

  13. Gabrielnes Avatar
    Gabrielnes

    https://globalindiapharmacy.com/# Global India Pharmacy

  14. Michaelves Avatar
    Michaelves

    Global India Pharmacy: buy medicines online in india – world pharmacy india

  15. ArthurLap Avatar
    ArthurLap

    pet pharmacy: pet drugs online – dog medicine

  16. AndrewHoozy Avatar
    AndrewHoozy

    canada rx pharmacy world: NorthAccess Rx – legit canadian pharmacy

  17. Michaelves Avatar
    Michaelves

    Paw Trust Meds: Paw Trust Meds – Paw Trust Meds

  18. AndrewHoozy Avatar
    AndrewHoozy

    adderall canadian pharmacy: NorthAccess Rx – canadian mail order pharmacy

  19. ArthurLap Avatar
    ArthurLap

    best online pharmacy india: Global India Pharmacy – online shopping pharmacy india

  20. WilliamSip Avatar
    WilliamSip
  21. Michaelves Avatar
    Michaelves

    real canadian pharmacy: best mail order pharmacy canada – canadian pharmacy tampa

  22. AndrewHoozy Avatar
    AndrewHoozy

    Global India Pharmacy: india pharmacy – buy prescription drugs from india

  23. Michaelves Avatar
    Michaelves

    top online pharmacy india: Global India Pharmacy – reputable indian pharmacies

  24. AndrewHoozy Avatar
    AndrewHoozy

    cheapest online pharmacy india: india pharmacy mail order – reputable indian pharmacies

  25. ArthurLap Avatar
    ArthurLap

    canada pet meds: Paw Trust Meds – dog medication online

  26. AndrewHoozy Avatar
    AndrewHoozy

    vet pharmacy: Paw Trust Meds – Paw Trust Meds

  27. WilliamSip Avatar
    WilliamSip
  28. ArthurLap Avatar
    ArthurLap

    canadian pharmacies online: canadian drugs pharmacy – canadian pharmacy ratings

  29. AndrewHoozy Avatar
    AndrewHoozy

    Global India Pharmacy: Online medicine order – indianpharmacy com

  30. Michaelves Avatar
    Michaelves

    canadian pharmacies: reputable canadian pharmacy – canadianpharmacy com

Leave a Reply

Your email address will not be published. Required fields are marked *