从多个表中读取数据.... 。 任何人都可以弄清楚为什么这段代码不起作用...... 。 当我选中复选框时,警报(脚本)显示出来, 。 我知道应该有数据的结果。 。 曼尼谢谢, 尼
<?php
include_once 'dbcon.php';
if(isset($_POST['chk'])=="")
{
?>
<script>
alert('Er moet tenminste één checkbox geselecteerd zijn !!!');
window.location.href='../EVENT/eventIndex.php';
</script>
<?php
}
$chk = $_POST['chk'];
$chkcount = count($chk);
?>
<form method="post" name="frm">
<table width="90%" align="center" border="0">
<tr>
<td colspan="6"><a href="NewTicket.php" class="StyleTxt">Voeg een nieuw ticket toe...<br>
</a></td>
</tr>
<tr>
<th width="15%" class="StyleTxt">Naam</th>
<th width="15%" class="StyleTxt">Voornaam</th>
<th width="15%" class="StyleTxt">Partner achternaam</th>
<th width="15%" class="StyleTxt">Partner voornaam</th>
<th width="15%" class="StyleTxt">Herbalife-ID</th>
<th width="15%" class="StyleTxt">Upline</th>
</tr>
<?php
for($i=0; $i<$chkcount; $i++)
{
$id = $chk[$i];
$res=$MySQLiconn->query("SELECT user.FName, user.LName, user.HerbalifeID, user.UplineS, registratie.PartnerFName, registratie.PartnerLName, registratie.NaamVIP1, registratie.NaamVIP2, registratie.NaamVIP3, registratie.NaamVIP4, registratie.NaamVIP5, registratie.NaamVIP6, registratie.NaamVIP7, registratie.NaamVIP8, registratie.NaamVIP9, registratie.NaamVIP10, registratie.NaamVIP11, registratie.NaamVIP12 FROM registratie INNER JOIN user ON registratie.userID = user.UserID AND registratie.eventID=".$id);
while($row=$res->fetch_array())
{
?>
<tr>
<td style="background-color:gold;"><?php echo $row['FName'];?></td>
<td style="background-color:gold;"><?php echo $row['LName'];?></td>
<td style="background-color:gold;"><?php echo $row['PartnerFName'];?></td>
<td style="background-color:gold;"><?php echo $row['PartnerLName'];?></td>
<td style="background-color:gold;"><?php echo $row['HerbalifeID'];?></td>
<td style="background-color:gold;"><?php echo $row['UplineS'];?></td><br />
</tr>
<tr>
<td>VIP: <?php echo $row['NaamVIP1'];?></td>
<td>VIP: <?php echo $row['NaamVIP2'];?></td>
<td>VIP: <?php echo $row['NaamVIP3'];?></td>
<td>VIP: <?php echo $row['NaamVIP4'];?></td>
<td>VIP: <?php echo $row['NaamVIP5'];?></td>
<td>VIP: <?php echo $row['NaamVIP6'];?></td>
</tr>
<tr>
<td>VIP: <?php echo $row['NaamVIP7'];?></td>
<td>VIP: <?php echo $row['NaamVIP8'];?></td>
<td>VIP: <?php echo $row['NaamVIP9'];?></td>
<td>VIP: <?php echo $row['NaamVIP10'];?></td>
<td>VIP: <?php echo $row['NaamVIP11'];?></td>
<td>VIP: <?php echo $row['NaamVIP12'];?></td>
</tr>
<?php
}
}
?>
答案 0 :(得分:0)
除了代码中的SQL注入漏洞之外,我建议您阅读(参见http://php.net/manual/en/security.database.sql-injection.php),但代码中存在一个小问题。
if(isset($_POST['chk'])=="")
这是不正确的,因为isset返回一个布尔值,你无法将boolean与string进行比较,它是无效的。 检查Mike的评论如下。如果你想检查字符串不为空并设置,执行:
if(isset($_POST['chk']) && !empty($_POST['chk']))
isset的联机帮助页面在这里:http://php.net/manual/en/function.isset.php; “如果var存在并且其值不是NULL,则返回TRUE,否则返回FALSE。”
另一件小事: $ chk没有默认值,这意味着,如果没有提供,整个脚本就会爆炸。要解决此问题,您可以使用PHP7中的新语法添加默认值,但为了兼容性:
if (!isset($_POST['chk']) {
$chk = 'something'
}