繁体   English   中英

如何用href发送2个值?

[英]How to send 2 values with href?

我正在尝试在整个 href 中发送 2 个值。 如果我发送一个值,例如 - id,一切都很好。

这是我的代码:

<select id="options" name="options" method="post">                      
    <option value="opt1">Option one</option>
    <option value="opt2">Option two</option>
    <option value="opt3">Option three</option>
</select>
<br>
<a href="cart.php?action=update&id=<?php echo $row['id']?>">
    <span class="btn btn-success">Change</span>
</a>

$row有我获取的数据,所以我从那里得到我的 id。 我还想发送一个在下拉列表中选择的值。 我会将这些值发送到此:

if($_GET["action"] == "update") {
    $stat = $_GET['options'];
    $itemID = $_GET['id'];
    $sql = "UPDATE orders
    SET status = '$stat'
    WHERE id = '$itemID'";
    $connect->query($sql);
    header("location:index.php?status=1");
}

然而我的$stat里面什么都没有。

我在互联网上尝试了几乎所有可能的解决方案,但没有一个解决了我的问题。

要使这项工作在您的情况下工作,您需要使用带有 GET 方法的 FORM。 不是 select 元素上的方法。

<form method="GET" action="cart.php">
    <input type="hidden" name="action" value="update">
    <input type="hidden" name="id" value="<?php echo $row['id'] ?>">
    <select id="options" name="options">                      
        <option value="opt1">Option one</option>
        <option value="opt2">Option two</option>
        <option value="opt3">Option three</option>
    </select>
    <button class="btn btn-success" type="submit">Change</button>
</form>

选择选项 1 将提交到cart.php?action=update&id=1&options=opt1

另一种选择是使用 POST:

<form method="POST" action="cart.php?action=update&id=<?php echo $row['id'] ?>">
    <select id="options" name="options">                      
        <option value="opt1">Option one</option>
        <option value="opt2">Option two</option>
        <option value="opt3">Option three</option>
    </select>
    <button class="btn btn-success" type="submit">Change</button>
</form>

然后在您的 PHP 中:

$action = $_POST['action'];
$options = $_POST['options'];
//etc

请记住,您很容易受到SQL 注入的影响,应该使用准备好的语句

您使用 post 方法而不是 $_GET 使用 $_POST 并且您应该先连接数据库,然后再向其中写入任何内容。 为这些事情使用表单标签也可能更聪明,请参阅https://www.w3schools.com/tags/tag_form.asp 希望我帮助了你

这是您的代码中的两个错误,您使用的方法是post method not get ,另一个是您没有执行该方法的表单,您需要创建 select 作为表单才能正常工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM