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

  1. MarcusenUrb Avatar
    MarcusenUrb

    stromectol usa: Iver Protocols Guide – ivermectin purchase

  2. EdwardLaush Avatar
    EdwardLaush

    where to get cheap clomid fertility pct guide fertility pct guide

  3. Michaelles Avatar
    Michaelles

    buy Elavil: AmiTrip – Amitriptyline

  4. WalterLeaws Avatar
    WalterLeaws

    https://iver.us.com/# Iver Protocols Guide

  5. StevenMor Avatar
    StevenMor

    https://amitrip.us.com/# Generic Elavil

  6. Duanegat Avatar
    Duanegat

    Hi, if you are looking for side effects info regarding common medicines, take a look at this online directory. It covers usage and risks very well. Read more here: https://magmaxhealth.com/Clomid. Hope it helps.

  7. DavidPeT Avatar
    DavidPeT

    Hey everyone, if you need a reliable online pharmacy to order prescription drugs securely. I found this site: lamictal. Stocking a wide range of meds with fast shipping. Hope this helps.

  8. MilesCed Avatar
    MilesCed

    Hi all, I recently found side effects info on common medicines, I recommend this online directory. You can read about safety protocols clearly. Link: https://magmaxhealth.com/Toradol. Very informative.

  9. MatthewGuert Avatar
    MatthewGuert

    Hi guys, if you need a reliable source for meds to order prescription drugs cheaply. Take a look at this site: clarinex. Selling high quality drugs and huge discounts. Thanks.

  10. Duanegat Avatar
    Duanegat

    Hey everyone, I recently found a medical guide about prescription drugs, I found this medical reference. You can read about safety protocols clearly. Link: https://magmaxhealth.com/Allopurinol. Very informative.

  11. DavidPeT Avatar
    DavidPeT

    Hello, anyone searching for an affordable drugstore to buy medicines cheaply. I recommend MagMaxHealth: protonix. They offer generic tablets at the best prices. Thanks.

  12. DonaldNaila Avatar
    DonaldNaila

    In terms of side effects and interactions, it is recommended to check the detailed guide on: https://magmaxhealth.com/clomid.html to ensure correct administration.

  13. MilesCed Avatar
    MilesCed

    Hi all, if you are looking for dosage instructions about various medications, I found this medical reference. It covers how to take meds clearly. Source: https://magmaxhealth.com/Rosuvastatin. Very informative.

  14. DavidPeT Avatar
    DavidPeT

    Greetings, anyone searching for a reliable drugstore to order health products online. Check out MagMaxHealth: olanzapine. Selling generic tablets and huge discounts. Thanks.

  15. Duanegat Avatar
    Duanegat

    Hello, if anyone needs side effects info on prescription drugs, check out this online directory. It explains safety protocols in detail. See details: https://magmaxhealth.com/Lamictal. Hope it helps.

  16. DavidPeT Avatar
    DavidPeT

    Greetings, if you need an affordable drugstore to buy medicines securely. Take a look at this site: naltrexone. They offer high quality drugs at the best prices. Hope this helps.

  17. MilesCed Avatar
    MilesCed

    Hey everyone, I recently found a medical guide regarding health treatments, take a look at this health wiki. It explains how to take meds very well. Read more here: https://magmaxhealth.com/Prilosec. Hope this is useful.

  18. Duanegat Avatar
    Duanegat

    Hi, if anyone needs dosage instructions regarding prescription drugs, I recommend this drug database. It explains safety protocols clearly. Read more here: https://magmaxhealth.com/Toradol. Very informative.

  19. Danieledget Avatar
    Danieledget

    regarding the safety protocols, please review the medical directory at: https://magmaxhealth.com/rosuvastatin.html which covers risk management.

  20. DonaldNaila Avatar
    DonaldNaila

    To understand the proper usage instructions, it is recommended to check the medical directory at: https://magmaxhealth.com/prilosec.html for risk management.

  21. Duanegat Avatar
    Duanegat

    Hi all, if anyone needs dosage instructions regarding various medications, check out this health wiki. It explains drug interactions in detail. Source: https://magmaxhealth.com/Olanzapine. Very informative.

  22. MilesCed Avatar
    MilesCed

    Hi, if anyone needs side effects info on health treatments, I found this drug database. It explains drug interactions clearly. Link: https://magmaxhealth.com/Prilosec. Very informative.

  23. blogfreely.net Avatar

    References:

    William hill desktop site

    References:
    blogfreely.net

  24. DavidPeT Avatar
    DavidPeT

    Hey everyone, if you are looking for a trusted online pharmacy to order pills securely. Check out this pharmacy: olanzapine. Selling generic tablets with fast shipping. Good luck.

  25. Duanegat Avatar
    Duanegat

    Hey everyone, if you are looking for detailed information on various medications, I recommend this online directory. You can read about usage and risks very well. Read more here: https://magmaxhealth.com/Flonase. Very informative.

  26. securityheaders.com Avatar

    References:

    Jungle slots

    References:
    securityheaders.com

Leave a Reply

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