LF11期_day19~20 补环境(二)入门案例

案例代码

javascript 复制代码
function get_sign() {
    /*// 黑匣子,省略很多代码
    // (1) BOM和DOM正常的前端动作
    window.addEventListener("test")
    // 搜索框
    let kw = document.getElementById("kw")
    let _class = kw.getAttribute("class")

    // 创建画布
    let canvas = document.createElement("canvas")
    let ctx = canvas.getContext("2d");
    ctx.fillRect(10, 10, 100, 100);*/

    // (2) 基于DOM和BOM进行环境校验
   /* if (navigator.toString() === '[object Navigator]') {
        let navLength = navigator.userAgent.length
        return "u82d1660a" + navLength // Yuan老师的微信,想深入学逆向爬虫的联系我,结一段善缘!

    } else {
        return false
    }*/
}

console.log(get_sign())

上述代码:

let ctx = canvas.getContext("2d");

ctx.fillRect(10, 10, 100, 100);*/

如果ctx没有后续操作,是不用补的,但是最终还是用的

补充的js

最终补环境答案代码:

javascript 复制代码
window = {
    addEventListener: function () {

    }
}
kw = {
    getAttribute: function () {

    }
}
ctx = {
    fillRect:function () {

    }
}

canvas ={
    getContext: function () {
        return ctx
    }
}

document = {
    getElementById:function (id) {
        console.log("document getElementById:",id); // 看调用了什么标签名。以便缺啥补啥
        // 讲解if作用,看下一步调用了什么标签,以及这个标签有没有下一步调用。比如kw有下一步调用,所以这里就要if。如果没有下一步调用,这个if不加也没事!
        if(id === "kw"){ //而且这个方法,可能会被其他标签调用很多次!一定要看具体缺什么标签,然后if判断返回该标签
            // console.log("id",id)
            // console.log(typeof id)
            // console.log(typeof kw)
            return kw// 这里就是返回kw标签!object对象!而id是string对象!
        }
    },
    createElement:function (ele) {
        console.log("document createElement:",ele)
        if (ele === "canvas"){
            return canvas
        }
    }
}

navigator = {
    toString() {
        return "[object Navigator]";
    },
    userAgent: 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/148.0.0.0 Safari/537.36'
}

// 关键:设置 Symbol.toStringTag,让 Object.prototype.toString.call(navigator) 返回正确结果
Object.defineProperty(navigator, Symbol.toStringTag, {
  value: "Navigator",
  writable: false,
  enumerable: false,
  configurable: true
});

解析一,Object.defineProperty:

javascript 复制代码
Object.defineProperty(navigator, Symbol.toStringTag, {
  value: "Navigator",
  writable: false,
  enumerable: false,
  configurable: true
});

A:为什么需要如上代码的解释!

Q:在node-js版本中,18版本是不用这一段的。这段主要是因为node最新版本中,具体查了AI之后才知道的!

就是我们补充navigator,重写里面的toString方法return "object Navigator"。但是最新nodejs版本是这个navigator的toString是继承自Object对象的!!!

也就是AI所说的:你当前的写法只重写了 navigator.toString() 方法,但浏览器里的 Object.prototype.toString.call(navigator) 检测的是对象的 Symbol.toStringTag 内部标记,不是直接调用你写的 toString()。

这里不会详情查原型链知识点!

相关推荐
weedsfly6 分钟前
前端必知必会:从 IIFE 到 ESM,模块化到底在解决什么?
前端·javascript
渣波10 分钟前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
槑有老呆13 分钟前
每次跟大模型聊天,都是一次「失忆」的 HTTP 请求
javascript
sarasuki16 分钟前
彻底搞懂JS闭包:从作用域链、形成条件到优缺点
javascript
糖拌西瓜皮18 分钟前
TypeScript 进阶:泛型、条件类型、类型守卫与装饰器
javascript·node.js
swipe14 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
kyriewen15 小时前
AI 生成的代码能跑就行?这 5 个坑迟早炸
前端·javascript·ai编程
kisshyshy15 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
胡志辉16 小时前
从v8源码和react深入浅出理解 JavaScript 作用域链与闭包
前端·javascript
Bolt16 小时前
TypeScript 7.0 来了:当 tsc 用 Go 重写之后
javascript·typescript·go