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

  1. WilliamTon Avatar
    WilliamTon

    http://primelinepharmacy.com/# cheapest ed online

  2. Edwardsew Avatar
    Edwardsew

    pin up kz казино онлайн: pin up

  3. Whitneycer Avatar
    Whitneycer

    cheapest online ed treatment Pharmacological Sciences Research Institute ed medications online

  4. WilliamTon Avatar
    WilliamTon

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

  5. WilliamTon Avatar
    WilliamTon

    http://corevitalpharmacy.com/# CoreVital Pharmacy

  6. RickyKah Avatar
    RickyKah

    pin up 634: pin up

  7. Whitneycer Avatar
    Whitneycer

    cheap ed medication Pharmacological Institute get ed meds online

  8. WilliamTon Avatar
    WilliamTon
  9. DewayneAlmok Avatar
    DewayneAlmok

    https://pharmacologicalsciences.com/ Pharmacological Sciences Research Institute

  10. RickyKah Avatar
    RickyKah

    pin up kz: pin up

  11. Whitneycer Avatar
    Whitneycer

    best online ed medication Pharmacological Sciences ed treatment online

  12. WilliamTon Avatar
    WilliamTon

    https://novamenpharmacy.shop/# Generic Viagra online

  13. Ralphfoogs Avatar
    Ralphfoogs

    buy antibiotics for sinus antibiotics prescribed antibiotics online

  14. Richardemina Avatar
    Richardemina

    antibiotics Doxycycline Hyclate antibiotics

  15. Ralphfoogs Avatar
    Ralphfoogs

    antibiotics online prescription OTC antibiotics antibiotics online pharmacy

  16. Louisvap Avatar
    Louisvap

    https://antimicrobialresearch.com/ Institute for Antimicrobial Research

  17. Richardemina Avatar
    Richardemina

    prescription antibiotic Antibiotics Pharmacology otc uti medicine

  18. RonaldSon Avatar
    RonaldSon

    https://antimicrobialresearch.com/amoxil.html Sulfamethoxazole Trimethoprim

  19. WilliamBom Avatar
    WilliamBom

    OTC antibiotics antibiotic without presription

  20. Ralphfoogs Avatar
    Ralphfoogs

    get antibiotics quickly Institute for Antimicrobial Research buy antibiotics from india

  21. Richardemina Avatar
    Richardemina

    antibiotics online prescription Amoxicillin Trihydrate antibiotics online pharmacy

  22. Ralphfoogs Avatar
    Ralphfoogs

    antibiotics over the counter Amoxicillin Trihydrate antibiotics online pharmacy

  23. WilliamBom Avatar
    WilliamBom

    Doxycycline Hyclate Over the counter antibiotics for infection

  24. Richardemina Avatar
    Richardemina

    antibiotics for uti Doxycycline Hyclate buy doxycycline antibiotics

  25. Ralphfoogs Avatar
    Ralphfoogs

    generic antibiotics online pharmacy Ciprofloxacin Hydrochloride buy amoxicillin antibiotic

  26. Richardemina Avatar
    Richardemina

    buy antibiotics online safely Institute for Antimicrobial Research prescription antibiotic

  27. Ralphfoogs Avatar
    Ralphfoogs

    over the counter antibiotics Sulfamethoxazole Trimethoprim prescription antibiotic

  28. Dang k'y binance us Avatar

    Thanks for sharing. I read many of your blog posts, cool, your blog is very good. https://www.binance.com/register?ref=JW3W4Y3A

  29. WilliamBom Avatar
    WilliamBom

    Sulfamethoxazole Trimethoprim buy antibiotics from india

  30. Richardemina Avatar
    Richardemina

    buy antibiotics for uti Doxycycline Hyclate antibiotics for uti over the counter

  31. Ralphfoogs Avatar
    Ralphfoogs

    antibiotics online purchase IARP buy antibiotics for uti

  32. Louisvap Avatar
    Louisvap

    https://antimicrobialresearch.com/ Institute for Antimicrobial Research

  33. Ralphfoogs Avatar
    Ralphfoogs

    generic antibiotics online pharmacy Ciprofloxacin Hydrochloride antibiotics online purchase

  34. Richardemina Avatar
    Richardemina

    best online doctor for antibiotics Antibiotics Pharmacology antibiotics online purchase

  35. Ralphfoogs Avatar
    Ralphfoogs

    antibiotics for uti IARP over the counter antibiotics

  36. Richardemina Avatar
    Richardemina

    antibiotic without presription Amoxicillin Trihydrate buy doxycycline antibiotics

  37. RonaldSon Avatar
    RonaldSon

    https://antimicrobialresearch.com/bactrim.html Sulfamethoxazole Trimethoprim

  38. Louisvap Avatar
    Louisvap
  39. WilliamBom Avatar
    WilliamBom

    Sulfamethoxazole Trimethoprim buy antibiotics for uti

Leave a Reply

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