」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > RemoveCookieWall,Firefox 擴充

RemoveCookieWall,Firefox 擴充

發佈於2024-11-08
瀏覽:221

RemoveCookieWall, una extension de Firefox

您是否厭倦了網站上流行的要求您接受第三方 cookie 或結帳的橫幅?在這篇文章中,我解釋瞭如何製作(並發布)一個 Firefox 擴充功能以避免大多數網站出現這種情況

資訊

此擴充功能的程式碼發佈在 https://github.com/jagedn/removecookiewall-addon 您可以從 https://addons.mozilla.org/es/firefox/addon/removecookiewall/

在 Firefox 中(也可以在行動裝置上)安裝它

幾個月來,由於歐洲的要求(我認為),大多數網站在您第一次訪問它們時都會向您顯示一個橫幅,該橫幅不允許您繼續,直到您在以下兩者之間做出決定:

  • 我將在您的瀏覽器中放置數千個第三方 cookie,以監控您瀏覽的內容

  • 去結帳處付錢讓我不要這樣做

大多數這些程式庫會在頁面載入後立即執行 javascript 來讀取您的 cookie。如果他們發現您尚未簽出,他們會向您顯示一個 HTML 對話框,並透過將樣式變更為「封鎖」(或類似)來阻止正文

這個對話框不允許您閱讀下面的內容,但是...它仍然是HTML 的DOM 元素,因此,由於瀏覽器允許您打開開發控制台並檢查HTML,所以我想到了手動刪除對話框(您只需按一下“檢查”,查看定義它的HTML,然後按一下“刪除”)和chimpón,對話方塊就會消失。然後,我會尋找“body”聲明,並透過雙擊樣式屬性,刪除封鎖它的屬性,現在可以捲動。

小魔法。

然後發生了什麼事?好吧,javascript 程式碼只是一直等待用戶事件到達,告訴它您按下了哪個按鈕,但這些按鈕不再存在,因此它永遠不會到達,也不會安裝第三方 cookie。

好的,但是如果我刷新頁面怎麼辦?好吧,重新開始...所以這非常適合新的瀏覽器擴展為我做這件事。

刪除 CookieWall 擴展

Firefox 擴展,簡而言之,是一個保留的瀏覽器記憶體空間,其中執行可以與之對話的 javascript 程式碼。

它可以(如果用戶授予權限)將程式碼注入您訪問的頁面、打開選項卡、關閉選項卡、與遠端服務通訊…

RemoveCookieWall 是一個 Firefox 擴展,它「唯一」需要的是瀏覽器向用戶訪問的所有頁面注入一個小的 JavaScript 程式碼。

當頁面載入時,這個 javascript 將檢查是否有一個 DOM 元素與我調查過的他們正在使用的任何元素相符。如果偵測到它,它將使用標準 Javascript 函數將其刪除。

由於橫幅有時會在我們的程式碼執行後(毫秒)秒出現,因此腳本所做的就是重複搜尋幾秒鐘。此後,如果橫幅尚未出現,則擴充功能假定該頁面沒有 CookieeWall 並結束

這就是全部。剩下的就是打包程式碼,新增一個清單檔案來指示我們的擴充功能所需的權限,並將其發佈在 Firefox 中

程式碼

JS代碼基本上是:

var readyStateCheckInterval;
var counter = 0;

function sanitizeBody() {
    document.body.style.overflow = "unset"
    document.body.classList.remove('sxnlzit')
    document.body.classList.remove('didomi-popup-open')
    document.body.parentNode.classList.remove('sp-message-open')
}

function removeMe(element) {
    element.remove();
    sanitizeBody();
}

readyStateCheckInterval = setInterval(function() {
    if (document.readyState === "complete") {
        counter  ;
        const removeParent = ['div.pmConsentWall']; //elpais
        [...removeParent].forEach(s => {
            var divs = document.body.querySelectorAll(s);
            [...divs].forEach(element => {
                removeMe(element.parentNode);
            });
        });
        const removeThis = [
            'div[data-nosnippet="data-nosnippet"]',
            '#mrf-popup',
            '#didomi-popup',
            '[id^="sp_message_container_"]',
            '#cl-consent',
            'dialog.cookie-policy'
        ];
        [...removeThis].forEach(s => {
            var divs = document.body.querySelectorAll(s);
            [...divs].forEach(element => {
                removeMe(element);
            });
        });
        if (counter > 30) {
            clearInterval(readyStateCheckInterval);
        }
    }
}, 100);

