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

  1. JamesJep Avatar
    JamesJep
  2. Jeffreybrump Avatar
    Jeffreybrump

    mexican drugstore shipping to usa: mexican drugstore shipping to usa – mexican meds

  3. DanielSpere Avatar
    DanielSpere

    licensed canadian drug suppliers: licensed canadian drug suppliers – licensed canadian drug suppliers

  4. JamesFaw Avatar
    JamesFaw

    https://trustedindiacarerx.com/# best online pharmacy no prescription

  5. Jeffreybrump Avatar
    Jeffreybrump

    BorderValue RX: mexico border medications usa access – pharmacys in mexico

  6. DanielSpere Avatar
    DanielSpere

    rx pharmacy: verified india drug manufacturers – canada rx pharmacy world

  7. JamesFaw Avatar
    JamesFaw

    https://bordervaluerx.com/# mexico border medications usa access

  8. DanielSpere Avatar
    DanielSpere

    licensed canadian drug suppliers: safe online pharmacies in canada – CertifiedMaple RX

  9. Jeffreybrump Avatar
    Jeffreybrump

    walmart pharmacy online: india medication delivery to usa – the peoples pharmacy

  10. JamesFaw Avatar
    JamesFaw

    https://certifiedmaplerx.com/# licensed canadian drug suppliers

  11. DanielSpere Avatar
    DanielSpere

    super pharmacy: trusted indian pharmacy usa – order pharmacy online egypt

  12. Jeffreybrump Avatar
    Jeffreybrump

    affordable border pharmacy mexico: mexican drugstore shipping to usa – mexico border medications usa access

  13. JamesFaw Avatar
    JamesFaw

    http://trustedindiacarerx.com/# canadian pharmacy in canada

  14. 45.144.30.78 Avatar

    References:

    Bodybuilder supplement stacks

    References:
    https://lyfeclick.com/@ammlinnea57146

  15. http://8.217.32.95 Avatar

    References:

    Three risks of using anabolic steroids and other performance-enhancing drugs

    References:
    https://koseongnam.com/terrasimon2715

  16. DanielSpere Avatar
    DanielSpere

    BorderValueRX: BorderValue RX – affordable border pharmacy mexico

  17. www.godhip.com Avatar

    References:

    Most popular steroids for bodybuilding

    References:
    https://eduxhire.com/employer/free-testosterone-levels-by-age-pg-ml/

  18. Jeffreybrump Avatar
    Jeffreybrump

    CertifiedMaple RX: canadian medication delivery to usa – CertifiedMaple RX

  19. https://www.ttd.group/johnpohlman245 Avatar

    References:

    Best injectable steroids for beginners

    References:
    https://cyprusjobs.com.cy/companies/neck-wikipedia/

  20. www.scserverddns.top Avatar

    References:

    Natural legal steroids

    References:
    http://43.139.240.37:17000/astrid1270396

  21. gitea.bel.blue Avatar

    References:

    Interesting facts about steroids

    References:
    http://crontab.club:30015/jonellesamuels

  22. git.silvertone.com.au Avatar

    References:

    Best stack supplements get ripped

    References:
    http://106.55.0.66:31807/skyeclemons019

  23. https://git.alderautomation.ca Avatar

    References:

    Best cutting steroid stack

    References:
    https://code.nspoc.org/sammycarr96093

  24. http://118.89.79.106 Avatar

    References:

    Metabolic fitness can be achieved through

    References:
    https://git.mana-web.com/monaf402533537

  25. DanielSpere Avatar
    DanielSpere

    BorderValue RX: mexican drugstore shipping to usa – BorderValue RX

  26. Jeffreybrump Avatar
    Jeffreybrump

    canadian medication delivery to usa: certified canadian pharmacy usa – licensed canadian drug suppliers

  27. 34.17.182.140 Avatar

    References:

    Steroids before and after 1 cycle

    References:
    http://10-day.net/bbs/board.php?bo_table=free&wr_id=3202636

  28. gitea.shirom.me Avatar

    References:

    Bodybuilders after steroids

    References:
    http://20.249.208.89:3000/karolynchu186

  29. allasguru.com Avatar

    References:

    Test steroid for sale

    References:
    http://59.80.22.43:30000/barneywiseman0

  30. www.telugustatusvideo.com Avatar

    References:

    Supplements to take with steroids

    References:
    http://120.77.174.236:3000/florencewalpol

  31. Allendwems Avatar
    Allendwems

    http://stericarepharmacy.com/# prednisone for sale

  32. 104.254.131.244 Avatar

    References:

    Anabolic mass gainer side effects

    References:
    https://li1420-231.members.linode.com/mellissagvb621

Leave a Reply

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