PHP CLI Tips and Tricks
PHPWomen Contest Winner
ByPHPWomen.org recently held an article-writing contest on their Best Practices Forum. Authors of the two winning submissions each received copies of Zend Studio for Eclipse, a 1-year subscription to Linux Pro Magazine (which is called Linux Magazine outside North America), and the opportunity to feature their articles on the magazine websites. Congratulations goes to Gerard Sychay for his winning submission!
It's not called the Command Line Interface for nothing. I programmed in PHP for a long time without even looking at the PHP CLI. When I finally did, I started appreciating all of its usefulness and features. Now I'd say I use it almost every day.
In this article, I'll show you three quick tips that can boost your PHP development productivity. Let's dive right in:
`php -r`
Did you know you can execute a line of PHP with the -r option? Use it like this:
% php -r 'echo "Hello world!\n";'
Hello world!
Note that everything inside the single apostrophes must be valid PHP syntax, so mind your double quotes and semi-colons. This has a number of uses. For example, how about some quick math?
% php -r 'echo sqrt(150)."\n";'
12.247448713916
Or finding out what week of the year we're in?
%$ php -r 'echo date("W") . "\n";'
26
Or finding out what day of the week Independence Day in the U.S. falls on next year?
% php -r 'echo date("l", strtotime("2009-07-04")) . "\n";'
Saturday
Or generating a random number for the office raffle?
% php -r 'echo rand(0, 100) . "\n";'
33
Sometimes, I just need a bunch of random letters and numbers. I find a random md5 hash usually does the trick:
% php -r 'echo md5(uniqid(rand(), true)) . "\n";'
faa5f6cd713bcfb64aa0b297d62c5345
You get the idea.
PHP Interactive Shell
I don’t know whether it’s really a shell, but it gets the job done. Have you ever wanted to test a small snippet of PHP code? You might have a small test script somewhere under a web server root you can quickly access. It’s a pain. With interactive PHP, you can test these right from the command line!
% php -a
Interactive mode enabled
<?php
echo "hello world!\n";
hello world!
exit;
%
This is great for figuring out little problems or little snippets of code while developing. For example, I can never remember where the $haystack and where the $needle go in assorted string functions:
% php -a
Interactive mode enabled
<?php
// does the $needle or $haystack come first?
echo strpos("lo", "hello");
echo strpos("hello", "lo");
3
// so the $haystack comes first
Or how about figuring out that regular expression you need?
% php -a
Interactive mode enabled
<?php
// get rid of all characters but "abc"
$regex = "/^[abc]/";
echo preg_replace($regex, "", "abcdef");
bcdef
// oops, that gets rid of [abc] occurring at the line beginning
// let's try again
$regex = "/[^abc]/";
echo preg_replace($regex, "", "abcdef");
abc
// that's what I wanted
PHP Command Interpreter
This isn't really a command-line tip, but you might it useful if you are on Unix. You know you can execute a PHP script by running php myscript.php, but did you know you don't even need the php command?
When Unix runs a script, it looks for a command interpreter to interpret the script at the very top of the file. The command interpreter line begins with the shebang string (#!). You probably have done this with shell scripts, but you can do it with PHP scripts as well. So, if you have a PHP script named myscript.php that looks like this:
#!/usr/bin/php
<?php
echo "Hello world again!\n";
?>
You can run this script by running the file name:
% ./myscript.php
Hello world again!
(Make sure the file is executable.) So if you have an awesome PHP script that does some task for you, or a PHP script that deploys your site, you can put the script in your $PATH and simply call it like any other Unix command.
That's about it. There are a few other PHP CLI features you might find useful. For example, php -l will run a syntax check on PHP code, and php -i will give you output similar to the phpinfo() function.
Are there any other interesting ways you've used the PHP CLI?
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
So Long Neofetch and Thanks for the Info
Today is a day that every Linux user who enjoys bragging about their system(s) will mourn, as Neofetch has come to an end.
-
Ubuntu 24.04 Comes with a “Flaw"
If you're thinking you might want to upgrade from your current Ubuntu release to the latest, there's something you might want to consider before doing so.
-
Canonical Releases Ubuntu 24.04
After a brief pause because of the XZ vulnerability, Ubuntu 24.04 is now available for install.
-
Linux Servers Targeted by Akira Ransomware
A group of bad actors who have already extorted $42 million have their sights set on the Linux platform.
-
TUXEDO Computers Unveils Linux Laptop Featuring AMD Ryzen CPU
This latest release is the first laptop to include the new CPU from Ryzen and Linux preinstalled.
-
XZ Gets the All-Clear
The back door xz vulnerability has been officially reverted for Fedora 40 and versions 38 and 39 were never affected.
-
Canonical Collaborates with Qualcomm on New Venture
This new joint effort is geared toward bringing Ubuntu and Ubuntu Core to Qualcomm-powered devices.
-
Kodi 21.0 Open-Source Entertainment Hub Released
After a year of development, the award-winning Kodi cross-platform, media center software is now available with many new additions and improvements.
-
Linux Usage Increases in Two Key Areas
If market share is your thing, you'll be happy to know that Linux is on the rise in two areas that, if they keep climbing, could have serious meaning for Linux's future.
-
Vulnerability Discovered in xz Libraries
An urgent alert for Fedora 40 has been posted and users should pay attention.