代碼注入頁面後,每隔 100 毫秒開始一個間隔

腳本會查看 document.body.querySelectorAll 是否找到任何元素,例如 #mrf-popup、#didomi-popup 等。如果找到它,只需使用 element.remove()

將其刪除

經過幾次嘗試,最終刪除了間隔

每個擴充功能都必須有一個 Manifest 檔案。此擴充的內容很簡單:

{

    "description": "Remove CookieWall",
    "manifest_version": 2,
    "name": "RemoveCookieWall",
    "version": "0.11",
    "homepage_url": "https://github.com/jagedn/removecookiewall-addon",
    "icons": {
        "48": "icons/border-48.png"
    },
    "content_scripts": [{
        "matches": [
            "*://*/*"
        ],
        "js": ["removeCookieWall.js"]
    }],
    "browser_specific_settings": {
        "gecko": {
            "id": "[email protected]"
        }
    }
}

如你所見,content_scripts表示我們要將js注入到所有頁面中。其他擴充只能指示一個站點,其他擴充在背景執行 javascript,...

建置並發布

要在 Firefox 中發布,我們只需提供一個包含擴充功能所需的所有檔案的 zip 檔案。為了方便起見,我創建了一個 build.sh 來簡單地運行 zip:

zip -r -FS ../remove-cookiewall.zip * --排除 '.git' --排除 'build.sh'

在 Firefox 中發布擴充功能沒有任何複雜性,而且是免費的。您的擴充必須通過可能需要一天(或幾天)天的初步審核

