2012-10-09 10 views
11

urls.py में admin.autodiscover() डालने के बिना व्यवस्थापक पृष्ठ You don't have permission to edit anything (See SO thread) दिखाता है।व्यवस्थापक का उपयोग करते समय admin.autodiscover() को Django में स्वचालित रूप से क्यों नहीं कहा जाता है, इसे स्पष्ट रूप से क्यों कहा जा सकता था?

ऐसा क्यों है? यदि आपको हमेशा व्यवस्थापक के उपयोग से जानकारी संपादित करने के लिए admin.autodiscover() जोड़ने की आवश्यकता है, भले ही आपके पास सुरक्षा के लिए एक सुपरसियर नाम और पासवर्ड हो, तो Django डेवलपर्स स्वचालित रूप से admin.autodiscover() क्यों ट्रिगर नहीं करते?

उत्तर

11

:

मुझे लगता है कि आप बेहतर नियंत्रण देने के बारे में है (संपादन Django 1.7+ के बाद पुराना हो, जरूरी नहीं अधिक, Alasdair का जवाब देखें)। contrib.admin.autodiscover के कोड पर विचार करें:

def autodiscover(): 
    """ 
    Auto-discover INSTALLED_APPS admin.py modules and fail silently when 
    not present. This forces an import on them to register any admin bits they 
    may want. 
    """ 

    import copy 
    from django.conf import settings 
    from django.utils.importlib import import_module 
    from django.utils.module_loading import module_has_submodule 

    for app in settings.INSTALLED_APPS: 
     mod = import_module(app) 
     # Attempt to import the app's admin module. 
     try: 
      before_import_registry = copy.copy(site._registry) 
      import_module('%s.admin' % app) 
     except: 
      # Reset the model registry to the state before the last import as 
      # this import will have to reoccur on the next request and this 
      # could raise NotRegistered and AlreadyRegistered exceptions 
      # (see #8245). 
      site._registry = before_import_registry 

      # Decide whether to bubble up this error. If the app just 
      # doesn't have an admin module, we can ignore the error 
      # attempting to import it, otherwise we want it to bubble up. 
      if module_has_submodule(mod, 'admin'): 
       raise 

तो यह स्वचालित रूप से INSTALLED_APPS admin.py मॉड्यूल लोड और चुपचाप असफल जब नहीं मिला होगा।

# urls.py 
from django.conf.urls import patterns, url, include 
from myproject.admin import admin_site 

urlpatterns = patterns('', 
    (r'^myadmin/', include(admin_site.urls)), 
) 
इस मामले में

, आप autodiscovery() कॉल करने के लिए की जरूरत नहीं है: अब, ऐसे मामले हैं जब आप वास्तव में है कि इस तरह जब अपने खुद के AdminSite का उपयोग कर के रूप में नहीं करना चाहते हैं।

अन्य बार भी जब आप केवल व्यवस्थापक के माध्यम से अपनी परियोजनाओं के ऐप्स का सबसेट देखना या संपादित करना चाहते हैं, और autodiscovery() पर कॉल करने से आपको ऐसा करने में सक्षम नहीं होगा।

+0

मुझे समझ में नहीं आता कि इसे ऐप्स लोड करने की आवश्यकता क्यों है। क्या 'INSTALLED_APPS' में ऐप्स प्रत्येक बार' सेटिंग्स.py' निष्पादित नहीं होते हैं (उदा। सर्वर लॉन्च करते समय)? – Bentley4

+5

'autodiscover' ऐप्स लोड नहीं कर रहा है, यह प्रत्येक ऐप के लिए 'admin.py' आयात कर रहा है। – Alasdair

+0

@ बेंटले 4 हां जैसे अलास्डेयर ने कहा, यह केवल प्रत्येक ऐप के 'admin.py' को आयात कर रहा है। –

13

Django 1.7 से पहले, सिफारिश admin.autodiscover() urls.py में कॉल करना था। यदि आवश्यक हो तो इसे अक्षम करने की अनुमति दी गई। इसे स्वचालित रूप से कॉल करने के बजाय admin.autodiscover() की आवश्यकता है कार्रवाई में पाइथन दर्शन 'Explicit is better than implicit' का एक उदाहरण था। याद रखें, django.contrib.admin ऐप वैकल्पिक है, यह हर साइट पर स्थापित नहीं है, इसलिए यह हमेशा ऑटोडिस्कवर चलाने के लिए समझ में नहीं आता है।

अधिकांश समय ऑटोडिस्कवर काफी अच्छी तरह से काम करता है। हालांकि अगर आपको अधिक नियंत्रण की आवश्यकता है, तो आप इसके बजाय विशिष्ट ऐप्स की व्यवस्थापक फ़ाइलों को मैन्युअल रूप से आयात कर सकते हैं। उदाहरण के लिए, आप प्रत्येक में अलग-अलग ऐप्स के साथ multiple admin sites पंजीकृत करना चाहेंगे।

ऐप लोडिंग Django 1.7 में refactored थी। autodiscover() को व्यवस्थापक ऐप की डिफ़ॉल्ट ऐप कॉन्फ़िगरेशन में ले जाया गया था। इसका अर्थ यह है कि जब ऑटोडिस्कवर अब व्यवस्थापक एप लोड होता है तब चलता है, और admin.autodiscover() को आपके urls.py में जोड़ने की आवश्यकता नहीं है। यदि आप ऑटोोडिसवरी नहीं चाहते हैं, तो आप इसके बजाय SimpleAdminConfig का उपयोग करके इसे अक्षम कर सकते हैं।

+6

यह django 1.7 में बदल दिया गया था और अब ऑटोोडिस्कवर स्वचालित रूप से कॉल किया जाता है और इसे अक्षम किया जा सकता है। – simplylizz

3

Django आपको django का उपयोग करने की आवश्यकता नहीं है। contrib। हर साइट पर मैडमिन - यह कोर मॉड्यूल नहीं है।

संबंधित मुद्दे