$_GET删除记录停止工作
$_GET stopped working for deleting records
对于一个web应用程序,我正在构建删除用户功能停止工作。我没有改变任何与这个函数相关的东西。所以我很困惑。我有PHP控制台安装在chrome(和应用程序)。但是它没有给出任何错误或警告。
我正在使用bootbox来验证用户是否真的应该被删除:
function delete_id(id, fullname) {
bootbox.confirm({
size: 'small',
message: '<i class="glyphicon glyphicon-question-sign orange"></i>Are you sure you want to delete user "'+fullname+'"?',
callback: function(result) {
if(result) {
window.location.href = '?delete_id='+id;
}
}
});
}
然后它应该通过php函数传递:
function delete_user ($mysqli) {
if(isset($_GET['delete_id'])) {
$sql_name = "SELECT * FROM users WHERE uid='".$_GET['delete_id']."'";
$result_name = $mysqli->query($sql_name);
$row = $result_name->fetch_assoc();
$sql_log = "DELETE FROM loginlog WHERE uid='".$row['uid']."'";
$result_log = $mysqli->query($sql_log);
$sql_user = "DELETE FROM users WHERE uid='".$row['uid']."'";
$result_user = $mysqli->query($sql_user) or die(mysqli_errno($mysqli));
$_SESSION['success'] = "User '"".$row['firstname']." ".$row['prefix']." ".$row['lastname']."'" is deleted.";
header("location: ".BASE_PATH."/includes/views/users.php");
exit();
}
}
在users.php
中调用delete_user()
函数这工作很好,但现在它不再…我是不是忽略了什么?
我建议:
function delete_user ($mysqli, $id) {
if(isset($id)) {
$sql_name = sprintf("SELECT * FROM users WHERE uid='%d'", $id);
$result_name = $mysqli->query($sql_name);
$row = $result_name->fetch_assoc();
$sql_log = "DELETE FROM loginlog WHERE uid='{$row['uid']}'";
$result_log = $mysqli->query($sql_log);
$sql_user = "DELETE FROM users WHERE uid='{$row['uid']}'";
$result_user = $mysqli->query($sql_user) or die(mysqli_errno($mysqli));
$_SESSION['success'] = "User '"{$row['firstname']} {$row['prefix']} {$row['lastname']}'" is deleted.";
return true;
} else {
return false;
}
}
则可以执行:
if(delete_user($sql, $_GET['id'])){
header("location: ".BASE_PATH."/includes/views/users.php");
}
使用最佳实践总是好的,即使在内部网中。如果有一个用户或者某个自认为知道一些事情的人,那么您可能会丢失一些表或者损坏一些行。永远保护你的用户输入的数据,特别是从用户。
相关文章:
- jQuery UI自动完成突然停止工作
- JavaScript打印功能使日历停止工作
- 下拉列表在使用z索引放置在前面后停止工作
- 由于响应中不存在“Access Control Allow Origin”标头,跨域请求停止工作
- 注入工厂时,Angular停止工作
- React Native DeviceEventEmitter键盘WillShow停止工作
- JavaScript在更改css时停止工作
- Chrome地理定位在更新后停止工作
- 重新启动jquery脚本后,角度停止工作
- twitter引导崩溃在第一次点击后停止工作
- 更新Wordpress和我的平滑滚动停止工作
- Hammer.js过了一段时间就停止工作了
- 应用程序在“关闭”之后停止工作(控制台中没有错误);咕哝的构造”;
- 当我添加JavaScript时,链接按钮停止工作
- NetBeans调试突然停止工作
- 某些Magento后端管理按钮已停止工作
- 表单验证在接近尾声时停止工作
- 为什么在ASP.NET Ajax更新面板中执行任何操作后javascript元素都停止工作
- jQuery UI自动完成在2041条记录后停止工作
- $_GET删除记录停止工作