जवाबों:
एक सरल समाधान मैं एक में उपयोग करें .htaccess
:
RewriteCond %{REQUEST_URI} !^/wp-admin [NC]
RewriteCond %{QUERY_STRING} author=\d
RewriteRule ^ - [L,R=403]
यह @ jptsetme के उत्तर के समान है, लेकिन यह तब भी काम करता है जब क्वेरी स्ट्रिंग होती है /?dummy&author=5
, और इसके लिए खोज पैटर्नRewriteRule
बहुत तेज़ होता है: आप अक्सर इसके ([0-9]*)
लिए नियमित अभिव्यक्तियों में एक कैप्चर देखते हैं । लेकिन कैप्चर की गई अभिव्यक्ति का उपयोग न करने पर कैप्चर के लिए मेमोरी बर्बाद करने की आवश्यकता नहीं है, और पहले कैरेक्टर के लिए एक मैच पर्याप्त है, क्योंकि आप स्वीकार नहीं करना चाहते हैं author=1b
।
अपडेट 20.04.2017
मैं उन लोगों से अधिक "टूटा हुआ" अनुरोध देख रहा हूं जो एक साधारण स्कैन चलाने के लिए बहुत मूर्ख हैं। अनुरोधित URL इस तरह दिखते हैं:
/?author={num:2}
तो आप ऊपर दिए गए नियम का विस्तार कर सकते हैं:
RewriteCond %{REQUEST_URI} !^/wp-admin [NC]
RewriteCond %{QUERY_STRING} ^author=\d+ [NC,OR]
RewriteCond %{QUERY_STRING} ^author=\{num
RewriteRule ^ - [L,R=403]
आप नहीं कर सकते।
डब्ल्यूपीएसएन टूल एक स्वचालित उपयोगिता है जो उपयोगकर्ता नाम निर्धारित करने के लिए वर्डप्रेस के अनुकूल यूआरएल का लाभ उठाती है। यह लेखकों के लिए पहले 10 संभावित आईडी के माध्यम से लूप करेगा और जांच करेगाLocation
उपयोगकर्ता नाम खोजने के लिए HTTP प्रतिक्रिया पर हेडर की ।
का उपयोग करते हुए http://mysite.url
उदाहरण के लिए रहा है ...
डब्ल्यूपीएसन जांच करेगा http://mysite.url/?author=1
। यदि आपकी साइट बहुत अधिक पर्मलिंक का उपयोग कर रही है, तो यह 301 Location
हेडर को एक हेडर के साथ लौटा देगा http://mysite.url/author/username
। यदि आपकी साइट नहीं है बहुत अधिक पर्मलिंक्स का उपयोग कर रही है, तो इसके बजाय यह 200 (ओके) की स्थिति लौटाएगी, इसलिए डब्ल्यूपीएसकेएन स्ट्रिंग "पोस्ट द्वारा उपयोगकर्ता नाम" की जांच करेगा और उपयोगकर्ता नाम को निकालेगा।
सबसे पहले, सिर्फ इसलिए कि कोई आपके उपयोगकर्ता नाम का अनुमान लगा सकता है, इसका मतलब यह नहीं है कि आपकी साइट असुरक्षित है। और वास्तव में कोई तरीका नहीं है कि आप किसी को अपनी साइट को इस तरह से पार्स करने से रोक सकें।
तथापि ...
यदि आप वास्तव में इस बारे में चिंतित हैं, तो मैं दो बातें करने की सलाह दूंगा:
एक अन्य विकल्प यह है कि आप अपने लेखक पर्मलिंक को फिर से लिखें। ऐसा करने के कई तरीके हैं, और आप शायद इस साइट पर भी कुछ पा सकते हैं ।
इसका पूरी तरह से परीक्षण नहीं किया गया है, लेकिन मुझे लगता है कि वेब सर्वर स्तर पर इसके चारों ओर दीवारें बनाने की कोशिश करने के बजाय अंतर्निहित संसाधन को हटाना बेहतर है। तो WP शब्दों में जो इसे लेखक-संबंधित क्वेरी चर को संसाधित करने से रोक रहा होगा।
if ( ! is_admin() ) {
add_filter(
'query_vars',
function ( $public_query_vars ) {
foreach ( array( 'author', 'author_name' ) as $var ) {
$key = array_search( $var, $public_query_vars );
if ( false !== $key ) {
unset( $public_query_vars[$key] );
}
}
return $public_query_vars;
}
);
}
PS ध्यान दें कि यह लेखक अभिलेखागार को पूरी तरह से मार देगा , जो उचित व्यामोह स्तर नहीं हो सकता है या नहीं :)
आप इस प्रकटीकरण को रोकने के लिए एक .htaccess rewrite नियम का उपयोग कर सकते हैं, लेकिन आपको EAMann द्वारा वर्णित पार्सबल सामग्री में उपयोगकर्ता नाम का खुलासा करने से बचने के लिए उपनामों का उपयोग करना भी सुनिश्चित करना चाहिए।
निम्नलिखित ब्लॉग का वर्णन है कि यह कैसे करना है लेकिन फिर से लिखना नियम में है: http://www.question-defense.com/2012/03/20/block-wordpress-user-enumeration-secure-wordpress-against-hacking
सही नियम को फिर से लिखे गए URL से क्वेरी स्ट्रिंग को हटा देना चाहिए, अन्यथा आप उपयोगकर्ता नाम अभी भी बताएंगे। इसे ऐसा दिखना चाहिए:
# Stop wordpress username enumeration vulnerability
RewriteCond %{REQUEST_URI} ^/$
RewriteCond %{QUERY_STRING} ^/?author=([0-9]*)
RewriteRule ^(.*)$ http://yoursite.com/somepage/? [L,R=301]
हमारे लिए अच्छा काम करना।
मैं जोड़ना चाहता था कि आप इसे नगनेक्स पर भी कर सकते हैं। चेक करें:
» वर्डप्रेस यूजर एनगेंशन को nginx पर ब्लॉक करना - www.edwidget.name
एक साइड नोट के रूप में, मैं WP इंजन के साथ होस्ट की गई अपनी साइट पर उपयोगकर्ता नामकरण को रोकना चाहता था, जो उपयोगकर्ताओं की निम्न स्तर के nginx config फ़ाइलों तक पहुंच को सीमित करता है। हालांकि, उनके नियंत्रण कक्ष में एक "पुनर्निर्देशन नियम" अनुभाग है, जो आपको इसे पूरा करने की अनुमति देता है। कुछ समय बाद मैं सबसे अच्छा विन्यास निकालने में कामयाब रहा:
Redirect Name: // choose a description for the rewrite
Domain: // you *must* select a domain; "All Domains" will *not* work here!
Source: ^/$
Destination: /?
फिर आपको Advanced Settings
पैनल दिखाने की जरूरत है ...
Match args: author=([0-9]*)
Rewrite type: 301 Permanent
Et voila, आपके उपयोगकर्ता नाम सुरक्षित हैं [r]!
मैंने htaccess में निम्न जोड़कर WPScan से उपयोगकर्ता गणना पूरी तरह से अवरुद्ध कर दी है
# Stop wordpress username enumeration vulnerability
RewriteCond %{REQUEST_URI} ^/$
RewriteCond %{QUERY_STRING} ^/?author=([0-9]*)
RewriteRule ^(.*)$ http://yourdomain.com [L,R=301]
RewriteCond %{QUERY_STRING} author=d
RewriteRule ^ /? [L,R=301]
एक gov't एजेंसी के लिए एक प्रवेश परीक्षक के रूप में मेरी पेशेवर राय ... यह है हमेशा हैअपनी वेबसाइट के बारे में जानकारी को संकलित करना कठिन बनाता है। आप में से कुछ के पास एक वेबसाइट होगी जो गूगल, स्क्रिप्ट किडी हैकर्स से ऊपर उठती है। हम स्तरित सुरक्षा के बारे में बात कर रहे हैं और प्रत्येक परत के साथ, आप एक प्रवेश प्रयास में समय और जटिलता जोड़ते हैं। प्रत्येक परत हैकर के लिए आवश्यक कौशल को भी जोड़ता है। WP पर कुछ बहुत अच्छे एप्लीकेशन फायरवॉल उपलब्ध हैं। उन लोगों के लिए देखें जो आईपी पते को ब्लॉक कर सकते हैं जिनके पास बार-बार उपयोगकर्ता लॉगिन प्रयास या 404 हैं। यह विचार आपके फ़ायरवॉल के लिए है कि आईपी को स्वचालित रूप से ब्लॉक करें जो आपकी वेबसाइट को उन पृष्ठों के लिए स्कैन करता है जो मौजूद नहीं हैं या आपकी साइट पर बार-बार साइन करने का प्रयास नहीं करते हैं। एक अच्छी सुविधा में XSS और SQL इंजेक्शन अवरोधक क्षमताएं भी शामिल हैं। टिप्स और ट्रिक्स मुख्यालय, पीटर, रुहुल, आइवी से ऑल इन वन वन सिक्योरिटी का उपयोग करने पर विचार करें।
.htaccess
मार्ग के बजाय , एक अन्य विकल्प निम्न कोड को अपने बच्चे के विषय में जोड़ना है functions.php
:
# Redirect author page to homepage
add_action( 'template_redirect', 'wpse_46469_author_page' );
function wpse_46469_author_page() {
# If the author archive page is being accessed, redirect to homepage
if ( is_author() ) {
wp_safe_redirect( get_home_url(), 301 );
exit;
}
}
इसके अतिरिक्त, आप निम्न लेखक लिंक को बदल सकते हैं जो प्रत्येक पृष्ठ के उपयोगकर्ता नाम में कुछ और (जैसे मुखपृष्ठ) में जोड़े जाते हैं, निम्न का उपयोग करके:
# Replace author URL with the homepage
add_filter( 'author_link', 'wpse_46469_author_link' );
function wpse_46469_author_link() {
# Return homepage URL
return home_url();
}
मुझे पता है कि यह एक पुरानी पोस्ट है, लेकिन भविष्य के संदर्भों के लिए मैं अपना समाधान भी जोड़ना चाहूंगा। यह केवल एक स्निपेट है जिसे functions.php
आपकी थीम पर रखा जाना है। यह सब कुछ जगह और काम कर रहा है, यहां तक कि लेखक अभिलेखागार भी, लेकिन यह खराब गणना अनुरोधों को मारता है।
if (!is_admin()) {
if( preg_match('/author=([0-9]*)/i', $_SERVER['QUERY_STRING']) ) {
add_filter( 'query_vars', 'iside_remove_author_from_query_vars' );
}
add_filter('redirect_canonical', 'iside_remove_author_from_redirects', 10, 2);
}
function iside_remove_author_from_redirects($redirect, $request) {
if( !is_admin() && preg_match('/author=([0-9]*)/i', $_SERVER['QUERY_STRING']) ) {
add_filter( 'query_vars', 'iside_remove_author_from_query_vars' );
}
return $redirect;
}
function iside_remove_author_from_query_vars( $query_vars ) {
if( !is_admin() ) {
foreach( array( 'author', 'author_name' ) as $var ) {
$key = array_search( $var, $query_vars );
if ( false !== $key ) {
unset( $query_vars[$key] );
}
}
}
return $query_vars;
}
यह क्या करता है:
author=1
यदि आप पर्मलिंक का उपयोग करते हैं, तो यह लेखक को चातुर्य में अभिलेखागार को छोड़ देगा। इसके अलावा, अगर यूआरएल कुछ /dummy?author=1
इस तरह होगा : यह सिर्फ पेज दिखाएगा /dummy
।
इस सवाल के लिए रार्स्ट के जवाब और https://perishablepress.com/stop-user-enumeration-wordpress/ का धन्यवाद
मैं अपनी दृष्टि पोस्ट करना चाहता हूं:
RewriteCond %{REQUEST_URI} ^/$
RewriteCond %{QUERY_STRING} ^author= [NC]
RewriteRule (.*) $1? [L]
पहली पंक्ति केवल मुख पृष्ठ का पता लगाती है। मैं समझाता हूँ क्यों। यह "उपयोगकर्ता-एन्यूमरेशन" सुविधा केवल होम पेज पर काम करती है, इसलिए सभी यूआरएल को फिर से लिखने की आवश्यकता नहीं है।
अगला हम author=
क्वेरी स्ट्रिंग की तलाश करते हैं। यह स्पष्ट है।
अंत में, हम बिना किसी खंड के मूल पृष्ठ दिखाते हैं , पुनर्निर्देश (301, 302) या प्रतिबंध (403)। यह किसी भी अन्य बेकार पैरामीटर के साथ एक पृष्ठ की तरह काम नहीं करना चाहिए?