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

  1. Leonarddeark Avatar
    Leonarddeark

    buy ivermectin nz Iver Therapeutics stromectol 12mg

  2. a-taxi.com.ua Avatar

    References:

    Anabolic steroids prescription

    References:
    a-taxi.com.ua

  3. TracyThics Avatar
    TracyThics
  4. LarryViofs Avatar
    LarryViofs

    best canadian online pharmacy: canadian discount pharmacy – Smart GenRx USA

  5. LinwoodTwirl Avatar
    LinwoodTwirl

    Neuro Relief USA: gabapentin – Neuro Relief USA

  6. wikimapia.org Avatar

    References:

    Anabolic steroids dangers

    References:
    wikimapia.org

  7. LinwoodTwirl Avatar
    LinwoodTwirl

    Neuro Relief USA: neurontin 800 mg tablets – Neuro Relief USA

  8. LarryViofs Avatar
    LarryViofs

    Neuro Relief USA: neurontin for sale – Neuro Relief USA

  9. TracyThics Avatar
    TracyThics

    https://neuroreliefusa.shop/# neurontin 800 mg pill

  10. LinwoodTwirl Avatar
    LinwoodTwirl

    Neuro Relief USA: generic neurontin 300 mg – Neuro Relief USA

  11. TracyThics Avatar
    TracyThics

    http://neuroreliefusa.com/# generic neurontin cost

  12. LarryViofs Avatar
    LarryViofs

    Neuro Relief USA: neurontin 200 mg price – neurontin pill

  13. LinwoodTwirl Avatar
    LinwoodTwirl

    ivermectin lotion: buy ivermectin uk – Iver Therapeutics

  14. to-portal.com Avatar

    References:

    Steroid over the counter

    References:
    to-portal.com

  15. TracyThics Avatar
    TracyThics

    http://ivertherapeutics.com/# ivermectin cream canada cost

  16. LinwoodTwirl Avatar
    LinwoodTwirl

    neurontin 100 mg cost: Neuro Relief USA – neurontin tablets 100mg

  17. GlennTix Avatar
    GlennTix

    https://neuroreliefusa.com/# neurontin 300 mg tablets

  18. LarryViofs Avatar
    LarryViofs

    canadian drug stores: generic viagra online canadian pharmacy – canada drugs online review

  19. Leonarddeark Avatar
    Leonarddeark

    Neuro Relief USA Neuro Relief USA Neuro Relief USA

  20. TracyThics Avatar
    TracyThics
  21. LinwoodTwirl Avatar
    LinwoodTwirl

    zoloft generic: buy zoloft – zoloft buy

  22. LarryViofs Avatar
    LarryViofs

    Iver Therapeutics: Iver Therapeutics – ivermectin 1 cream generic

Leave a Reply

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