【问题标题】:AJAX script not parsing variable to php correctlyAJAX 脚本未正确将变量解析为 php
【发布时间】:2017-06-04 08:42:24
【问题描述】:

2017 年 1 月 19 日更新 - 问题已解决 - 在 get.php 文件中的 get 请求中删除了“intval”,值 q 现在正在捕获正确的数据。

我想要达到的目标可以总结为两点:

1.) 根据 MySql 表动态填充的下拉框

2.) 根据下拉菜单中选择的内容,下面的文本字段将通过 SQL 查询显示相应的 ID。

我一直在尝试关注 W3Schools guide 并相应地对其进行修改以满足我的需求,但我遇到了困难。

这是我目前拥有的:

PHP -

<?php
    mysql_connect('localhost', 'root', '');
    mysql_select_db('core_log');

    $sql = "SELECT local_authority FROM ons_code_tbl";
    $result = mysql_query($sql);

    echo "<tr>";
    echo "<td> Local Authority: </td>";
    echo "<td>";
    echo "<select name='local_authority'onchange='showLocal_authority(this.value)'>";
    echo '<option value=""></option>';
       while ($row = mysql_fetch_array($result)) {
            echo "<option value='" . $row['local_authority'] . "'>" . $row['local_authority'] . "</option>";
        }
    echo "</select>";
    echo "</td>";
    echo "</tr>";
?>

脚本 -

<script>
        function showLocal_authority(str) {
            if (str == "") {
                document.getElementById("txtHint").innerHTML = "";
                return;
            } else { 
                if (window.XMLHttpRequest) {
                    // code for IE7+, Firefox, Chrome, Opera, Safari
                    xmlhttp = new XMLHttpRequest();
                } else {
                    // code for IE6, IE5
                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
                }
                xmlhttp.onreadystatechange = function() {
                    if (this.readyState == 4 && this.status == 200) {
                        document.getElementById("txtHint").innerHTML = this.responseText;
                    }
                };
                xmlhttp.open("GET","get.php?q="+str,true);
                xmlhttp.send();
            }
        }
</script>

get.php -

<?php
   $q = intval($_GET['q']);

   $con = mysqli_connect('localhost','root','','core_log');
   if (!$con) {
       die('Could not connect: ' . mysqli_error($con));
   }

   mysqli_select_db($con,"ons_code_tbl");
   $sql="SELECT ons_code FROM ons_code_tbl WHERE local_authority = '".$q."'";
   $result = mysqli_query($con,$sql);
   $row = mysqli_fetch_array($result);
   $name = $row['ons_code'];

   echo "<td>" . $q . "</td>";

   mysqli_close($con);
?>

我做了一个测试,只是简单地回显了值 q 以查看它的输出,它应该是他们在下拉列表中选择的任何值,而不是显示 0?

在下面的屏幕截图中,它应该显示“Amber Valley”以及从 MySQL 表中提取的正确 ONS 代码。

如果有人能告诉我为什么值 q 不存储例如“Amber Valley”,那就太好了,谢谢!

【问题讨论】:

  • 请给您的问题一个相关的标题。另请注意,W3Schools 与 W3C 完全无关,他们的建议通常已经过时,在某些情况下完全不正确。
  • 您正在将 ajax 中的字符串发送到脚本 php,但第一行在此字符串上创建一个 intval,返回 0:php.net/manual/fr/function.intval.php
  • $q = intval($_GET['q']); 的字符串将为 0
  • @Yoleth 就是这样,删除 intval 并使用 $_GET 只解决了我的问题!谢谢!
  • @FelippeDuarte 谢谢!删除 intval 解决了这个问题!

标签: php jquery mysql ajax web


【解决方案1】:

替换这一行:

$q = intval($_GET['q']);

$q = $_GET['q'];

然后用prepared statement进行查询,避免SQL注入:

mysqli_select_db($con,"ons_code_tbl");
$sql="SELECT ons_code FROM ons_code_tbl WHERE local_authority = ?";
$stmt = mysqli_prepare($con, $sql);
mysqli_stmt_bind_param($stmt, "s", $q);
mysqli_stmt_execute($stmt);
mysqli_stmt_bind_result($stmt, $ons_code);
mysqli_stmt_fetch($stmt);

只需将echo "&lt;td&gt;" . $q . "&lt;/td&gt;"; 替换为echo "&lt;td&gt;" . $ons_code . "&lt;/td&gt;";

【讨论】:

  • 太棒了,从这个帖子中学到了很多东西 :) 谢谢费利佩
猜你喜欢
  • 1970-01-01
  • 2014-11-07
  • 2017-01-18
  • 2014-01-20
  • 1970-01-01
  • 2012-08-10
  • 2012-04-24
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多