Author |
Message |
Dawg
RavenNuke(tm) Development Team
data:image/s3,"s3://crabby-images/3704c/3704c29e2cfe2ff2e85a730db92047deba398f37" alt=""
Joined: Nov 07, 2003
Posts: 928
|
Posted:
Sun Sep 16, 2007 9:12 pm |
|
Greetings All,
I am using the include function in several apps and I just wanted to make sure I am doing it correctly and securely.
Code:
<?php
$path = 'pages/';
$extension = '.php';
if ( preg_match("#^[a-z0-9_]+$#i",$page) ){
$filename = $path.$page.$extension;
include($filename);
}
?>
|
Does this look right or is there a better way?
Dave |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 5:55 am |
|
I started playing around with this today and my first example I could not get to work....
Code:<?php
$path="/full/path/to/script/";
if (getdomain($path) == 'yourdomain'){
include($path.'somefile.php');
}
?>
|
I am going to try this one now.... |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 5:56 am |
|
but that is not going to work with a remote include.....back to the drawing board... |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
Site Admin
data:image/s3,"s3://crabby-images/90769/907690f0b3800b7c3631940ce09741fc8d7ec9ba" alt=""
Joined: Aug 29, 2004
Posts: 9457
Location: Arizona
|
Posted:
Mon Sep 17, 2007 6:14 am |
|
The important thing to keep in mind is that you can use relative pathing, but it is relative to the original script that was requested via the browser. So, for example, if this is a nuke module, than the script which was requested was modules.php (unless include_path is being used - rare).
Another thing to keep in mind is variable scope. If you include a file within a function, for example, the variables and code become a part of that function's scope. |
_________________ Only registered users can see links on this board! Get registered or login!
Only registered users can see links on this board! Get registered or login! |
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
montego
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 6:15 am |
|
Sorry, forgot to mention a few other things:
Some hosts will restrict you from being able to include a file that is outside your web account, so if that is what you were trying to do in the first example, what was the error?
Also, many hosts restrict remote includes... |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 6:29 am |
|
montego,
Thank You for replying this really has me stumped!
I have the scripts working with a regular include. I am just trying to secure them againest injection.
Code:
<?php
$path = 'http://www.mysever.com/path1/path2/';
$extension = '.php';
if ( preg_match("#^[a-z0-9_]+$#i",$page) ){
$filename = $path.$page.$extension;
include($filename);
}
?>
|
I would have thought that would work....but it doesn't....
Hackers are such a PITA!
Dawg |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 6:34 am |
|
Would this stop them from injecting?
Code:
$myserver="http://www.mysever.com";
$path="/full/path/to/script/";
if ($myserver($path) == 'myserver'){
include($myserver.$path.'somefile.php');
}
|
|
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 8:04 am |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
technocrat
Life Cycles Becoming CPU Cycles
data:image/s3,"s3://crabby-images/35c25/35c259de005947897e9e0165c0980cfaa17df688" alt=""
Joined: Jul 07, 2005
Posts: 511
|
Posted:
Mon Sep 17, 2007 9:04 am |
|
Use base paths instead.
example:
Lets say that a file your including is in the same folder as this file. You would use
include_once(dirname(__FILE__).'/file.php');
If it's lets say
/html/blocks/file.php
And this file is
/html/modules/whatever/includer.php
include_once(dirname(dirname(dirname(__FILE__)))).'/blocks/file.php');
This should help you stop anything that is not alphanumeric or a _
if (preg_match("/[^\w_\-]/i",$file)) {
die('Invalid File Name');
} |
_________________ Only registered users can see links on this board! Get registered or login!
Only registered users can see links on this board! Get registered or login! / Only registered users can see links on this board! Get registered or login! |
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 9:16 am |
|
technocrat,
Thank You for the input but it is a remote file that I am including. I have a bunch of weather models that run on another server (my server....my models) and these includes bring in the files to be included in the site.
Problem one is getting rid of other sites that were using my stuff as their own....I fixed that. Now I am just trying to secure everything down tight to keep out the hackers.
Thank You again for your time and input cause I am STUCK!
Dawg |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
Former Moderator in Good Standing
data:image/s3,"s3://crabby-images/e0184/e0184c289d846a553594e6ddcdc67f3354a52fed" alt=""
Joined: Apr 06, 2006
Posts: 2415
Location: Iowa, USA
|
Posted:
Mon Sep 17, 2007 9:56 am |
|
Dawg wrote: |
I have the scripts working with a regular include. I am just trying to secure them againest injection.
Code:
<?php
$path = 'http://www.mysever.com/path1/path2/';
$extension = '.php';
if ( preg_match("#^[a-z0-9_]+$#i",$page) ){
$filename = $path.$page.$extension;
include($filename);
}
?>
|
I would have thought that would work....but it doesn't....
Hackers are such a PITA!
Dawg |
Your regular expression seems fine to me at first glance. If in doubt test it first before trying to use it in the include_once.
If instead you know in advance what "pages" you are going to call on the remote server you could forgo the regular expression and do something like:
Code:
$allowedPages = array('xyz', 'aaa', 'etc');
if (in_array($page, $allowedPages))
{
include_once ...
}
|
Your host may not allow remote inclusion and maybe that is why it isn't working. |
_________________ Only registered users can see links on this board! Get registered or login! - An Event Calendar for PHP-Nuke
Only registered users can see links on this board! Get registered or login! - A Google Maps Nuke Module |
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Dawg
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 10:53 am |
|
Gremmie,
Thank You for your time. It works just fine with include...I just want to lock it down from the hackers.
Dave |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
Gremmie
data:image/s3,"s3://crabby-images/6ea31/6ea3138e9a23822aea960115951a6c1ae34639ea" alt=""
|
Posted:
Mon Sep 17, 2007 1:34 pm |
|
Your code that I quoted looked fine. Why did you say it didn't work? |
|
|
|
data:image/s3,"s3://crabby-images/74676/7467655c43f84619d5d7cf725b1d668453dba0fe" alt="" |
|