PHP DZone Story Information Grabber

By  on  

Having a user submit a post to DZone is great for several reasons:

  • A reader thinks enough of what you wrote to want to share it with others.
  • Your blog gets more readership.
  • Your blog revenue increases.
  • The inlink and traffic boost improve your search engine rank and Alexa ranks.
  • The new visitors may post comments, which may enhance your article.

Surely there are numerous more. Thus, it's important to keep track of the information about your article provided by DZone. Luckily, using some quick PHP code, you can grab relevant information right from DZone. All you need to know is the DZone URL that features your article.

The Code

/* step 1:  download the page content */
$dzone_content = file_get_contents('http://www.dzone.com/links/f_programming_fast_guide.html');

/* step 2:  parse it! */
$votes_up = get_match('/class="ldStats-up">(.*)<\/li>/isU',$dzone_content);
$votes_down = get_match('/class="ldStats-down">(.*)<\/li>/isU',$dzone_content);
$views = get_match('/class="ldStats-views">(.*)<\/li>/isU',$dzone_content);
$clicks = get_match('/class="ldStats-clicks">(.*)<\/li>/isU', $dzone_content);

/* step 3:  echo */
echo 'Up Votes: ',$votes_up,'<br />';
echo 'Down Votes: ',$votes_down,'<br />';
echo 'Views: ',$views,'<br />';
echo 'Clicks: ',$clicks,'<br />';

/* helper:  does regex */
function get_match($regex,$content)
{
	preg_match($regex,$content,$matches);
	return $matches[1];
}

One note: each usage of this script increments DZone's "views" stat, so if you plan on keeping accurate statistics, record the number of requests to the page and subtract that from the total.

Recent Features

  • By
    Send Text Messages with PHP

    Kids these days, I tell ya.  All they care about is the technology.  The video games.  The bottled water.  Oh, and the texting, always the texting.  Back in my day, all we had was...OK, I had all of these things too.  But I still don't get...

  • By
    Create a CSS Flipping Animation

    CSS animations are a lot of fun; the beauty of them is that through many simple properties, you can create anything from an elegant fade in to a WTF-Pixar-would-be-proud effect. One CSS effect somewhere in between is the CSS flip effect, whereby there's...

Incredible Demos

  • By
    9 Incredible CodePen Demos

    CodePen is a treasure trove of incredible demos harnessing the power of client side languages.   The client side is always limited by what browsers provide us but the creativity and cleverness of developers always pushes the boundaries of what we think the front end can do.  Thanks to CSS...

  • By
    Fading Links Using jQuery:  dwFadingLinks

    UPDATE: The jQuery website was down today which caused some issues with my example. I've made everything local and now the example works. Earlier this week, I posted a MooTools script that faded links to and from a color during the mouseover and mouseout events.

Discussion

  1. I added some lines for those who are behind a proxy, also you have an extra on line 8 but this is a good one to track your posts on DZone :)

    /* step 1: download the page content */
    $default_opts = array(‘http’=>array(
    ‘method’=>”GET”,
    ‘header’=>”Accept-language: en\r\n” . “Cookie: foo=bar”,
    ‘proxy’=>”tcp://http-proxy.mycompany.com:80″));
    $def = stream_context_get_default($default_opts);
    $dzone_content = file_get_contents(‘http://www.dzone.com/links/f_programming_fast_guide.html’);
    
    /* step 2: parse it! */
    $votes_up = get_match(‘/class=”ldStats-up”>(.*)/isU’, $dzone_content);
    $votes_down = get_match(‘/class=”ldStats-down”>(.*)/isU’, $dzone_content);
    $views = get_match(‘/(.*)/isU’, $dzone_content);
    $clicks = get_match(‘/(.*)/isU’, $dzone_content);
    
    /* step 3: echo */
    echo ‘Up Votes: ‘,$votes_up,”;
    echo ‘Down Votes: ‘,$votes_down,”;
    echo ‘Views: ‘,$views,”;
    echo ‘Clicks: ‘,$clicks,”;
    
    /* helper: does regex */
    function get_match($regex, $content){
    preg_match($regex, $content, $matches);
    return $matches[1];
    }
    

Wrap your code in <pre class="{language}"></pre> tags, link to a GitHub gist, JSFiddle fiddle, or CodePen pen to embed!