Как использовать внешние переменные (например, POST / GET) в PHP с уровнем ошибки E_NOTICE - PullRequest
0 голосов
/ 13 октября 2009

Я ищу лучший способ использования внешних переменных в PHP с уровнем ошибок, включая E_NOTICE.

У меня есть три возможных пути, я был бы рад, если бы вы могли дать несколько советов по каждому или предложить другой подход, который вам нравится.

class WebApp {

    public static function _GET($Index) {
        if (isset($_GET[$Index])) {
            return $_GET[$Index];
        } else {
            return NULL;
        }
    }
}

// E_NOTICE, does not throw a notice:
echo WebApp::_GET('ID');

// E_NOTICE, throws a notice:
echo $_GET['ID'];

2

class RequestSanitizer {
    const V_INTEGER = 1;
    const V_STRING = 2;
    const V_REAL = 3;

    public static function Sanitize($arr) {
        foreach ($arr as $key => $val) {
            if (array_key_exists($key, $_GET)) {
                switch ($val) {
                    case RequestSanitizer::V_INTEGER:
                        $_GET[$key] = $_GET[$key] + 0;
                        break;
                    case RequestSanitizer::V_STRING:
                        $_GET[$key] = $_GET[$key] + '';
                        break;
                    case RequestSanitizer::V_REAL:
                        $_GET[$key] = $_GET[$key] + 0;
                        break;
                }
            } else {
                $_GET[$key] = null;
            }
        }
    }
}

RequestSanitizer::Sanitize(array(
    'GraphID' => RequestSanitizer::V_INTEGER,  
    'UserName' => RequestSanitizer::V_STRING,  
    'Password' => RequestSanitizer::V_STRING,  
    'Price' => RequestSanitizer::V_REAL 
));

echo $_GET['GraphID'];

3

if (isset($_GET['ID']) && ($_GET['ID']+0>0)) {
   echo $_GET['ID']
}

Ответы [ 2 ]

1 голос
/ 13 октября 2009

Я бы использовал

if (isset($_GET['ID']) && ($_GET['ID']+0>0)) {
   echo (int)$_GET['ID']
}

с приведением к целому числу (int). Если значение должно быть целым числом.

0 голосов
/ 13 октября 2009

я бы использовал класс Request, который инкапсулирует все Php «суперглобальные переменные» и предоставляет такие методы, как «param ()», «numParam ()», «arrayParam ()» и т.

$req = new Request();
$user_id = $req->numParam('id');
 // user_id is guaranteed to be a valid integer or 0
...