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

  1. AndrewMuh Avatar
    AndrewMuh

    vet pharmacy: Vet Rx Index – online vet pharmacy

  2. TylerShets Avatar
    TylerShets
  3. Henryaloth Avatar
    Henryaloth

    https://mensrxindex.shop/# cheapest erectile dysfunction pills

  4. AndrewMuh Avatar
    AndrewMuh

    Mens RX Index: Mens RX Index – Mens RX Index

  5. RobertFup Avatar
    RobertFup

    where to buy erectile dysfunction pills Mens RX Index Mens RX Index

  6. Williamchabe Avatar
    Williamchabe

    pet med: Vet Rx Index – canada pet meds

  7. Henryaloth Avatar
    Henryaloth
  8. AndrewMuh Avatar
    AndrewMuh

    pet meds for dogs: pet meds for dogs – vet pharmacy

  9. TylerShets Avatar
    TylerShets

    https://mensrxindex.shop/# erectile dysfunction pills online

  10. AndrewMuh Avatar
    AndrewMuh

    canadian pharmacy meds: Certified Canada Rx – Certified Canada Rx

  11. Williamchabe Avatar
    Williamchabe

    Mens RX Index: best ed meds online – buy ed medication online

  12. RobertFup Avatar
    RobertFup

    discount pet meds pet meds official website pet prescriptions online

  13. TylerShets Avatar
    TylerShets

    https://certifiedcanadarx.com/# pharmacy com canada

  14. AndrewMuh Avatar
    AndrewMuh

    canadian drugs pharmacy: Certified Canada Rx – online canadian pharmacy

  15. binance us тркелу Avatar

    Thank you for your sharing. I am worried that I lack creative ideas. It is your article that makes me full of hope. Thank you. But, I have a question, can you help me?

  16. AndrewMuh Avatar
    AndrewMuh

    Certified Canada Rx: buying drugs from canada – canadian pharmacy drugs online

  17. Williamchabe Avatar
    Williamchabe

    Certified Canada Rx: certified canadian pharmacy – Certified Canada Rx

  18. TylerShets Avatar
    TylerShets

    https://mensrxindex.com/# cheapest ed treatment

  19. AndrewMuh Avatar
    AndrewMuh

    Mens RX Index: best online ed pills – online ed treatments

  20. TylerShets Avatar
    TylerShets

    https://certifiedcanadarx.com/# Certified Canada Rx

  21. Williamchabe Avatar
    Williamchabe

    ed med online: best ed medication online – buy erectile dysfunction treatment

  22. AndrewMuh Avatar
    AndrewMuh

    Mens RX Index: buy erectile dysfunction pills – Mens RX Index

  23. RobertFup Avatar
    RobertFup

    Mens RX Index ed online meds erectile dysfunction meds online

Leave a Reply

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