」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 修補您的 Discord 活動的網路請求,以實現順利的 CSP 合規性

修補您的 Discord 活動的網路請求,以實現順利的 CSP 合規性

發佈於2024-11-02
瀏覽:169

透過Discord運行Discord活動時,您可能會遇到內容安全策略(CSP)問題。您可以透過確保網路請求遵循 Discord 代理 規則來修復這些問題。

這可以手動完成...或者你可以讓@robojs/patch處理它。

什麼是CSP?

Patch Your Discord Activity’s Network Requests for Smooth CSP Compliance

內容安全策略 (CSP) 是一種安全標準,有助於防止 跨站腳本 (XSS) 攻擊。它控制頁面可以載入哪些資源以及可以向何處發送資料。

當您在Discord 中運行Discord 活動 時,您實際上是在使用Discord 代理 作為中間人,這意味著它設定了自己的 CSP 規則。如果您的網路請求不遵守這些規則,它們將被阻止。

  • 除非以 /.proxy 為前綴,否則像 /api/token 這樣的相對請求將被阻止。
  • 像 https://example.com/api/token 這樣的外部請求將被阻止,除非它們被映射代理

解決 CSP 違規問題

如上所述,您所要做的就是確保您的網路請求遵循 Discord 代理 規則。在某些情況下,這包括將 /.proxy 新增至請求路徑的開頭。

// Before
fetch('/api/token')

// After
fetch('/.proxy/api/token')

然而,WebSockets 可能有點棘手。特別是當依賴熱模組替換(HMR)時,它會在您自己的活動之前加載,例如Vite。因此,我們創建了 @robojs/patch 來為您處理一切。

修補你的活動

@robojs/patch 是一個輕量級軟體包,可以修補您的網路請求以遵循 Discord 代理 規則。它透過更新 fetchWebSocket 全域變數來運作。

npm install @robojs/patch

根據您的專案設置,我們有不同的方法來應用此補丁。

方式一:Vite插件(建議)

如果您使用Vite,您可以將補丁作為插件應用到您的Vite配置檔案中。

import { DiscordProxy } from '@robojs/patch'
import { defineConfig } from 'vite'

export default defineConfig({
    plugins: [DiscordProxy.Vite()]
})

我們推薦此方法,因為它允許補丁在Vite的HMR客戶端之前運行,確保其正常工作。

方法二:函數調用

如果您沒有使用Vite,您可以直接呼叫函數來套用補丁。

import { DiscordProxy } from '@robojs/patch'

DiscordProxy.patch()

請務必在專案開始時、載入其他腳本之前呼叫此函數。 (例如,index.js 檔案的頂部)

➞? 文件: @robojs/patch

外部請求

這不會影響對外部 URL 發出的請求。如果您遇到CSP問題,您可以透過建立您自己的代理或在Discord開發者入口網站中映射它們來解決這些問題。

➞? 教學: 使用代理解決 CSP 問題

對 Discord 活動有興趣?

Patch Your Discord Activity’s Network Requests for Smooth CSP Compliance

Robo.js 是一個強大的框架,用於輕鬆建立 Discord 活動。它提供了廣泛的功能和工具來幫助您創建史詩般的 Discord 體驗!

加入我們的Discord Server與其他開發人員聊天、提出問題並分享您的專案。我們是一群友善的人,總是很樂意提供協助!另外,我們自己的人工智慧機器人,Sage,可以幫助您解決任何問題。

➞? 社群:加入我們的 Discord 伺服器

➞? 教學: 使用 Robo.js 在幾秒鐘內創建一個 Discord 活動

機器人 - 想像魔法

透過輕鬆的活動、機器人、伺服器等來增強 Discord! ⚡ | 83 會員

