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

959 responses to “Using the BitLy API to shorten urls”

  1. Kennethdiera Avatar
    Kennethdiera

    Unm Pharm: Unm Pharm – Unm Pharm

  2. Michaelanoli Avatar
    Michaelanoli

    http://unmpharm.com/# buy kamagra oral jelly mexico

  3. CraigKab Avatar
    CraigKab

    india pharmacy mail order top 10 online pharmacy in india pharmacy website india

  4. JosephBab Avatar
    JosephBab

    canadian pharmacy: Nyu Pharm – canadian pharmacies that deliver to the us

  5. Kennethdiera Avatar
    Kennethdiera

    legitimate online pharmacies india: Online medicine home delivery – Umass India Pharm

  6. Michaelanoli Avatar
    Michaelanoli
  7. hit spin auszahlung methode Avatar

    Bei Playio oder auch Cashed gibt es Freispiele, wenn man sein Konto wieder auflädt.
    Freispiele unterliegen auch bestimmten Bonusbedingungen, die Sie unbedingt
    beachten müssen. Einige Casinos vergeben Freispiele an Ihre treuen Kunden, wenn diese Geburtstag haben oder als Teil des Willkommenspakets.

    Beim ersten Blick in den Kassenbereich werdet ihr die Paysafecard
    oftmals nicht sehen, erst nachdem ihr eure Ersteinzahlung vorgenommen habt, wird euch die Paysafecard neben knapp zehn weiteren Bezahlmöglichkeiten angeboten. Nicht
    nutzen könnt ihr die Paysafecard demnach für das Neukundenangebot, welches sich auf
    100 Euro und 500 Freispiele beläuft. Denn auch dort wollt ihr sicherlich
    so wenig wie möglich an Daten preisgeben und seid daher nicht daran interessiert, eure Kreditkarten- oder Bankkartendaten hinterlegen zu wollen. Dieses 2020 gegründete
    Casino, das eine Glücksspiellizenz aus Curacao
    vorweisen kann, kommt nämlich mit einem völlig durchgeknallten Mexiko-Thema daher,
    bei dem fünf nicht unbedingt alltägliche Charaktere im Mittelpunkt stehen. In diesem Online Casino ohne Verifizierung,
    welches eine Glücksspiellizenz aus Curacao vorweisen kann, dürft ihr euch auf mehr als
    3.000 erstklassige Spiele freuen, die natürlich aus allen erdenkbaren Genres stammen. Das Bizzo Casino ist
    ein im Jahr 2021 gegründetes Online Casino, welches von der Techsolution NV Group geleitet wird
    und eine Glücksspiellizenz aus Curacao vorweisen kann.

    References:
    https://online-spielhallen.de/spirit-casino-deutschland-ein-umfassender-einblick-fur-deutsche-spieler/

  8. JosephBab Avatar
    JosephBab

    canadian pharmacy world: Nyu Pharm – canadian pharmacy 24 com

  9. CraigKab Avatar
    CraigKab

    Umass India Pharm reputable indian pharmacies indian pharmacy online

Leave a Reply

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