Support for generators has been added via the yield keyword. Generators provide an easy way to implement simple iterators without the overhead or complexity of implementing a class that implements the Iterator interface.

A simple example that reimplements the range() function as a generator (at least for positive stepvalues):

function xrange($start, $limit, $step = 1) {
for ($i = $start; $i <= $limit; $i += $step) {
yield $i;

echo ‘Single digit odd numbers: ‘;

* Note that an array is never created or returned,
* which saves memory.
foreach (xrange(1, 9, 2) as $number) {
echo “$number “;

echo “\n”;

The above example will output:

Single digit odd numbers: 1 3 5 7 9 

finally keyword added 

try-catch blocks now support a finally block for code that should be run regardless of whether an exception has been thrown or not.

New password hashing API

new password hashing API that makes it easier to securely hash and manage passwords using the same underlying library as crypt() in PHP has been added. See the documentation for password_hash() for more detail.

foreach now supports list()

The foreach control structure now supports unpacking nested arrays into separate variables via the list()construct. For example:

$array = [
[1, 2],
[3, 4],

foreach ($array as list($a, $b)) {
echo “A: $a; B: $b\n”;

The above example will output:

A: 1; B: 2
A: 3; B: 4

Further documentation is available on the foreach manual page.

empty() supports arbitrary expressions 

Passing an arbitrary expression instead of a variable to empty() is now supported. For example:

function always_false() {
return false;

if (empty(always_false())) {
echo “This will be printed.\n”;

if (empty(true)) {
echo “This will not be printed.\n”;

The above example will output:

This will be printed.

array and string literal dereferencing ¶

Array and string literals can now be dereferenced directly to access individual elements and characters:

echo 'Array dereferencing: ';
echo [1, 2, 3][0];
echo "\n";

echo ‘String dereferencing: ‘;
echo ‘PHP'[0];
echo “\n”;

The above example will output:

Array dereferencing: 1
String dereferencing: P

Class name resolution via ::class ¶

It is possible to use ClassName::class to get a fully qualified name of class ClassName. For example:

namespace Name\Space;
class ClassName {}

echo ClassName::class;

echo “\n”;

The above example will output:


OPcache extension added ¶

The Zend Optimiser+ opcode cache has been added to PHP as the new OPcache extension. OPcache improves PHP performance by storing precompiled script bytecode in shared memory, thereby removing the need for PHP to load and parse scripts on each request. See the installation instructions for more detail on enabling and using OPcache.

foreach now supports non-scalar keys ¶

foreach now supports keys of any type. While non-scalar keys cannot occur in native PHP arrays, it is possible for Iterator::key() to return a value of any type, and this will now be handled correctly.

Apache 2.4 handler supported on Windows ¶

The Apache 2.4 handler SAPI is now supported on Windows.

Improvements to GD ¶

Various improvements have been made to the GD extension, these include:



In version 2.5 WordPress introduced shortcodes, and all of us have probably used them at one time or another. They usually come bundled with plugins, or even themes, and what they do is watch for when you insert something inside square brackets then replace that with some other content; it could be a simple sentence or it could be a massive PHP function, it all depends on what you instructed WordPress to do.

Bundled shortcodes are great, and speed up things considerably, but wouldn’t it be great to know how to create shortcodes of your own?

In this article I’ll take you through creating some simple WordPress shortcodes to help you create any functionality you like.


The shortcode API works very simply: first you need to create a callback function that will run anytime the shortcode is used; then you need to tie that function to a specific shortcode making it ready for use. The code is frequently placed in the functions.php file, but if you plan on having a lot of shortcodes, it makes sense to create a separate file and include that file in your functions.php file.

In our first example we want to create a shortcode that will create some lorem ipsum every time we type [lorem] into the editor. First we need to create the callback function that will return the lorem ipsum (in shortcodes we don’t echo anything, everything is returned):

function lorem_function() {
  return 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec nulla vitae lacus mattis volutpat eu at sapien. Nunc interdum congue libero, quis laoreet elit sagittis ut. Pellentesque lacus erat, dictum condimentum pharetra vel, malesuada volutpat risus. Nunc sit amet risus dolor. Etiam posuere tellus nisl. Integer lorem ligula, tempor eu laoreet ac, eleifend quis diam. Proin cursus, nibh eu vehicula varius, lacus elit eleifend elit, eget commodo ante felis at neque. Integer sit amet justo sed elit porta convallis a at metus. Suspendisse molestie turpis pulvinar nisl tincidunt quis fringilla enim lobortis. Curabitur placerat quam ac sem venenatis blandit. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Nullam sed ligula nisl. Nam ullamcorper elit id magna hendrerit sit amet dignissim elit sodales. Aenean accumsan consectetur rutrum.';

Next we need to add this shortcode to WordPress using the add_shortcode function in either our functions.php file or a file that’s being included in it, this function adds the shortcode and also ties it to the function we just created. add_shortcode only takes two arguments, the first one being the name we want this shortcode to have (what we will type between the square brackets) and the second one being the function we want to attach to that shortcode:

add_shortcode('lorem', 'lorem_function');

That is all it takes to create a simple shortcode in WordPress.


Continuing with this dummy content idea, we often need images in our content when we preparing our mockups and these images need to be different sizes, so now we’ll create a shortcode to insert an image like this:

[picture width="500" height="500"]

When WordPress encounters this we want a function that will insert an image. It needs to read the width and height attributes, but just in case we’ll also provide default values so that it can be used without the attributes. Because we may not have an image available, we’re going to use the service to provide us with a random image.

First we need to create the function:

function random_picture($atts) {
      'width' => 400,
      'height' => 200,
   ), $atts));
return '<img src="'. $width . '/'. $height . '" />';

We named this function random_picture and since this shortcode will be able to take arguments we gave it the $atts parameter. In order to use the attributes we need two functions: the shortcode_atts which is a WordPress function that combines our attributes with known attributes and fills in defaults when needed; and the extractPHP function which, as the name suggests, extracts those attributes we set for our shortcode. Finally the function returns the value we want, in this case the HTML code for our image combined with the width and height variables.

The only thing left to do is register this shortcode:

add_shortcode('picture', 'random_picture');

Our shortcode is complete, when we type [picture] it will give us a random image 400 by 200, and if we use the attributes we can create an image of any size we please.


Creating little shortcodes for things we use frequently definitely helps us when writing blog posts because you can do anything you please with shortcodes, it can be as simple as returning a sentence, or as complex as adding a form or the latest posts sorted by month.

Compress Image without loosing the QUALITY

<title>PHP Image</title>
<h1>Image Compression Using PHP</h1>
<form action=”” method=”post” enctype=”multipart/form-data”>
Upload an Image: <input type=”file” name=”image”><br>
Quality: <input type=”number” min=”30″ max=”100″ value=”50″ name=”quality”><br>
<input type=”submit” name=”compress” value=”Compress”>


$img = getimagesize($uploaded_file);

if ($img[‘mime’] == ‘image/jpeg’)
$image = imagecreatefromjpeg($uploaded_file);
elseif ($img[‘mime’] == ‘image/gif’)
$image = imagecreatefromgif($uploaded_file);
elseif ($img[‘mime’] == ‘image/png’)
$image = imagecreatefrompng($uploaded_file);
die($img[‘mime’].’Is unsupported format!!!’);
imagejpeg($image, $output, $quality);
<h3>Original Image (Size: <?php $osize=filesize($uploaded_file); echo round(($osize/1024),2).’ Kb’; ?>)</h3>
<img src=”<?php echo $uploaded_file; ?>”>
<h3>Compressed Image (Size: <?php $osize=filesize($output); echo round(($osize/1024),2).’ Kb’; ?>)</h3>
<img src=”<?php echo $output; ?>”>
<?php } ?>

Some Good Things

Yeah I know. What we tell is what we never do.
But still tell others some good things like
“Don’t get habituated to some things… which we can just tell and not apply for ourselves”

  • Eating junk food.
  •   Watching TV instead of going to the gym.
  •   Showing up to a job you hate everyday.
  •   Biting your nails.
  •   Smoking

They reflect on the below:

  • How in shape or out of shape you are?
  • How happy or unhappy you are?
  • How successful or unsuccessful you are?

Read Emails by PHP

Using IMAP you can read your inbox messages of your gmail account. Here I have shared code below.


            function readMail() {
                        $dns = “{}INBOX”;
                        $email = “Your Mail”;
                        $password = “Password”;
                        $openmail = imap_open($dns,$email,$password ) or die(“Cannot Connect “.imap_last_error());
                        if ($openmail) {
                                    echo  “You have “.imap_num_msg($openmail). ” messages in your inbox\n\r”;
                                    for($i=1; $i <= 100; $i++) {
                                                $header = imap_header($openmail,$i);
                                                echo “<br>”;
                                                echo $header->Subject.” (“.$header->Date.”)”;
                        echo “\n\r”;
                        $msg = imap_fetchbody($openmail,1,””,”FT_PEEK”);
                        $msgBody = imap_fetchbody ($openmail, $i, “2.1”);
                        if ($msgBody == “”) {
                        $partno = “2.1”;
                        $ msgBody = imap_fetchbody ($openmail, $i, $partno);
                        $ msgBody = trim(substr(quoted_printable_decode($msgBody), 0, 200));
                        echo $msg;
                        else {
                        echo “False”;