当前位置: 首页 > news >正文

怎么把网站上传到空间济宁做网站公司找融合

怎么把网站上传到空间,济宁做网站公司找融合,进入wordpress后,个人网站备案备注写什么Overview 在 XXX.php 的第 X 行中,responsemsg() 方法将未经验证的输入写入 JSON。攻击者可以利用此调用将任意元素或属性注入 JSON 实体。 Details JSON injection 会在以下情况中出现: 1. 数据从一个不可信赖的数据源进入程序。 2. 将数据写入到 …

Overview

在 XXX.php 的第 X 行中,responsemsg() 方法将未经验证的输入写入 JSON。攻击者可以利用此调用将任意元素或属性注入 JSON 实体。

Details

JSON injection 会在以下情况中出现:

1. 数据从一个不可信赖的数据源进入程序。

2. 将数据写入到 JSON 流。 在这种情况下,由 XXX.php 的第 X 行的 json_decode() 编写 JSON。 应用程序通常使用 JSON 来存储数据或发送消息。用于存储数据时,JSON 通常会像缓存数据那样处理,而且可能会包含敏感信息。用于发送消息时,JSON 通常与 RESTful 服务一起使用,并且可以用于传输敏感信息,例如身份验证凭据。 如果应用程序利用未经验证的输入构造 JSON,则可以更改 JSON 文档和消息的语义。

在相对理想的情况下,攻击者可能会插入无关的元素,导致应用程序在解析 JSON 文档或请求时抛出异常。在更为严重的情况下,例如涉及 JSON Injection,攻击者可能会插入无关的元素,从而允许对 JSON 文档或请求中对业务非常关键的值执行可预见操作。还有一些情况,JSON Injection 可以导致 Cross-Site Scripting 或 Dynamic Code Evaluation。

例 1:以下 PHP 代码将非特权用户(这些用户具有“默认”角色,与之相反,特权用户具有“管理员”角色)的用户帐户身份验证信息从用户控制的 URL 参数 username 和 password 序列化为位于 ~/user_info.json 的 JSON 文件:

$username = $_GET['username']; $password = $_GET['password']; $user_info_json_string = '{"role":"default","username":"' . $username . '","password":"' . $password . '"}';

$user_info_json_file = fopen('~/user_info.json', 'w');

fwrite($user_info_json_file, $user_info_json_string);

fclose($user_info_json_file);

但是,由于 JSON 序列化使用字符串串联来执行,将不会对 username 和 password 中的不可信赖数据进行验证以转义与 JSON 相关的特殊字符。这样,用户就可以任意插入 JSON 密钥,可能会更改已序列化的 JSON 的结构。在本例中,如果非特权用户 mallory(密码为 Evil123!)将 %22,%22role%22:%22 附加到其用户名中,并将该值传递到 username URL 参数,则最终保存到 ~/user_info.json 的 JSON 将为: { "role":"default", "username":"mallory", "role":"admin", "password":"Evil123!" } 如果之后使用 PHP 的本地 json_decode() 函数对已序列化的 JSON 文件进行反序列化,如下所示:

$user_info_json_string = file_get_contents('user_info.json', 'r');

$user_info_json_data = json_decode($user_info_json_string);

$user_info_json_data 中 username、password 和 role 的最终值将分别为 mallory、Evil123! 和 admin。在没有进一步验证反序列化 JSON 中的值是否有效的情况下,应用程序会错误地为用户分配 mallory“管理员”特权。

Recommendations

在将用户提供的数据写入 JSON 时,请遵循以下准则:

1.不要使用从用户输入派生的名称创建 JSON 属性。

2. 确保使用安全的序列化函数(能够以单引号或双引号分隔不可信赖的数据,并且避免任何特殊字符)执行对 JSON 的所有序列化操作。

示例 2:以下 PHP 代码实现的功能与Example 1 相同,但会使用 json_encode() 而不是字符串连接来对数据进行序列化,从而确保正确地分隔和转义任何不可信数据:

$username = $_GET['username'];

$password = $_GET['password'];

$user_info_array = array('role' => 'default', 'username' => $username, 'password' => $password);

$user_info_json_string = json_encode($user_info_array);

$user_info_json_file = fopen('~/user_info.json', 'w');

fwrite($user_info_json_file, $user_info_json_string);

fclose($user_info_json_file);

http://www.yayakq.cn/news/131192/

相关文章:

  • 兰州市做网站的公司动漫版
  • 南京建设网站哪家好如何做网站推广
  • 建设局网站买卖合同外贸平台有哪些用户量大的
  • 大连建设工程信息网改名为什么百度seo快速
  • 网站推广营销运营方式主要是WordPress
  • 通州设计网站建设移动互联网时代的渠道模式创新
  • ai网站大全可以做水印的网站
  • 网站的优点有哪些方面安阳做网站公司
  • h5网站开发软件自己做的网站怎么设置地址
  • 济宁网站建设 智雅公司建一个网站多少钱
  • 网站建设实训指导书建设网站的步骤
  • 网站开发好了 怎么发布成都装饰网站建设
  • 长沙优化网站多少钱东莞人才市场档案接收电话
  • 普陀区网站建设公司万户做的网站安全吗
  • 电脑做网站主机网站建设公司哪家好 在线磐石网络
  • 模板网站为什么做不了优化郑州做网站建设公司哪家好
  • 鄂州网站制作哪家好莱芜杂谈
  • 中国工程建设招聘信息网站合肥建设网网站
  • 创建网站的快捷方式大连网站建设平台
  • 计算机(网站建设与维护)男人和女人做羞羞的事情网站
  • 一般可以建些什么种类的网站崔凯 本地wordpress
  • 网页视频怎么下载到电脑国际网站怎么做优化
  • 如何开发网站快三直播十大平台直播间
  • 家具网站源码做数据新闻的网站
  • 简述企业网站维护的重要性印刷 技术支持 东莞网站建设
  • 郑州网站建设价位公司网站建设多少费用兴田德润在哪里
  • 个人网站要不要备案php 开源的企业网站
  • 美食网站开发的背景建站过程
  • 网站推广关键词工具网站建设怎么在图片上加字
  • 摄影工作室网站设计软件开发流程八个步骤