Patch Your Discord Activity’s Network Requests for Smooth CSP Compliance 不和諧網站
版本聲明 本文轉載於:https://dev.to/waveplay/patch-your-discord-activitys-network-requests-for-smooth-csp-compliance-432c?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • PHP與C++函數重載處理的區別
    PHP與C++函數重載處理的區別
    作為經驗豐富的C開發人員脫離謎題,您可能會遇到功能超載的概念。這個概念雖然在C中普遍,但在PHP中構成了獨特的挑戰。讓我們深入研究PHP功能過載的複雜性,並探索其提供的可能性。 在PHP中理解php的方法在PHP中,函數超載的概念(如C等語言)不存在。函數簽名僅由其名稱定義,而與他們的參數列表無關...
    程式設計 發佈於2025-04-22
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月份)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP...
    程式設計 發佈於2025-04-22
  • 使用jQuery如何有效修改":after"偽元素的CSS屬性?
    使用jQuery如何有效修改":after"偽元素的CSS屬性?
    在jquery中了解偽元素的限制:訪問“ selector 嘗試修改“:”選擇器的CSS屬性時,您可能會遇到困難。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    程式設計 發佈於2025-04-22
  • 為什麼不使用CSS`content'屬性顯示圖像?
    為什麼不使用CSS`content'屬性顯示圖像?
    在Firefox extemers屬性為某些圖像很大,&& && && &&華倍華倍[華氏華倍華氏度]很少見,卻是某些瀏覽屬性很少,尤其是特定於Firefox的某些瀏覽器未能在使用內容屬性引用時未能顯示圖像的情況。這可以在提供的CSS類中看到:。 googlepic { 內容:url(&...
    程式設計 發佈於2025-04-22
  • 在PHP中如何高效檢測空數組?
    在PHP中如何高效檢測空數組?
    在PHP 中檢查一個空數組可以通過各種方法在PHP中確定一個空數組。如果需要驗證任何數組元素的存在,則PHP的鬆散鍵入允許對數組本身進行直接評估:一種更嚴格的方法涉及使用count()函數: if(count(count($ playerList)=== 0){ //列表為空。 } 對...
    程式設計 發佈於2025-04-22
  • Go web應用何時關閉數據庫連接?
    Go web應用何時關閉數據庫連接?
    在GO Web Applications中管理數據庫連接很少,考慮以下簡化的web應用程序代碼:出現的問題:何時應在DB連接上調用Close()方法? ,該特定方案將自動關閉程序時,該程序將在EXITS EXITS EXITS出現時自動關閉。但是,其他考慮因素可能保證手動處理。 選項1:隱式關閉終...
    程式設計 發佈於2025-04-22
  • Java為何無法創建泛型數組?
    Java為何無法創建泛型數組?
    通用陣列創建錯誤 arrayList [2]; JAVA報告了“通用數組創建”錯誤。為什麼不允許這樣做? 答案:Create an Auxiliary Class:public static ArrayList<myObject>[] a = new ArrayList<my...
    程式設計 發佈於2025-04-22
  • 將圖片浮動到底部右側並環繞文字的技巧
    將圖片浮動到底部右側並環繞文字的技巧
    在Web設計中圍繞在Web設計中,有時可以將圖像浮動到頁面右下角,從而使文本圍繞它纏繞。這可以在有效地展示圖像的同時創建一個吸引人的視覺效果。 css位置在右下角,使用css float and clear properties: img { 浮點:對; ...
    程式設計 發佈於2025-04-22
  • C++20 Consteval函數中模板參數能否依賴於函數參數?
    C++20 Consteval函數中模板參數能否依賴於函數參數?
    [ consteval函數和模板參數依賴於函數參數在C 17中,模板參數不能依賴一個函數參數,因為編譯器仍然需要對非contexexpr futcoriations contim at contexpr function進行評估。 compile time。 C 20引入恆定函數,必須在編譯時進...
    程式設計 發佈於2025-04-22
  • 如何干淨地刪除匿名JavaScript事件處理程序?
    如何干淨地刪除匿名JavaScript事件處理程序?
    刪除匿名事件偵聽器將匿名事件偵聽器添加到元素中會提供靈活性和簡單性,但是當要刪除它們時,可以構成挑戰,而無需替換元素本身就可以替換一個問題。 element? element.addeventlistener(event,function(){/在這里工作/},false); 要解決此問題,請考...
    程式設計 發佈於2025-04-22
  • eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    稱量()和ast.literal_eval()中的Python Security 在使用用戶輸入時,必須優先確保安全性。強大的python功能eval()通常是作為潛在解決方案而出現的,但擔心其潛在風險。 This article delves into the differences betwee...
    程式設計 發佈於2025-04-22
  • Java數組中元素位置查找技巧
    Java數組中元素位置查找技巧
    在Java數組中檢索元素的位置 利用Java的反射API將數組轉換為列表中,允許您使用indexof方法。 (primitives)(鏈接到Mishax的解決方案) 用於排序陣列的數組此方法此方法返回元素的索引,如果發現了元素的索引,或一個負值,指示應放置元素的插入點。
    程式設計 發佈於2025-04-22
  • 如何避免Go語言切片時的內存洩漏?
    如何避免Go語言切片時的內存洩漏?
    ,a [j:] ...雖然通常有效,但如果使用指針,可能會導致內存洩漏。這是因為原始的備份陣列保持完整,這意味著新切片外部指針引用的任何對象仍然可能佔據內存。 copy(a [i:] 對於k,n:= len(a)-j i,len(a); k
    程式設計 發佈於2025-04-22
  • 您如何在Laravel Blade模板中定義變量?
    您如何在Laravel Blade模板中定義變量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配變量對於存儲以後使用的數據至關重要。在使用“ {{}}”分配變量的同時,它可能並不總是最優雅的解決方案。 幸運的是,Blade通過@php Directive提供了更優雅的方法: $ old_section =...
    程式設計 發佈於2025-04-22
  • Java中如何使用觀察者模式實現自定義事件?
    Java中如何使用觀察者模式實現自定義事件?
    在Java 中創建自定義事件的自定義事件在許多編程場景中都是無關緊要的,使組件能夠基於特定的觸發器相互通信。本文旨在解決以下內容:問題語句我們如何在Java中實現自定義事件以促進基於特定事件的對象之間的交互,定義了管理訂閱者的類界面。 以下代碼片段演示瞭如何使用觀察者模式創建自定義事件: args...
    程式設計 發佈於2025-04-22

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

Copyright© 2022 湘ICP备2022001581号-3