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

3,879 responses to “Using the BitLy API to shorten urls”

  1. PedroMorne Avatar
    PedroMorne

    https://antibiotics.cheap/# over the counter antibiotics

  2. Edgaraligh Avatar
    Edgaraligh

    over the counter antibiotics: over the counter antibiotics – over the counter antibiotics

  3. EliasRaiff Avatar
    EliasRaiff

    rybelsus oral tablet: can you lose weight on rybelsus – us pharmacy no prescription

  4. DanielAnank Avatar
    DanielAnank

    https://stromectol.reviews/# stromectol reviews

  5. Edgaraligh Avatar
    Edgaraligh

    stromectol reviews: can you buy stromectol over the counter – stromectol reviews

  6. DavidBam Avatar
    DavidBam

    stromectol reviews stromectol reviews stromectol reviews

  7. EliasRaiff Avatar
    EliasRaiff

    rybelsus attorney: 14 mg rybelsus to mounjaro – online pharmacies

  8. PedroMorne Avatar
    PedroMorne

    https://semaglutide.life/# rybelsus used for

  9. DanielAnank Avatar
    DanielAnank

    https://antibiotics.cheap/# over the counter antibiotics

  10. Edgaraligh Avatar
    Edgaraligh

    online semaglutide: semaglutide life – top-rated online pharmacies

  11. EliasRaiff Avatar
    EliasRaiff

    antibiotics over the counter: antibiotics cheap – antibiotics cheap

  12. DanielAnank Avatar
    DanielAnank

    https://semaglutide.life/# is compounded semaglutide, the same as ozempic

  13. PedroMorne Avatar
    PedroMorne

    https://semaglutide.life/# how many mg is 5 units of semaglutide

  14. Edgaraligh Avatar
    Edgaraligh

    stromectol reviews: stromectol reviews – stromectol reviews

  15. EliasRaiff Avatar
    EliasRaiff

    stromectol reviews: ivermectin lotion for lice – stromectol reviews

  16. DavidBam Avatar
    DavidBam

    retatrutide vs semaglutide rybelsus vs ozempic weight loss does rybelsus have semaglutide

  17. DanielAnank Avatar
    DanielAnank

    https://stromectol.reviews/# stromectol reviews

  18. Edgaraligh Avatar
    Edgaraligh

    can semaglutide make you tired: rybelsus precio en walmart – us pharmacy no prescription

  19. EliasRaiff Avatar
    EliasRaiff

    ivermectin tablets: stromectol reviews – buy ivermectin canada

  20. PedroMorne Avatar
    PedroMorne

    https://antibiotics.cheap/# antibiotics cheap

  21. DanielAnank Avatar
    DanielAnank

    https://stromectol.reviews/# stromectol reviews

  22. Edgaraligh Avatar
    Edgaraligh

    pastillas rybelsus para que sirve: semaglutide life – no rx needed pharmacy

  23. EliasRaiff Avatar
    EliasRaiff

    stromectol tablet 3 mg: stromectol reviews – stromectol without prescription

  24. DavidBam Avatar
    DavidBam

    stromectol reviews ivermectin canada stromectol reviews

  25. DanielAnank Avatar
    DanielAnank
  26. Edgaraligh Avatar
    Edgaraligh

    stromectol reviews: stromectol reviews – stromectol reviews

  27. PedroMorne Avatar
    PedroMorne

    https://stromectol.reviews/# stromectol reviews

  28. EliasRaiff Avatar
    EliasRaiff

    stromectol reviews: ivermectin price uk – stromectol 3mg

  29. binance Registrera dig Avatar

    Your article helped me a lot, is there any more related content? Thanks!

Leave a Reply

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