gpt4 book ai didi

php - 仅允许通过本地服务器上的 ajax 访问 PHP 文件

转载 作者:IT王子 更新时间:2023-10-29 00:08:01 25 4
gpt4 key购买 nike

我有一个网站需要根据用户交互增加数据库中的值。当用户单击按钮时,将调用一个 php 脚本来增加值。我想保护这个脚本不被外部脚本访问。目前,用户可以使用 javascript 函数编写自己的网页,该函数重复访问同一个 php 文件以破坏数据库中的值。

这是我执行递增的 jquery 代码:

jQuery(function(){
$('.votebtn').click(function(e){
var mynum = $(this).attr('id').substring(0,5);
$.ajax({
url:"countvote.php",
type:"GET",
data: {
thenum:mynum
},
cache: false,
success:function(data) {
alert('Success!');
}
}
});
});
});

我将如何着手使本地服务器上只有来自 ajax/jquery 的调用才能访问“countvote.php”?如果这不是解决问题的正确方法,我愿意接受任何可以防止我的 php 脚本被外部脚本滥用的建议。

最佳答案

解决方案需要两个步骤。

首先,ajax 文件必须只允许使用此代码在 ajax 请求中访问。

define('IS_AJAX', isset($_SERVER['HTTP_X_REQUESTED_WITH']) &&      strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest');
if(!IS_AJAX) {die('Restricted access');}

其次,ajax 文件可以使用命令 $_SERVER['HTTP_REFERER'] 调用它的文件名进行访问。因此,您可以仅在主机服务器中限制访问。

$pos = strpos($_SERVER['HTTP_REFERER'],getenv('HTTP_HOST'));
if($pos===false)
die('Restricted access');

也许代码只适用于第二部分

关于php - 仅允许通过本地服务器上的 ajax 访问 PHP 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15436948/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com