版本聲明 本文轉載於:https://dev.to/jagedn/removecookiewall-una-extension-de-firefox-1pab?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 使用 MapStruct 來映射繼承層次結構
    使用 MapStruct 來映射繼承層次結構
    Intro MapStruct provides a rich set of features for mapping Java types. The technical documentation describes extensively the classes and ann...
    程式設計 發佈於2024-11-08
  • SQLite 參數替換是否會導致 Python 中的綁定錯誤?
    SQLite 參數替換是否會導致 Python 中的綁定錯誤?
    SQLite 參數替換問題在Python 2.5 中使用SQLite3 時,嘗試迭代列表並從中檢索資料時會出現一個常見問題一個資料時會出現一個常見問題一個資料庫.使用建議的「?」作為 SQL 注入預防措施的參數通常會導致有關綁定數量的錯誤。 經過調查,很明顯該錯誤源自於資料庫表的初始建立。建立語句,...
    程式設計 發佈於2024-11-08
  • 可以處理變數的 ID 以存取 Python 中的物件嗎?
    可以處理變數的 ID 以存取 Python 中的物件嗎?
    變數的 ID 可以取消引用嗎? 在 Python 中,id() 函數傳回物件的唯一識別碼。這個標識符可以儲存在變數中,但是這個變數的ID可以解引用嗎? 從學術角度來看,答案是肯定的。 _ctypes 模組提供了一個函數 PyObj_FromPtr(),可以將指標轉換為 Python 物件。使用此函數...
    程式設計 發佈於2024-11-08
  • 為什麼 imagecreatefrompng() 產生黑色背景而不是透明區域?
    為什麼 imagecreatefrompng() 產生黑色背景而不是透明區域?
    imagecreatefrompng() 產生黑色背景而不是透明區域? 在 PHP 中,imagecreatefrompng() 函數通常用於處理 PNG映像。然而,據觀察,使用此函數時,PNG 透明度可能會轉換為純黑色。 要解決此問題,可以在使用imagecreatetruecolor() 建立新...
    程式設計 發佈於2024-11-08
  • Go反射中reflect.Type和reflect.Value的主要差異是什麼?
    Go反射中reflect.Type和reflect.Value的主要差異是什麼?
    Go 中的反射類型和值Go 中的反射允許開發人員在運行時檢查和操作類型和值。了解它們的差異對於有效使用反射至關重要。 反射中的類型與值在反射中,reflect.TypeOf(i) 返回一個reflect.Type 對象,而reflect.ValueOf(i)返回一個reflect.Value obj...
    程式設計 發佈於2024-11-08
  • 如何在 AngularJS 中安全地設定變數的 iframe src 屬性?
    如何在 AngularJS 中安全地設定變數的 iframe src 屬性?
    在AngularJS 中從變數設定iframe src 屬性在AngularJS 中,嘗試從下列位置設定iframe 的src 屬性時可能會遭遇到問題一個變數。為了解決這個問題,這裡有一個逐步指南:1。注入 $sce 服務將 $sce(嚴格上下文轉義)服務注入控制器以處理清理。 function A...
    程式設計 發佈於2024-11-08
  • 為什麼我的 KeyListener 無法在 JPanel 中運作?
    為什麼我的 KeyListener 無法在 JPanel 中運作?
    JPanel 中KeyListeners 無回應:常見問題當使用KeyListeners 偵測JPanel 中的按鍵時,開發人員經常遇到這樣的問題:偵聽器無法觸發所需的操作。此問題可能由多個因素引起。 焦點元件約束KeyListener 依賴將自身附加到焦點元件才能正常運作。預設情況下,焦點不會自動...
    程式設計 發佈於2024-11-08
  • 從 React 到 React Native 的旅程
    從 React 到 React Native 的旅程
    作为一名 React / JS 开发人员,您可能有这样的想法 “我应该学习 React Native 吗?” 这是一个公平的问题,也是我几年前问自己的问题。事实证明,学习 React Native 绝对是正确的决定。这让我成为了亚马逊的高级开发倡导者,我现在使用 React Native 跨 And...
    程式設計 發佈於2024-11-08
  • 使用 Filament 和 Laravel 建立強大的管理面板:逐步指南
    使用 Filament 和 Laravel 建立強大的管理面板:逐步指南
    Laravel 是一个强大的 PHP 框架,为开发 Web 应用程序提供了坚实的基础。 Filament 是一个开源、优雅的 Laravel 管理面板和表单构建器,可简化管理界面的创建。本指南将引导您使用最新版本的 Filament 和 Laravel 构建强大的管理面板。 Laravel SaaS...
    程式設計 發佈於2024-11-08
  • 如何從 Pandas DataFrame 提取列標題?
    如何從 Pandas DataFrame 提取列標題?
    從 Pandas DataFrame 擷取列標題從 Pandas DataFrame 擷取列標題Pandas DataFrame 是通用的資料結構,可實現高效率的資料操作與分析。一項常見任務涉及提取列標題,這對於獲取 DataFrame 結構的概述或進一步處理非常有用。 假設您有一個從使用者輸入匯入...
    程式設計 發佈於2024-11-08
  • 透過範例解釋 Web 儲存 API
    透過範例解釋 Web 儲存 API
    Web Storage API: বিস্তারিত আলোচনা Web Storage API হলো জাভাস্ক্রিপ্টের একটি শক্তিশালী API যা ব্রাউজারে ব্যবহারকারীর ডেটা স্টোর করার জন্য ব্যবহ...
    程式設計 發佈於2024-11-08
  • 使用 Web 工具進行 Android 開發:使用 Ionic React 進行生產的最快方式
    使用 Web 工具進行 Android 開發:使用 Ionic React 進行生產的最快方式
    Investing in Android development can yield a huge device market share, expanded market reach, and high return on investment. With over 6.8 billion sma...
    程式設計 發佈於2024-11-08
  • 在Python中如何檢查字串是否以“hello”開頭?
    在Python中如何檢查字串是否以“hello”開頭?
    在Python中驗證以「hello」開頭的字串在Python中,判斷字串是否以「hello」開頭類似於Bash的常規表達方式。實作方法如下:aString = "hello world" aString.startswith("hello")startswit...
    程式設計 發佈於2024-11-08
  • 使用 Flama JWT 身份驗證保護 ML API
    使用 Flama JWT 身份驗證保護 ML API
    You've probably heard about the recent release of Flama 1.7 already, which brought some exciting new features to help you with the development and pro...
    程式設計 發佈於2024-11-08
  • 掌握 MySQL 效能:MySQL 延遲是什麼及其重要性
    掌握 MySQL 效能:MySQL 延遲是什麼及其重要性
    了解数据库性能的复杂性可能具有挑战性,但了解延迟等关键指标至关重要。随着企业越来越依赖数据驱动的洞察力,确保数据库快速有效地响应变得至关重要。在本文中,我们将深入探讨 MySQL 延迟的概念、其重要性,以及数据库优化先驱 Releem 如何处理此指标。 什么是延迟? 延迟是一个在从网...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3