【问题标题】:Undefined offset notice with array within foreach loopforeach 循环中带有数组的未定义偏移量通知
【发布时间】:2016-01-20 14:55:00
【问题描述】:

我有一个 form.php,其中包含一个发布到 update.php 以更新 mysql 数据库的数组。 每个的相关部分是:

form.php

 if ($type == "1")      {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input  type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop1[]" value="'. $row['Prop1'] .'"/>    
    <input  type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input  type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}  
if ($type == "2")       {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop2[]"  value="'. $row['Prop2'] .'"/>
    <input type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}     

更新.php

foreach ($_POST['aid'] as $key=>$assetid) {
$atype = $_POST['atype'][$key];
if ($atype == "1")      {   

    $stmt =  $mysqli->stmt_init();
    $query = "UPDATE asset SET 
             SerialNumber=?,UnitSize=?,Prop1=?,Latitude=?,Longitude=?  WHERE AID = ?";
    if($stmt->prepare($query)) {

    $stmt->bind_param('sdddds', $serialnum, $unitsize, $prop1, $lat, $long, $assetid);

        $assetid = $_POST['aid'][$key];
        $serialnum = $_POST['serialnum'][$key];
        $unitsize = $_POST['unitsize'][$key];
        $prop1 = $_POST['prop1'][$key];
        $lat = $_POST['latitude'][$key];
        $long = $_POST['longitude'][$key];
        $stmt->execute();
    $stmt->close();
    }
}
elseif ($atype == "2")      {   

    $stmt =  $mysqli->stmt_init();
    $query = "UPDATE asset SET 
             SerialNumber=?,Prop2=?, Latitude=?,Longitude=? WHERE AID = ?";
    if($stmt->prepare($query)) {

    $stmt->bind_param('ssdds', $serialnum, $prop2, $lat, $long, $assetid);

        $assetid = $_POST['aid'][$key];
        $serialnum = $_POST['serialnum'][$key];
        $prop2 = $_POST['prop2'][$key];
        $lat = $_POST['latitude'][$key];
        $long = $_POST['longitude'][$key];
        $stmt->execute();
    $stmt->close();
     }
}}

这对数组中除一个输入之外的所有输入都非常有效。 我不断收到以下信息:

注意:未定义的偏移量:3

与下面一行有关:

$prop2 = $_POST['prop2'][$key];

除此之外,所有其他数据库字段都在正常更新。谁能指出我正确的方向吗?

【问题讨论】:

  • 检查你在 $_POST['aid'] 和 $_POST['atype'] 中获得了多少索引......它必须相同..否则你会收到偏移错误。
  • 如果我使用 print_r 它给我每个相同的数量。

标签: php mysql arrays foreach prepared-statement


【解决方案1】:

您应该为此数组输入字段使用相同的名称。即 prop[] ,但你使用了 prop1[] 和 prop2[]。

if ($type == "1")      {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input  type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop[]" value="'. $row['Prop1'] .'"/>    
    <input  type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input  type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}  
if ($type == "2")       {echo ' 
    <input type="hidden" id="assettype" name="atype[]" value="'. $row['AType'] .'"/>
    <input type="hidden" id="assetid" name="aid[]" value="'. $row['AID'] .'"/>

    <input type="text"  name="serialnum[]" value="'. $row['SerialNumber'] .'"/>
    <input type="text"  name="unitsize[]" value="'. $row['UnitSize'] .'"/>
    <input type="text"  name="prop[]"  value="'. $row['Prop2'] .'"/>
    <input type="text"  name="latitude[]" value="'. $row['Latitude'] .'"/>
    <input type="text"  name="longitude[]" value="'. $row['Longitude'] .'"/>
                ';}     

在行动页面更新如下:

$prop2 = $_POST['prop'][$key];

不知道你用的是什么逻辑,如果有逻辑错误使用,

$prop2 = !empty($_POST['prop2'][$key]) ? $_POST['prop2'][$key] : ''; 

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-07-23
    • 1970-01-01
    • 2023-01-10
    • 1970-01-01
    相关资源
    最近更新 更多