开发者

Any easier way to do $name = $_REQUEST["name"];?

So I'm new to PHP and am trying to create a form. I accept a bunch of parameters and want to process them in the same pag开发者_开发知识库e. I'm not sure how to do this without a giant if-else containing the entire page as if($_POST). This doesn't seem ideal.

In addition, I'm finding that I do the following a lot. Is there any way to shorten this? The names all remain the same.

$name = $_REQUEST["name"];
$gender = $_REQUEST["gender"];
$age = $_REQUEST["age"];

And I have a lot of lines which are just doing that, and it seems terribly inefficient


You can use the extract() function to do that. But it has a security downside: existing variables can be overwritten if someone would add variables to the POST header.

Edit: hsz's solution is better


What process you are doing with if..else..if you have to post the code so that we can let you know how that can be shorten.

you can avoid the assignment for each variable using extract function.

extract($_POST);

But be aware that can overwrite your existing variable if the are named same as your input controls.


Stop using $_REQUEST, because it is a combination of $_COOKIE , $_POST and $_GET. It becomes a security risk.


Instead of using $_REQUEST you should use $_POST here.

$keys = array('name', 'gender', 'age');
foreach ( $keys as $key ) {
  if ( isset($_POST[$key]) ) {
    $$key = $_POST[$key];
  }
  // optional:
  else {
    $$key = ''; // default value
  }
}


Magic quotes? http://php.net/manual/en/security.magicquotes.php


For the first thing: Turn it around. Don't do

if ($_POST) {
 // Your handling code
} else {
 echo "No data!";
}

do

if (!$_POST) {
 die("No data!");
}
// Your handling code


You can use extract(), however, this means that you're bringing in a lot of variables that you (might not know about) int your current scope.

My suggestion would be to loop through your array and do something with the variables in there (e.g. - validation)

foreach ($_POST as $key => $valu) {
   //do something with the variables
}

Also, don't use $_REQUEST unless you really want to check $_GET, $_POST and $_COOKIE. Use the proper array when accessing variables or people can send data you don't expect.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