資產訪問限制方法 - 阻止不需要的訪客
鑰匙要點
- >對您的資產實施訪問控制對於安全至關重要。白名單是推薦的方法,看門人只允許受信任的實體訪問您的資產。可以將該網守放置在HTTP服務器或應用程序代碼上,提供檢查HTTP_HOST的工具。
> HTTP服務器可以有效地處理訪問控制,而無需為每個請求啟動應用程序代碼。根據服務器,可以使用不同的方法,例如mod_rewrite或apache中的允許/拒絕,或者可以使用nginx中的httpreferermodule。但是,如果有許多域需要管理或頻繁更改,則這種方法的可伸縮性可能是一個挑戰。 在應用程序代碼級別上的訪問控制提供了更大的靈活性。此方法還可以處理IFRAME情況,在此情況下,轉介商未提供有關iFrame狀態的信息。但是,HTTP服務器和應用程序代碼方法都不是萬無一失的,建議使用基於令牌的守門人(例如Oauth)來增強安全性。 - >
但是,我們如何控制誰有訪問權限,允許誰消耗我們的帶寬並查詢我們的服務?
我們將問題定義為
控制訪問to
資產>
通過資產,我們的意思是:任何可以從我們的網站查詢的東西。
在談論訪問控件時,我們進入安全域。在談論安全性時,白名單應該是解決問題的方法。控制誰可以訪問您的資產
比控制誰更容易訪問您的資產。根本不可能知道互聯網的所有布吉怪物。為了保護我們的
資產,我們僱用了一個看門人,只讓我們信任的人。問題解決了。但是,看門人應該如何舉起? > 舉重策略
>取決於您希望看門人的安全性以及客戶要求的東西,可以使用不同的策略。 兄弟,你甚至舉起嗎?
那麼,您的看門人在哪裡坐在哪裡?事實上,客戶是訪問控制的事實,因為他是一個不可靠的人。另一方面,HTTP服務器和應用程序代碼是有用的選項。兩者都為我們提供了強大的工具來檢查HTTP_HOST。
>
在Apache中,有兩種不同的方法。我們可以使用mod_rewrite或允許/拒絕。
>對於每一個小編輯,我們都需要深入研究我們的配置文件 - 您手動更改的越多,越會出錯。 >
如前所述,依靠推薦人並不總是一個好主意。它不僅是來自我們不可靠的人的數據,而且還沒有關於我們是否處於iframe中的任何線索。根本無法知道。
這就是為什麼我們讓殺手檢查是否在iframe中的原因。如果是這樣,我們讓他殺死了我們的目標:
>
IP阻止在資產訪問限制中如何工作? IP阻塞是一種用於防止特定IP地址訪問數字資產的方法。這是通過將IP地址添加到服務器配置文件中的“黑名單”中來完成的。來自這些IP地址的任何請求都將被拒絕,有效地阻止了它們訪問資產。 用戶代理阻止是一種用於防止特定瀏覽器或設備訪問數字資產的方法。這是通過識別用戶代理字符串來完成的,用戶代理字符串在向服務器提出請求時由瀏覽器或設備發送。如果用戶代理字符串在服務器的“黑名單”上與一個匹配,則該請求將被拒絕。 >在資產訪問限制方法時,是否有使用資產訪問限制方法的缺點?可以提供高水平的安全性,他們還可以阻止合法用戶。例如,IP阻止可以阻止使用VPN或代理的用戶,而地理障礙可以阻止出國旅行的用戶。因此,重要的是在實施這些方法之前仔細考慮對用戶的潛在影響。
當人們使用鏈接
>
>根據所使用的設置,查詢通過一系列
。簡單的設置為:客戶端 - > http服務器 - >應用程序代碼>
>根據您的HTTP服務器,可以使用不同的解決方案。 mod_rewrite方法:
# Turn mod_rewrite on
RewriteEngine On
# if it is not trusted.domain.tld block it
RewriteCond %{HTTP_REFERER} !^trusted\.domain\.tld$ [NC]
RewriteCond %{HTTP_REFERER} !^trusted\.tld$ [NC]
RewriteRule ^ - [F]
#specify the files to guard, block all the assets
<files "*.*">
#block everyone
Deny from all
#allow trusted ones
Allow from trusted.tld trusted.domain.tld
</files>
這裡的大問題是可擴展性:如果我們有1000個域需要能夠訪問我們的資產怎麼辦?如果域列表經常更改
怎麼辦?
應用程序代碼知道該怎麼做
在應用程序代碼級別上,在應用程序代碼級別上擁有訪問控件意味著更大的靈活性。一個人可能很快就會讓他的守門人起床並跑步:location / {
valid_referers trusted.tld trusted.domain.tld;
if ($invalid_referer) {
return 444;
}
}
那些iframe呢? # Turn mod_rewrite on
RewriteEngine On
# if it is not trusted.domain.tld block it
RewriteCond %{HTTP_REFERER} !^trusted\.domain\.tld$ [NC]
RewriteCond %{HTTP_REFERER} !^trusted\.tld$ [NC]
RewriteRule ^ - [F]
#specify the files to guard, block all the assets
<files "*.*">
#block everyone
Deny from all
#allow trusted ones
Allow from trusted.tld trusted.domain.tld
</files>
location / {
valid_referers trusted.tld trusted.domain.tld;
if ($invalid_referer) {
return 444;
}
}
>
>這裡提供的解決方案將使您免受大多數布吉怪物的侵害。但是兩種解決方案都不是傻瓜。第一個使用來自客戶端的數據,第二個是由客戶端運行的JavaScript。
安全的方法是使用基於令牌的網守。 Oauth可能是您想要在這里工作的人,但這超出了本文的範圍。 資產訪問限制方法是用於防止未經授權訪問數字資產的策略。這些方法包括IP阻止,其中涉及從特定的IP地址阻止訪問;地理障礙,該地理位置限制了訪問權限;和用戶代理阻止,可防止從特定的瀏覽器或設備訪問。其他方法包括HTTP推薦程序阻止,該阻止限制了基於Referring網站的訪問和密碼保護,該密碼保護要求用戶輸入密碼以獲取訪問權限。
>如何在資產訪問限制中使用用戶代理阻止?
>
>密碼保護如何在資產訪問限制中起作用? >
可以一起使用多個資產訪問限制方法? 🎜>是的,可以將多個資產訪問限制方法一起使用以提供更高級別的安全性。例如,您可以使用IP封鎖來防止特定IP地址訪問,然後使用密碼保護進一步限制訪問對授權用戶的訪問。 >在您的網站上實現資產訪問限制方法通常涉及修改服務器的配置文件。確切的過程將取決於您使用的服務器軟件以及要實現的特定限制方法。
>>資產訪問限制方法的一些替代方法是什麼?
資產訪問限制方法的替代方法包括使用內容交付網絡(CDN)分配您的資產,使用防火牆保護服務器,或使用提供一系列安全功能的安全插件或服務。這些替代方案可以提供高水平的安全性,而沒有資產訪問限制方法的潛在缺點。
以上是資產訪問限制方法 - 阻止不需要的訪客的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在PHP中,應使用password_hash和password_verify函數實現安全的密碼哈希處理,不應使用MD5或SHA1。1)password_hash生成包含鹽值的哈希,增強安全性。 2)password_verify驗證密碼,通過比較哈希值確保安全。 3)MD5和SHA1易受攻擊且缺乏鹽值,不適合現代密碼安全。

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。
