如何统计某个网站加载资源或者发送请求的时候,都使用了哪些域名

要统计某个网站在加载资源或者发送请求时使用的所有域名,可以通过以下方法进行:

  1. **使用浏览器开发者工具**:
  • 打开你的网站。

  • 按下 `F12` 打开开发者工具,或通过右键点击页面并选择"检查"。

  • 在开发者工具中,切换到 "网络"(Network) 面板。

  • 刷新页面,你会看到所有的网络请求。

  • 在"域名"或"名称"列中,你可以看到所有请求的 URL。可以手动统计这些 URL 中的域名。

  1. **使用浏览器扩展**:
  • 有些浏览器扩展可以帮助你统计网站请求的域名,比如 `Ghostery`、`uBlock Origin` 等。

  • 安装并启用这些扩展,它们会显示所有的请求并提供统计数据。

  1. **编写脚本**:
  • 你可以编写一个脚本来自动统计这些域名。以下是一个示例的 JavaScript 代码,可以在浏览器控制台中运行:
javascript 复制代码
(function() {
    const domains = new Set();
    const requests = performance.getEntriesByType('resource');
    requests.forEach(request => {
        try {
            const url = new URL(request.name);
            domains.add(url.hostname);
        } catch (e) {
            console.error('Invalid URL:', request.name);
        }
    });
    console.log('Domains used:', Array.from(domains));
})();

将以上代码复制并粘贴到开发者工具的控制台中运行,你会在控制台中看到所有请求的域名列表。

通过这些方法,你就可以统计出某个网站加载资源或者发送请求时使用的所有域名。

方法三中的脚本讲解

通过以下步骤统计网站加载资源或发送请求时使用的所有域名:

  1. **创建一个 Set 用于存储域名**:
javascript 复制代码
const domains = new Set();
  1. **获取所有的资源请求信息**:
  • 使用 `performance.getEntriesByType('resource')` 获取所有资源请求的性能条目。这些条目包括所有被请求的资源,如 CSS、JS、图像等。
javascript 复制代码
const requests = performance.getEntriesByType('resource');
  1. **遍历所有请求并提取域名**:
  • 对每个资源请求,尝试解析其 URL 并提取域名。

  • 使用 `new URL(request.name)` 解析 URL,并提取域名 `url.hostname`。

  • 将域名添加到 `Set` 中,确保不会有重复的域名。

javascript 复制代码
   requests.forEach(request => {
       try {
           const url = new URL(request.name);
           domains.add(url.hostname);
       } catch (e) {
           console.error('Invalid URL:', request.name);
       }
   });
  1. **输出所有独特的域名**:
  • 将 `Set` 转换为数组并打印出来。
javascript 复制代码
   console.log('Domains used:', Array.from(domains));

完整的脚本如下:

javascript 复制代码
(function() {
    const domains = new Set();
    const requests = performance.getEntriesByType('resource');
    requests.forEach(request => {
        try {
            const url = new URL(request.name);
            domains.add(url.hostname);
        } catch (e) {
            console.error('Invalid URL:', request.name);
        }
    });
    console.log('Domains used:', Array.from(domains));
})();

脚本原理总结

  • **`performance.getEntriesByType('resource')`**:获取所有资源请求的性能条目。

  • **`new URL(request.name)`**:创建 URL 对象以解析请求 URL。

  • **`url.hostname`**:提取 URL 中的域名。

  • **`Set`**:用于存储唯一的域名,避免重复。

  • **`Array.from(domains)`**:将 `Set` 转换为数组,便于输出。

通过这些步骤,该脚本能够统计网站加载资源或发送请求时使用的所有域名。

相关推荐
AI浩6 小时前
【Labelme数据操作】LabelMe标注批量复制工具 - 完整教程
运维·服务器·前端
涔溪7 小时前
CSS 网格布局(Grid Layout)核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解
前端·css
2401_878454537 小时前
浏览器工作原理
前端·javascript
西陵7 小时前
为什么说 AI 赋能前端开发,已经不是选择题,而是必然趋势?
前端·架构·ai编程
by__csdn8 小时前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
天天扭码9 小时前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
Luna-player9 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
lionliu05199 小时前
js的扩展运算符的理解
前端·javascript·vue.js
小草cys9 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript
奇舞精选9 小时前
GELab-Zero 技术解析:当豆包联手中兴,开源界如何守住端侧 AI 的“最后防线”?
前端·aigc