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

  1. PatrickMoilm Avatar
    PatrickMoilm

    True Health Pharm: True Health Pharm – True Health Pharm

  2. Richardhor Avatar
    Richardhor

    True Health Pharm: True Health Pharm – п»їed pills online

  3. AnthonyUsedy Avatar
    AnthonyUsedy

    dog and cat medicine supply vet pharmacy online HappyPaws Pharmacy

  4. ElmerCix Avatar
    ElmerCix

    http://happypawspharmacy.com/# online pet pharmacy

  5. PatrickMoilm Avatar
    PatrickMoilm

    walmart online pharmacy: VitalCore Pharmacy – buy online pharmacy uk

  6. Richardhor Avatar
    Richardhor

    True Health Pharm: True Health Pharm – True Health Pharm

  7. PatrickMoilm Avatar
    PatrickMoilm

    pet antibiotics and care: HappyPaws Pharmacy – dog prescriptions online

  8. ElmerCix Avatar
    ElmerCix

    http://vitalcorepharmacy.com/# pharmacy in canada for viagra

  9. Richardhor Avatar
    Richardhor

    HappyPaws Pharmacy: dog and cat medicine supply – pet pharmacy USA

  10. AnthonyUsedy Avatar
    AnthonyUsedy

    pet pharmacy vet pharmacy discount pet meds

  11. PatrickMoilm Avatar
    PatrickMoilm

    HappyPaws Pharmacy: pet pharmacy USA – dog and cat medicine supply

  12. Richardhor Avatar
    Richardhor

    mexican pharmacy online: VitalCore Pharmacy – onlinecanadianpharmacy

  13. 34.17.182.140 Avatar

    References:

    Best over the counter muscle builder

    References:
    https://repositories.action2quare.com/tahliaelmer605

  14. GregorySpoib Avatar
    GregorySpoib
  15. https://docker-registry-lszz.uj.com.tw/jamilatilton84 Avatar

    References:

    What are the short term effects of steroids

    References:
    https://www.lizyum.com/@racheleauricht

  16. 43.142.166.108 Avatar

    References:

    Anabolic steroids benefits

    References:
    https://git.clubeye.net/krystalforsyth

  17. ElmerCix Avatar
    ElmerCix

    https://happypawspharmacy.com/# online pet pharmacy

  18. 120.26.116.243 Avatar

    References:

    Clear muscle vs hmb

    References:
    https://heywhatsgoodnow.com/@miriamj540524

  19. lasigal.com Avatar

    References:

    Legit research chemical supplies sites bodybuilding

    References:
    http://guilairo520.gain.tw/viewthread.php?tid=441747&extra=

  20. oa.sccehui.com Avatar

    References:

    Popular anabolic steroids

    References:
    http://1.95.221.174:3000/dick76u1970467

  21. AnthonyUsedy Avatar
    AnthonyUsedy

    trusted canadian pharmacy VitalCore Pharmacy best online pharmacy

  22. PatrickMoilm Avatar
    PatrickMoilm

    pet pharmacy USA: dog and cat medicine supply – pet pharmacy USA

  23. lordhub.vip Avatar

    References:

    Which of the following statements about anabolic steroids is false

    References:
    https://quickdatescript.com/@brandonbatty20

  24. Richardhor Avatar
    Richardhor

    dog and cat medicine supply: pet antibiotics and care – pet pharmacy USA

  25. ElmerCix Avatar
    ElmerCix
  26. PatrickMoilm Avatar
    PatrickMoilm

    pharmacy coupons: VitalCore Pharmacy – canadianpharmacyworld

  27. Richardhor Avatar
    Richardhor

    best pet rx: pet pharmacy USA – HappyPaws Pharmacy

  28. AnthonyUsedy Avatar
    AnthonyUsedy

    online pharmacy weight loss cheap viagra onlinecanadianpharmacy

  29. GregorySpoib Avatar
    GregorySpoib
  30. PatrickMoilm Avatar
    PatrickMoilm

    True Health Pharm: True Health Pharm – True Health Pharm

  31. Richardhor Avatar
    Richardhor

    True Health Pharm: online ed medications – True Health Pharm

  32. Brianbeate Avatar
    Brianbeate

    https://trustrxindia.com/# pharmacy website india

Leave a Reply

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