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

1,727 responses to “Using the BitLy API to shorten urls”

  1. GlennTix Avatar
    GlennTix

    https://ivertherapeutics.com/# ivermectin 6mg dosage

  2. TracyThics Avatar
    TracyThics

    https://smartgenrxusa.shop/# discount pharmacy mexico

  3. LarryViofs Avatar
    LarryViofs

    canadian pharmacy no prescription needed: Smart GenRx USA – Smart GenRx USA

  4. LinwoodTwirl Avatar
    LinwoodTwirl

    medication canadian pharmacy: Smart GenRx USA – my canadian pharmacy reviews

  5. TracyThics Avatar
    TracyThics

    https://sertralineusa.com/# zoloft without rx

  6. LinwoodTwirl Avatar
    LinwoodTwirl

    Smart GenRx USA: canadian pharmacy viagra reviews – Smart GenRx USA

  7. Leonarddeark Avatar
    Leonarddeark

    cost of ivermectin stromectol tablets for humans ivermectin cream 1%

  8. LarryViofs Avatar
    LarryViofs

    Smart GenRx USA: canadien pharmacies – Smart GenRx USA

  9. TracyThics Avatar
    TracyThics

    http://smartgenrxusa.com/# pharmacy online uae

  10. LinwoodTwirl Avatar
    LinwoodTwirl

    Neuro Relief USA: neurontin canada – neurontin drug

  11. TracyThics Avatar
    TracyThics

    https://ivertherapeutics.shop/# ivermectin 1% cream generic

  12. LinwoodTwirl Avatar
    LinwoodTwirl

    stromectol price in india: Iver Therapeutics – stromectol 3 mg tablet

  13. LarryViofs Avatar
    LarryViofs

    Iver Therapeutics: ivermectin generic cream – ivermectin nz

  14. Leonarddeark Avatar
    Leonarddeark

    canadian pharmacy store Smart GenRx USA Smart GenRx USA

  15. TracyThics Avatar
    TracyThics
  16. LinwoodTwirl Avatar
    LinwoodTwirl

    sertraline generic: zoloft no prescription – zoloft cheap

  17. LarryViofs Avatar
    LarryViofs

    sertraline zoloft: sertraline generic – zoloft cheap

  18. LinwoodTwirl Avatar
    LinwoodTwirl

    neurontin india: Neuro Relief USA – generic gabapentin

  19. TracyThics Avatar
    TracyThics

    http://smartgenrxusa.com/# canadian pharmacy no prescription

  20. LinwoodTwirl Avatar
    LinwoodTwirl

    pharmacy in canada for viagra: Smart GenRx USA – Smart GenRx USA

  21. Leonarddeark Avatar
    Leonarddeark

    generic zoloft zoloft pill zoloft cheap

  22. LarryViofs Avatar
    LarryViofs

    Sertraline USA: zoloft without dr prescription – generic zoloft

  23. TracyThics Avatar
    TracyThics
  24. LinwoodTwirl Avatar
    LinwoodTwirl

    zoloft buy: zoloft medication – zoloft buy

  25. GlennTix Avatar
    GlennTix

    https://sertralineusa.shop/# generic for zoloft

  26. TracyThics Avatar
    TracyThics

    http://sertralineusa.com/# zoloft without dr prescription

  27. LarryViofs Avatar
    LarryViofs

    zoloft buy: zoloft cheap – zoloft generic

  28. LinwoodTwirl Avatar
    LinwoodTwirl

    sertraline generic: sertraline generic – generic for zoloft

  29. Leonarddeark Avatar
    Leonarddeark

    top 10 online pharmacy in india Smart GenRx USA Smart GenRx USA

  30. TracyThics Avatar
    TracyThics

    http://neuroreliefusa.com/# Neuro Relief USA

  31. LinwoodTwirl Avatar
    LinwoodTwirl

    buy zoloft: zoloft without dr prescription – zoloft without dr prescription

  32. LarryViofs Avatar
    LarryViofs

    generic zoloft: zoloft without rx – buy zoloft

  33. TracyThics Avatar
    TracyThics
  34. LinwoodTwirl Avatar
    LinwoodTwirl

    Neuro Relief USA: Neuro Relief USA – neurontin 50mg cost

  35. GlennTix Avatar
    GlennTix

    http://neuroreliefusa.com/# brand name neurontin

  36. TracyThics Avatar
    TracyThics
  37. LinwoodTwirl Avatar
    LinwoodTwirl

    how to get neurontin: Neuro Relief USA – neurontin capsules 600mg

  38. LarryViofs Avatar
    LarryViofs

    purchase oral ivermectin: cost of ivermectin 1% cream – ivermectin 1 topical cream

  39. Leonarddeark Avatar
    Leonarddeark

    online pharmacy pain medicine reputable online pharmacy Smart GenRx USA

  40. GlennTix Avatar
    GlennTix

    https://ivertherapeutics.shop/# buy ivermectin canada

  41. TracyThics Avatar
    TracyThics

Leave a Reply

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