详解JSON和JSONP劫持以及解决方法

下面是详解JSON和JSONP劫持及解决方法的攻略。

什么是JSON和JSONP

JSON

JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式,其格式简单明了,易于阅读和编写,同时也易于机器解析和生成。JSON是一种完全独立于编程语言的数据格式,它的性能优越,能够处理庞大的数据量。

JSON数据格式示例:

{
    "name": "张三",
    "age": 20,
    "address": {
        "city": "北京",
        "street": "长安街",
        "zipcode": "100000"
    },
    "hobby": ["看电影", "旅游"]
}

JSONP

JSONP (JSON with Padding) 是一种解决跨域的方案,在页面上加载一个 JS 文件,通过 Script 标签引用,该 JS 文件返回一个回调函数,回调函数的参数就是我们想要获取的数据,回调函数会在页面中自动执行。因为 Script 标签不会被同源策略限制,所以可返回任意数据。

JSONP示例:
假设我们需要从其他网站获取数据,并在自己的网站中显示。通过 JSONP 可以实现该功能。

假设有一个返回数据的 API,地址为 http://example.com/api.php。JSONP 请求的地址应该是 http://example.com/api.php?callback=showData,其中 callback 参数是约定好的回调参数,showData 是在前端定义好的回调函数名(可自定义),返回的数据应该以 showData({data}) 的形式返回。

前端代码示例:

<script>
function showData(data) {
  console.log(data);
}
</script>
<script src="http://example.com/api.php?callback=showData"></script>

JSONP劫持

过程:黑客在第三方系统上注入代码,在第三方返回 JSONP 数据时,篡改回调函数中的数据。

举例:假设键名为 "data",键值为 "12345" 的JSONP数据被获取到之后,黑客通过修改第三方系统上的注入代码使得回调函数中的数据被改为了键名 "data" 而键值被修改为 "54321"。当我们在前端通过回调函数调用data时,得到的数据就不是我们期望的“12345”,而是被篡改后的“54321”。

解决办法:避免使用约定好的callback参数作为请求参数,自定义callback名。同时,在前端通过正则表达式或其他方法判断返回数据是否符合JSON格式,不满足则不执行回调函数,避免执行黑客篡改后的代码。以下代码示例:

