mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-24 12:07:23 +08:00
修复3个安全漏洞 (#15)
* 修复趣味盒未授权访问漏洞 趣味盒页面未做鉴权游客可以任意查看或发送内容 * 修复sql注入漏洞 * 修复sql注入 详见描述 代码第19行 if (!is_valid_id($class) && $class != 0) 如果class 为"sleep(5)" 虽然过不了is_valid_id校验 但是由于php 弱类型 非数字开头的字符串 最终会判断为 $class = 0 绕过了校验 另外建议is_valid_id 改为更直接的intval 将用户输入的的数据强制转换成int 防止sql注入
This commit is contained in:
@@ -3,6 +3,7 @@ require_once("../include/bittorrent.php");
|
|||||||
dbconn();
|
dbconn();
|
||||||
require_once(get_langfile_path());
|
require_once(get_langfile_path());
|
||||||
require_once(get_langfile_path("",true));
|
require_once(get_langfile_path("",true));
|
||||||
|
loggedinorreturn();
|
||||||
$action=$_GET["action"];
|
$action=$_GET["action"];
|
||||||
if (!$action)
|
if (!$action)
|
||||||
{
|
{
|
||||||
|
|||||||
+1
-1
@@ -38,7 +38,7 @@ elseif (isset($_GET["act"]) && $_GET["act"]=="addsect"){
|
|||||||
header("Refresh: 0; url=modrules.php");
|
header("Refresh: 0; url=modrules.php");
|
||||||
}
|
}
|
||||||
elseif (isset($_GET["act"]) && $_GET["act"] == "edit"){
|
elseif (isset($_GET["act"]) && $_GET["act"] == "edit"){
|
||||||
$id = $_GET["id"];
|
$id = intval($_GET["id"]);
|
||||||
$res = @mysql_fetch_array(@sql_query("select * from rules where id='$id'"));
|
$res = @mysql_fetch_array(@sql_query("select * from rules where id='$id'"));
|
||||||
stdhead("Edit rules");
|
stdhead("Edit rules");
|
||||||
//print("<td valign=top style=\"padding: 10px;\" colspan=2 align=center>");
|
//print("<td valign=top style=\"padding: 10px;\" colspan=2 align=center>");
|
||||||
|
|||||||
@@ -15,7 +15,8 @@ if (!$msg)
|
|||||||
stderr("Error","Don't leave any fields blank.");
|
stderr("Error","Don't leave any fields blank.");
|
||||||
$updateset = $_POST['clases'];
|
$updateset = $_POST['clases'];
|
||||||
if (is_array($updateset)) {
|
if (is_array($updateset)) {
|
||||||
foreach ($updateset as $class) {
|
foreach ($updateset as &$class) {
|
||||||
|
$class=intval($class);
|
||||||
if (!is_valid_id($class) && $class != 0)
|
if (!is_valid_id($class) && $class != 0)
|
||||||
stderr("Error","Invalid Class");
|
stderr("Error","Invalid Class");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user