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,536 responses to “Using the BitLy API to shorten urls”

  1. b"asta binance h"anvisningskod Avatar

    Thanks for sharing. I read many of your blog posts, cool, your blog is very good.

  2. RobertTup Avatar
    RobertTup

    casino deneme siteleri casino siteleri

  3. Thomasrendy Avatar
    Thomasrendy

    vdcasino vdcasino

  4. Aaronjah Avatar
    Aaronjah

    casino siteleri: casino deneme siteleri

  5. RobertTup Avatar
    RobertTup

    https://cassiteleri.buzz/# güvenilir casino siteleri

  6. Thomasrendy Avatar
    Thomasrendy

    vdcasino vdcasino

  7. Thomasrendy Avatar
    Thomasrendy

    https://vdcasino1st.blog/# vdcasino güncel giriş

  8. RobertTup Avatar
    RobertTup

    güvenilir casino siteleri: lisanslı casino siteleri

  9. Donaldpak Avatar
    Donaldpak

    https://cassiteleri.buzz/# güvenilir casino siteleri

  10. b"asta binance h"anvisningskod Avatar

    Your article helped me a lot, is there any more related content? Thanks!

  11. Thomasrendy Avatar
    Thomasrendy

    https://vdcasino1st.online/# vdcasino resmi giriş

  12. RobertTup Avatar
    RobertTup

    casino siteleri lisanslı casino siteleri

  13. Aaronjah Avatar
    Aaronjah

    https://cassiteleri.top/# casino deneme siteleri

  14. Donaldpak Avatar
    Donaldpak

    deneme bonusu veren casino siteleri: lisanslı casino siteleri

  15. Thomasrendy Avatar
    Thomasrendy

    vdcasino giriş vdcasino

  16. RobertTup Avatar
    RobertTup

    https://cassiteleri.top/# casino siteleri

  17. Donaldpak Avatar
    Donaldpak

    https://cassiteleri.top/# casino siteleri

  18. Thomasrendy Avatar
    Thomasrendy

    vdcasino resmi giriş vdcasino

  19. RobertTup Avatar
    RobertTup

    casino deneme siteleri: casino siteleri

  20. Donaldpak Avatar
    Donaldpak

    casino deneme siteleri: casino deneme siteleri

  21. RobertTup Avatar
    RobertTup

    lisanslı casino siteleri güvenilir casino siteleri

  22. Thomasrendy Avatar
    Thomasrendy

    vdcasino resmi giriş: vdcasino

  23. Donaldpak Avatar
    Donaldpak

    lisanslı casino siteleri güvenilir casino siteleri

  24. Aaronjah Avatar
    Aaronjah

    güvenilir casino siteleri: lisanslı casino siteleri

  25. RobertTup Avatar
    RobertTup

    https://cassiteleri.top/# deneme bonusu veren casino siteleri

  26. Thomasrendy Avatar
    Thomasrendy

    vdcasino vdcasino

  27. Donaldpak Avatar
    Donaldpak

    casino siteleri lisanslı casino siteleri

  28. RobertTup Avatar
    RobertTup

    https://cassiteleri.buzz/# casino deneme siteleri

  29. Thomasrendy Avatar
    Thomasrendy

    https://vdcasino1st.online/# vdcasino güncel giriş

  30. RobertTup Avatar
    RobertTup

    güvenilir casino siteleri casino siteleri

  31. Thomasrendy Avatar
    Thomasrendy

    vdcasino güncel adres vdcasino

  32. Donaldpak Avatar
    Donaldpak

    deneme bonusu veren casino siteleri: casino deneme siteleri

  33. RobertTup Avatar
    RobertTup

    https://cassiteleri.buzz/# deneme bonusu veren casino siteleri

  34. Aaronjah Avatar
    Aaronjah

    lisanslı casino siteleri: güvenilir casino siteleri

Leave a Reply

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