我的问题是:您可以使用表单和内部循环进行POST吗?我有这个应该给我一个复选框和旁边的歌曲标题,我希望能够选择几个复选框并将它们发布到" process.php"但是这个代码我没有向process.php发布任何内容。如果我点击提交按钮而没有选中任何方框它默认为我的数据库中的最后一个结果#,如果我检查任何或几个方框它说它" unifined off-set#9"这是我数据库中的最后一个结果。如果我在while循环中创建表单,我会得到每个结果的大量提交按钮。我不确定我做错了什么!请帮帮我!!!
这就是我需要发生的事情 ⎕歌名 ⎕歌名二 SUBMIT
如果你点击提交on process.php,我应该可以使用" song_name"
Please select songs: <br>
<form method="post" action="process.php">
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "song_selection";
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql = "SELECT * FROM songs";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
$a = 1;
// output data of each row
while($row = $result->fetch_assoc()) {
$song_name = $a++;
//echo "title: " . $row["title"]. "<br>";
?>
<div width="200">
<label>
<input type="checkbox" name="<?php echo $song_name; ?>" value="<?php echo $song_name; ?>" id="CheckboxGroup1_0" />
<?php echo $row['title']; ?></label>
</div>
<?php
} echo '<input type="submit" value="thanks">';
} else {
echo "0 results";
}
?>
</form>
<?php
echo $_POST[$song_name];
?>
答案 0 :(得分:1)
$song_name
是一个计数器值,而不是实际的歌曲名称,您在value=""
属性中使用了它。我相信$row['title']
是实际的歌曲名称,所以替换,
<input type="checkbox" name="<?php echo $song_name; ?>" value="<?php echo $song_name; ?>" id="CheckboxGroup1_0" />
与
<input type="checkbox" name="<?php echo $song_name; ?>" value="<?php echo $row['title']; ?>" id="CheckboxGroup1_0" />
从你的问题:
如果你点击提交on process.php,我应该可以使用&#34; song_name&#34;
如果这是您的要求,请按以下方式处理表格:
<强> process.php 强>
foreach($_POST as $key => $value){
echo $key . ": " . $value . "<br />";
}