我正在制作一个测试程序,我需要使用此代码:
"href=\"testmng.PHP?manageqn=" . htmlspecialchars_decode($r['testname'],ENT_QUOTES) . "?subjectname=". htmlspecialchars_decode($r['subname'],ENT_QUOTES)
我的问题是当manageqn和subjectname具有正确的值时,正确的格式是什么:
else if ((isset($_REQUEST['manageqn'])) && (isset($_REQUEST['subjectname']))) { $testname = $_REQUEST['manageqn']; $subname = $_REQUEST['subjectname']; $result = executeQuery("select testid from test where testname='" . htmlspecialchars($testname,ENT_QUOTES) . "';"); if ($r = MysqL_fetch_array($result)) { $_SESSION['testname'] = $testname; $_SESSION['subjectname'] = $subname; $_SESSION['testqn'] = $r['testid']; header('Location: prepqn.PHP'); } }
解决方法
假设您正在使用MysqLi连接到数据库,您需要使用
myqli_real_escape_string() PHP函数转义字符串,否则您可能会冒险将sql注入添加到您的应用程序:
executeQuery("select testid from test where testname='" . myqli_real_escape_string($testname) . "';");
但是,我建议使用MysqLi提供的预处理语句功能切换到参数化查询方法.然后你可以像这样执行executeQuery():
executeQuery("select testid from test where testname=?",$testname)
无需转义字符串以便进行安全查询.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。