-1

プロジェクトの編集ユーザー プロファイルを作成しています。このエラーに遭遇しました " Notice: Undefined index: userid in C:\xampp\htdocs\HelloWorld\EditProfile.php on line 18 ". エラーの原因を探すのに 1 時間費やしましたが、見つからないようです。私はここでこのガイドに従いましたphp - フォーラム投稿などの「編集」機能ここに私のコードがあります:

EditProfile.php

<?php 
// connect to SQL
$dbcnx = mysql_connect("localhost", "root", "2345fypj");
if (!$dbcnx)
  {
  echo( "<P>Unable to connect to the database server at this time.</P>" );
  exit();
}

// connect to database
$dbcon = mysql_select_db("my_db", $dbcnx);
if (!$dbcon) {
  echo( "<P>Unable to locate DB table at this time.</P>" );
  exit();
}

//data preparation for the query
$id = intval($_GET['userid']);

// selects title and description fields from database
$sql = "SELECT * FROM user_profile WHERE userid=$id";
$result = mysql_query($sql) or die(mysql_error());        
# retrieved by using $row['col_name']
$row = mysql_fetch_array($result);

?>

<h3>Edit</h3>
<form action="save_edit.php" enctype="multipart/form-data" method="post" name="myForm" />
  <table>
    <tr>
      <td><b>Name</b></td>
      <td><input type="text" size="70" maxlength="100" name="title" value="<?php echo $row['name'] ?>"></td>
    </tr>
    <tr>
      <td><b>Age</b></td>
      <td><input type="text" size="70" maxlength="100" name="title" value="<?php echo $row['age'] ?>"></td>
    </tr>
  </table>
  <input type="hidden" name="id" value="<?php echo $id; ?>" />
  <input name="enter" type="submit" value="Edit">
</form>

<?php 
mysql_close($dbcnx);
?>

save_edit.php

<?php
// connect to SQL
$con = mysql_connect("localhost", "root", "2345fypj");
if (!$con) {
  echo( "<P>Unable to connect to the database server at this time.</P>" );
  exit();
}
// connect to database
$dbcon = @mysql_select_db("user_profile", $con);
if (!$dbcon) {
  echo( "<P>Unable to locate DB table at this time.</P>" );
  exit();
}

#data preparation for the query
$id = intval($_POST["userid"]);
foreach ($_POST as $key => $value) $_POST[$key] = mysql_real_escape_string($value);

$sql = "UPDATE user_profile SET 
        name='$_POST[name]', 
        age='$_POST[age]', 
        WHERE userid=$id";

if (!mysql_query($sql,$con)) {
  die('Error: ' . mysql_error());
}

mysql_close($con);
header ("location: http://www.domain.com/url_to_go_to_after_update");
?>

前もって感謝します。

4

4 に答える 4

1
$id = intval($_GET['userid']);

これは、$id変数を URL の「userid」変数に設定することを意味します。たとえば、URL が mySite.com?userid=12 の場合、$id は「12」に設定されます。URL の最後のセクションに「username=aValue」がない場合、表示されているエラーが発生します。:)

これを次のように変更して、デフォルト値を設定できます。

$id = (isset($_GET['userid']) ? intval($_GET['userid']) : -1);
于 2012-05-03T02:47:45.483 に答える
0

コードの問題は、変数を使用する前に変数を使用することとは別にあります.intvalでデフォルト値に設定するときに引き続きクエリを実行します(常に少なくとも0を返します)。数値以外の文字が渡されると、常に更新されますテーブルの行 0 ユーザーの場合、何をすべきかは何も更新せず、ユーザーにエラーを返すことです。クエリで列を作成した,後もルージュがあります。age

<?php 
if(isset($_POST["userid"]) && is_numeric($_POST["userid"])){

    $_POST = array_walk($_POST,'mysql_real_escape_string');

    $sql = "UPDATE `user_profile` SET `name`='{$_POST['name']}', `age`='{$_POST['age']}' 
            WHERE `userid` = {$_POST['userid']}";
    mysql_query($sql);

}else{
    header('Location: ./failed');
}
?>
于 2012-05-03T03:15:14.053 に答える
0

$_GET['userid']問題は、未定義の変数を使用しようとしていることです。この変数は、URL の GET パラメータを参照します (例: EditProfile.php?userid=42)。このパラメーターが URL で渡されない場合、この警告が表示されます。変数の存在を確認する必要があります:

if (!isset($_GET['userid'])) {
  die("Parameter is missing!");  
}

$id = intval($_GET['userid']);
于 2012-05-03T02:46:22.627 に答える
0

アクセスする前に、値が正しく設定されていることを確認する必要があります。事前に isset 関数を使用してみてください。

http://php.net/manual/en/function.isset.php

于 2012-05-03T02:47:44.417 に答える