संक्षिप्त जवाब
example.com/bob/files/picture.jpg वर्डप्रेस मल्टीसाइट इंस्टॉलेशन में छवियों के लिए पसंदीदा, विहित URL है । URL में दो URL blogs.dir
अनिवार्य रूप से समान हैं, और दोनों ही फाइल सिस्टम संरचना का लाभ उठाते हैं। 'बॉब' के साथ पथ मौजूद है क्योंकि आपने उप-निर्देशिका स्थापित की है, उपडोमेन इंस्टॉल नहीं। अन्य पथ आपके अन्य साइटों के आधार पर मौजूद होंगे, जैसे example.com/fred/wp-content/blogs.dir/5/files/pictures.jpg। अन्यथा, कोई अन्य पथ मौजूद नहीं है।
लंबा जवाब
इस प्रक्रिया के बारे में बहुत कुछ समझा सकता है, और मैं आपके द्वारा खोजे जा रहे विस्तार के स्तर से 100% निश्चित नहीं हूं, इसलिए मैं यहां मूल बातें बताऊंगा।
वर्डप्रेस blog_id
मल्टीसाइट चीजों को व्यवस्थित रखने और अलग-अलग साइटों की फाइलों को अलग करने के लिए ("5" "/blogs.dir/" के बाद) फ़ाइलों को संग्रहीत करता है। यह निर्देशिका संरचना सार्वजनिक नहीं है। वर्डप्रेस रूट ^files/(.+)
करने के लिए फिर से लिखना नियमों का उपयोग करता है wp-includes/ms-files.php?file=$1
, और फिर wp-includes/ms-files.php
इमेज और / या कुछ सहायक हेडर को प्रोसेस और आउटपुट करता है। इसके कुछ फायदे हैं:
- सुरक्षा के संदर्भ में, कम जानकारी हमेशा बेहतर होती है। "wp-content / blogs.dir / 5" थोड़ा TMI है - यह कहता है कि आप वर्डप्रेस मल्टीसाइट चला रहे हैं और
blog_id
यह 5 है।
- URL संरचना एकल-साइट स्थापना के समान है। यदि आप कभी भी किसी साइट को मल्टीसाइट इंस्टॉलेशन से अपने आप में स्थानांतरित करना चाहते हैं, तो आपको डेटाबेस में उन संदर्भों को अपडेट नहीं करना होगा या बाहरी संदर्भों के लिए पुराने पथ 301 को अपडेट करना होगा।
- आप फ़ाइल निर्देशिका को सार्वजनिक पहुँच
deny from all
से बाहर ले जा सकते हैं या .htaccess
उदाहरण के लिए, यदि आप नहीं चाहते हैं, तो लोग मूल छवि आकारों तक नहीं पहुँच सकते।
- आप विशिष्ट फ़ाइलों तक पहुँच नियंत्रण जोड़ सकते हैं
एक मुख्य नुकसान है, जो यह है कि चित्र / फाइलें PHP से गुजर रही हैं (और शायद कुछ MySQL प्रश्नों की भी आवश्यकता होती है), इसलिए इसे अधिक संसाधनों की आवश्यकता होती है। यदि आपके पास कैशिंग प्लगइन स्थापित है, तो अतिरिक्त संसाधन नगण्य होने चाहिए।
फ़िल्टर के संबंध में, आप इस प्रक्रिया में किसी भी कारण से आसानी से फ़िल्टर नहीं कर सकते हैं: न ही म्यू-प्लग , प्लगइन्स, या आपका विषय लोड हो गया है *। सबसे अच्छा आप कर सकते हैं wp-config.php में स्थिरांक को ओवरराइड करते हैं। यहां सबसे उपयोगी / प्रासंगिक स्थिरांक हैं जिन्हें आप ओवरराइड कर सकते हैं:
if ( !defined( 'UPLOADBLOGSDIR' ) )
define( 'UPLOADBLOGSDIR', 'wp-content/blogs.dir' );
if ( !defined( 'UPLOADS' ) ) {
// Uploads dir relative to ABSPATH
define( 'UPLOADS', UPLOADBLOGSDIR . "/{$wpdb->blogid}/files/" );
if ( 'wp-content/blogs.dir' == UPLOADBLOGSDIR )
define( 'BLOGUPLOADDIR', WP_CONTENT_DIR . "/blogs.dir/{$wpdb->blogid}/files/" );
}
/**
* Optional support for X-Sendfile header
*/
if ( !defined( 'WPMU_SENDFILE' ) )
define( 'WPMU_SENDFILE', false );
/**
* Optional support for X-Accel-Redirect header
*/
if ( !defined( 'WPMU_ACCEL_REDIRECT' ) )
define( 'WPMU_ACCEL_REDIRECT', false );
* भले ही प्लगइन्स लोड न हों, ड्रॉप-इन करें। इसलिए, जब आप मानक प्लगइन्स का उपयोग नहीं कर सकते हैं, तो वर्डप्रेस अभी भी जो कुछ भी ज़रूरत है उसे करने के लिए नींव देता है, जैसे (जैसा कि ऊपर उल्लेख किया गया है) संवेदनशील फ़ाइलों तक पहुंच नियंत्रण को जोड़ना। ड्रॉप-इन sunrise.php
ऐसे कोड को जोड़ने के लिए एक अच्छी जगह होगी।