I have this script.php file which i want to run as a cron job on my linux/apache server.
However, i do not want public to access www.mycompanyname.com/script.php and also run the script concurrently.
How can we prevent that? How can we restrict the script to the server's access only? Is it using chmod or setting something inside .htaccess file, something along the line?
Any advice ?
You can do this as the first line of PHP in script.php
...
if (PHP_SAPI !== 'cli') {
exit;
}
If someone hits your script via HTTP, the PHP_SAPI
will be cgi
I believe, and not cli
, causing your script to exit straight away.
Of course, this relies on your cron calling php script.php
.
You could also send...
header('HTTP/1.0 404 Not Found');
... or of course, leave it outside your web root.
If you put the script outside of the webroot folder it will not be accessible through your webserver. e.g. your webroot is at /var/www/public_html/ you put the script.php outside of that folder, for example: /var/www/
You probably have something like a public_html
directory, in which you have all the phps. Just put it outside of that directory.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With