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()。

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

相关推荐
爱吃提升1 小时前
Figma 组件库搭建清单(含命名规范+常用组件模板)
前端·javascript·figma
右耳朵猫AI1 小时前
JavaScript技术周刊 2026年第20周
开发语言·javascript·ecmascript
Cobyte2 小时前
15.响应式系统比对:链表在 Preact Signals 响应式系统中的应用
前端·javascript·vue.js
ZengLiangYi2 小时前
SourceAdapter 插件架构详解
javascript·算法·架构
ZengLiangYi2 小时前
如何解析 5 种完全不同格式的 AI 对话
javascript·人工智能·算法
七夜zippoe3 小时前
OpenClaw Canvas 执行:JavaScript 注入实战
开发语言·javascript·udp·canvas·openclaw
zzx2006__3 小时前
JavaScript最终考核
开发语言·前端·javascript
甄心爱学习3 小时前
【项目实训(个人10)】
开发语言·前端·javascript
触底反弹3 小时前
dom操作这篇文章就够了
javascript·面试