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

2,790 responses to “Using the BitLy API to shorten urls”

  1. Edwardagide Avatar
    Edwardagide
  2. Arthurtat Avatar
    Arthurtat

    ed meds online: PrimeLine Pharmacy – ed medications cost

  3. Hectorswate Avatar
    Hectorswate

    NovaMen Pharmacy: NovaMen Pharmacy – NovaMen Pharmacy

  4. Edwardagide Avatar
    Edwardagide

    https://primelinepharmacy.shop/# order ed pills online

  5. Hectorswate Avatar
    Hectorswate

    Cheap generic Viagra online: sildenafil online – NovaMen Pharmacy

  6. Arthurtat Avatar
    Arthurtat

    sildenafil over the counter: NovaMen Pharmacy – Viagra without a doctor prescription Canada

  7. Edwardagide Avatar
    Edwardagide

    https://novamenpharmacy.shop/# Sildenafil 100mg price

  8. Hectorswate Avatar
    Hectorswate

    п»їed pills online: cheap ed pills – get ed meds online

  9. Michaeledges Avatar
    Michaeledges
  10. Hectorswate Avatar
    Hectorswate

    Generic Cialis price: Tadalafil price – Buy Tadalafil 20mg

  11. Edwardagide Avatar
    Edwardagide

    http://corevitalpharmacy.com/# п»їcialis generic

  12. Arthurtat Avatar
    Arthurtat

    CoreVital Pharmacy: buy cialis pill – CoreVital Pharmacy

  13. Hectorswate Avatar
    Hectorswate

    NovaMen Pharmacy: NovaMen Pharmacy – NovaMen Pharmacy

  14. Arthurtat Avatar
    Arthurtat

    cheapest ed online: erectile dysfunction medication online – buy erectile dysfunction treatment

  15. Edwardagide Avatar
    Edwardagide

    https://novamenpharmacy.shop/# sildenafil 50 mg price

  16. Hectorswate Avatar
    Hectorswate

    get ed meds today: ed pills pharmacy – cheapest online ed meds

  17. Michaeledges Avatar
    Michaeledges

    http://primelinepharmacy.com/# buy erectile dysfunction pills online

  18. Arthurtat Avatar
    Arthurtat

    cheap ed treatment: PrimeLine Pharmacy – buy ed pills online

  19. Edwardagide Avatar
    Edwardagide
  20. Hectorswate Avatar
    Hectorswate

    NovaMen Pharmacy: viagra canada – NovaMen Pharmacy

  21. Arthurtat Avatar
    Arthurtat

    buy erectile dysfunction pills: ed pills pharmacy – buying erectile dysfunction pills online

  22. Edwardagide Avatar
    Edwardagide
  23. Hectorswate Avatar
    Hectorswate

    Generic Cialis price: CoreVital Pharmacy – п»їcialis generic

  24. Arthurtat Avatar
    Arthurtat

    cheap ed meds online: ed medicine online – online erectile dysfunction medication

  25. Edwardagide Avatar
    Edwardagide
  26. Michaeledges Avatar
    Michaeledges

    https://novamenpharmacy.com/# Generic Viagra for sale

  27. Hectorswate Avatar
    Hectorswate

    п»їcialis generic: Tadalafil price – п»їcialis generic

  28. Arthurtat Avatar
    Arthurtat

    CoreVital Pharmacy: Generic Tadalafil 20mg price – CoreVital Pharmacy

  29. Edwardagide Avatar
    Edwardagide
  30. Hectorswate Avatar
    Hectorswate

    CoreVital Pharmacy: CoreVital Pharmacy – CoreVital Pharmacy

  31. Arthurtat Avatar
    Arthurtat

    ed medications online: where can i get ed pills – ed pills cheap

  32. Edwardagide Avatar
    Edwardagide

    https://novamenpharmacy.shop/# Buy generic 100mg Viagra online

  33. Hectorswate Avatar
    Hectorswate

    ed meds by mail: ed rx online – erectile dysfunction drugs online

  34. Michaeledges Avatar
    Michaeledges
  35. StevenIllug Avatar
    StevenIllug

    jojobet: jojobet

  36. Richardbag Avatar
    Richardbag

    https://jojovip.top/# jojobet casino

  37. Edwardagide Avatar
    Edwardagide

    https://primelinepharmacy.shop/# ed prescription online

  38. StevenIllug Avatar
    StevenIllug

    jojobet resmi giriş: jojobet

  39. Richardbag Avatar
    Richardbag

    https://jojovip.blog/# jojobet güncel

  40. Edwardagide Avatar
    Edwardagide

Leave a Reply

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