<script>
function myFunc(data) {
    if (/^[{\[]/.test(data)) { // 检查返回数据是否是符合JSON格式的数据,只有符合才执行回调函数
        console.log(data);
    }
}
</script>
<script src="http://example.com/api.php?callback=myFunc"></script>

JSON劫持

过程:黑客在第三方系统返回JSON格式数据时,篡改数据内容,达到攻击目的。

举例:假设第三方接口返回的数据为:

{
  "username": "test",
  "isVIP": false
}

黑客通过篡改第三方系统中的数据,将 "isVIP" 的值改为 true,攻击用户,并获得其VIP权益。

解决办法:加密校验,防篡改。对数据进行加密,在客户端解密校验,当数据被篡改时,校验失败,不能正常使用数据。

以下是加密解密代码示例:

// 对数据进行加密
function enCode(str) {
    return window.btoa(str); // 使用base64加密
}

// 对数据进行解密
function deCode(str) {
    return window.atob(str); // 解密base64字符串
}

// 简单的校验数据是否被篡改的方法
function checkData(data, code) {
    if (enCode(data) === code) { // 当加密后的校验值与传来的校验码一致,说明数据未被篡改
        console.log(data);
    }
}

参考文章:https://blog.csdn.net/huang_xw/article/details/69853721 和 https://cloud.tencent.com/developer/article/1186095

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解JSON和JSONP劫持以及解决方法 - Python技术站

(0)
上一篇 4天前
下一篇 4天前

相关文章

  • 可以读取EXCEL文件的js代码第2/2页

    让我来为您详细讲解如何读取EXCEL文件的JS代码攻略。 一、安装依赖 要读取EXCEL文件,我们首先需要安装必要的依赖。请使用以下命令安装: npm install xlsx 二、导入模块 安装完依赖后,我们需要在JS文件中导入xlsx模块,以便使用其中的操作函数。请使用以下代码导入: const XLSX = require("xlsx&quo…

    JavaScript 4天前
    00
  • javascript中parseInt()函数的定义和用法分析

    下面我就来为你介绍一下JavaScript中parseInt()函数的定义和用法分析。 1. 定义 parseInt()是JavaScript中的一个全局函数,用于将字符串解析成整数。该函数接收两个参数:要转换为整数的字符串和一个可选的进制数,表示要解析的字符串是几进制的。如果不提供进制数,则默认采用十进制。 2. 用法分析 2.1 解析十进制 下面是一个解…

    JavaScript 4天前
    00
  • js 页面执行时间计算代码

    下面是关于“js 页面执行时间计算代码”的完整攻略。 1. 确定需要计算的页面区域 在编写计算页面执行时间的代码之前,需要确定需要计算的页面区域。这可以是整个页面,也可以只是页面上的一部分。一般来说,计算整个页面的执行时间比较耗费资源,建议还是选择计算某一个特定区域的执行时间。 2. 使用performance API 在计算页面执行时间时,可以使用浏览器提…

    JavaScript 4天前
    00
  • JS数组方法slice()用法实例分析

    JS数组方法slice()用法实例分析 简介 slice() 方法返回一个新的数组对象,这个对象是由 begin 和 end 决定的原数组的浅拷贝。原数组不会被修改。常用于数组的复制或提取。 语法 array.slice(begin, end) 参数描述: begin:一个零开始的索引,提取起始处的元素。 end(可选):一个零开始的索引,提取终止处的元素。…

    JavaScript 4天前
    00
  • JS版获取字符串真实长度和取固定长度的字符串函数

    获取字符串真实长度和取固定长度的字符串函数,可以方便地进行字符串截取和限制。 获取字符串真实长度 常规的字符串长度获取方式是使用 str.length,但这种方式对于非 ASCII 字符(如中文、日文、韩文等)是不准确的,因为每个非 ASCII 字符占用的字节不同。解决这个问题的方法是使用 encodeURIComponent 将字符串编码为 URI 组件,…

    JavaScript 4天前
    00
  • 基于JavaScript实现数码时钟效果

    基于JavaScript实现数码时钟效果攻略 在网页中实现时钟效果,在 JavaScript 中常用的方式是使用 setInterval() 函数来定期获取当前时间,并更新页面上显示时间的元素。实现数码时钟效果可以使得网页更加美观和实用。 本文将详细讲解如何基于 JavaScript 实现数码时钟效果。过程中将包含两条示例说明。 1. HTML 结构 需要在…

    JavaScript 4天前
    00
  • JS获取html对象的几种方式介绍

    以下是关于JS获取html对象的几种方式的完整攻略: 1. 通过id获取对象 我们可以通过id来获取html对象。具体步骤如下: var obj = document.getElementById(‘idName’); 其中,’idName’是你想要获取的id名称。这个方法在页面中只能有一个元素拥有该id才能生效。 举个例子,如果你想获取以下html代码中的…

    JavaScript 4天前
    00
  • js实例之01支付后的10秒倒计时

    这是一个通过js实现的支付后的页面,点击支付会跳出一个弹窗,提示你是否要确定支付,确定后进入付后界面,该页面有着10秒倒计时,计时结束后便会返回原界面。也可以选择立刻返回,来返回主页面第一个zhifu.html页面<!DOCTYPE html> <html lang=”en”> <head> <meta charse…

    JavaScript 2023年4月18日
    00
  • JavaScript对象解构的用法实例解析

    下面进入详细讲解“JavaScript对象解构的用法实例解析”的完整攻略。 什么是对象解构 在 JavaScript 中,对象解构是一种将对象中属性的值解构到独立变量中的方法。它允许您从对象中选择某些属性并将其作为独立变量使用。 对象解构的语法 对象解构使用专门的语法来表示,具体来说,它的语法如下: const { property1, property2 …

    JavaScript 4天前
    00
  • js中实现字符串和数组的相互转化详解

    JS中实现字符串和数组的相互转化详解 在JS中,字符串和数组之间相互转化是比较常见的操作。通常会通过split和join完成转化。接下来将详细介绍这两个方法的使用技巧。 split方法 split方法可以将字符串按照指定的分隔符,转化成数组。 const str = "hello,world" const arr = str.split(…

    JavaScript 4天前
    00