JS中注入eval, Function等系统函数截获动态代码

yizhihongxing

注入eval、Function等系统函数可以使攻击者截获JS代码的执行过程,从而实现对网站的控制。以下是JS中注入eval、Function等系统函数的完整攻略:

  1. 针对eval的注入攻击

步骤1: 攻击者在代码中构造出可执行代码(即包含函数或变量)的字符串,然后通过eval这一系统函数来执行

eval("console.log('Hello, World!')");

步骤2: 攻击者解析URL、Cookie等数据,将需要执行的代码封装成字符串,然后通过eval执行,从而实现控制网站的目的。

var codeToExecute = "alert(document.cookie);"; 
eval(codeToExecute);
  1. 针对Function的注入攻击

步骤1:攻击者利用Function方法创建一个函数

var myFunc = new Function('console.log("Hello, World!");');
myFunc();

步骤2:攻击者对需要控制的函数或者对象进行修改

var originalFunc = function() {
    console.log('original function');
};
var evilFunc = new Function('console.log("evil function")');
Function.prototype.toString = function() {
    return evilFunc.toString(); 
}
originalFunc(); 

在这段代码中,攻击者覆盖了Function对象的toString函数的实现,使原来的函数输出变为了“evil function”。

需要注意的是,注入eval、Function等系统函数可能会导致代码执行的预期结果与实际执行结果产生较大的差异,例如安全问题、代码意外中断等。因此,在编写代码时应避免使用这些注入攻击技术,以保证系统的安全性和可靠性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JS中注入eval, Function等系统函数截获动态代码 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • 初识JavaScript的基础

    初识JavaScript的基础 JavaScript是什么? JavaScript是一种轻量级编程语言,与HTML和CSS一起构成了Web前端开发的三大基石之一。 JavaScript通常用于前端交互、页面呈现以及移动设备开发等领域,同时也可用于服务端开发以及跨平台应用开发。 它是一种解释型语言,不需要编译就可以运行。 学习JavaScript前的准备 学习…

    JavaScript 2023年5月17日
    00
  • JS 创建对象(常见的几种方法)

    下面是关于JS创建对象的几种常见方法的详细攻略。 概述 在之前,我们可以通过使用对象字面量的方式来创建 JavaScript 中的对象,但是如果我们需要创建多个类似的对象,这将非常麻烦。因此,在 JavaScript 中我们可以使用不同的方法来创建对象,这些方法包括:构造函数模式、工厂模式、原型模式、组合模式和 ES6 中的 class 语法。 构造函数模式…

    JavaScript 2023年5月27日
    00
  • 使用RequireJS库加载JavaScript模块的实例教程

    我来详细讲解如何使用RequireJS库加载JavaScript模块。 什么是RequireJS RequireJS是一个JavaScript模块加载器,它可以帮助我们实现依赖模块的异步加载。它采用了AMD规范,并提供了一种便捷的方式,使JavaScript开发人员可以更容易地组织和管理代码。 安装与配置 下载RequireJS 去RequireJS的官方网…

    JavaScript 2023年5月27日
    00
  • JS弹出新窗口被拦截的解决方法

    JS弹出新窗口的功能是在网页中常用的,但在很多情况下,弹出的新窗口会被浏览器的弹窗拦截器所拦截,导致网页运行结果不如预期。本篇攻略将会提供几种JS弹窗被拦截的解决方法。 一、使用window.open()打开新窗口 常规的弹出新窗口实现方式是使用window.open()方法,在这种情况下,浏览器的弹窗拦截器很容易就将其拦截。为了避免这种情况,我们可以设定新…

    JavaScript 2023年6月11日
    00
  • JavaScript基础系列之函数和方法详解

    下面是“JavaScript基础系列之函数和方法详解”的完整攻略: 1. 函数的定义和调用 1.1 函数的定义 函数的定义可以使用 function 关键字,语法如下: function functionName(parameter1, parameter2) { // Function body } 其中 functionName 表示函数名,parame…

    JavaScript 2023年5月18日
    00
  • SVG动画vivus.js库使用小结(实例代码)

    下面是一份详细的攻略,包含vivus.js库的使用方法及实例代码: 介绍 Vivus.js库是一个轻量级的javascript库,可以创建美观的SVG描边动画效果。它支持很多动态效果,例如从头开始显示、流线显示、延迟显示等等。 安装 首先,在你的html文档中引入vivus.js文件: <script src="vivus.js"&…

    JavaScript 2023年6月11日
    00
  • JavaScript中Function详解

    JavaScript中Function详解 JavaScript中的函数是一种可重用代码块,它们可以带有参数并且可以返回值。在JavaScript中,函数是第一类对象,意味着它们可以像其他数据类型一样被赋值、传递和操作。 函数声明和调用 JavaScript中可以用 function 关键字定义一个函数。函数定义包括函数名、参数和函数体。下面是一个函数 ad…

    JavaScript 2023年5月27日
    00
  • jQuery Tools tab(幻灯片)

    下面是jQuery Tools tab(幻灯片)的完整攻略。 什么是jQuery Tools tab(幻灯片) jQuery Tools tab是一个基于jQuery的选项卡插件,可以通过点击选项卡来切换不同的内容页面。除此之外,还可以通过添加一些特效来改变选项卡的样式和显示方式。 如何使用jQuery Tools tab 引入jQuery库和jQuery …

    JavaScript 2023年6月11日
    00
合作推广
合作推广
分享本页
返回顶部