2012-10-09 6 views
11

Ohne admin.autodiscover() in urls.py die Admin-Seite zeigt You don't have permission to edit anything (See SO thread).Warum wird admin.autodiscover() nicht automatisch in Django aufgerufen, wenn der Admin verwendet wird, warum sollte er explizit aufgerufen werden?

Warum ist das so? Wenn Sie immer admin.autodiscover() hinzufügen müssen, um Informationen mit dem Admin zu bearbeiten, obwohl Sie einen Superusernamen und ein Passwort für die Sicherheit haben, warum haben die Django-Entwickler nicht automatisch admin.autodiscover() ausgelöst ?.

Antwort

11

(edit: Obsoleted nach Django 1.7+, nicht notwendig, mehr finden Sie Alasdair Antwort)

Ich denke, es geht um Sie feinere Kontrolle. Betrachten Sie den Code von 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 

So ist es automatisch die INSTALLED_APPS admin.py Module geladen werden kann und unbemerkt fehlschlagen, wenn sie nicht gefunden. Nun gibt es Fälle, wenn Sie tatsächlich wollen nicht, dass, wie wenn die eigene Verwendung AdminSite:

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

urlpatterns = patterns('', 
    (r'^myadmin/', include(admin_site.urls)), 
) 

in diesem Fall Sie nicht autodiscovery() anrufen müssen.

Es gibt auch andere Zeiten, wenn Sie nur eine Teilmenge der Apps Ihrer Projekte über Admin sehen oder bearbeiten möchten, und das Aufrufen von autodiscovery() würde dies nicht ermöglichen.

+0

Ich verstehe nicht, warum es Apps laden muss. Werden nicht jedes Mal Anwendungen in 'INSTALLED_APPS' geladen, wenn 'settings.py' ausgeführt wird (z. B. beim Starten des Servers)? – Bentley4

+5

'autodiscover' lädt die Apps nicht, es wird' admin.py' für jede App importiert. – Alasdair

+0

@ Bentley4 Ja wie Alasdair sagte, es importiert nur das 'admin.py' von jeder App. –

13

Vor Django 1.7 war die Empfehlung, den Aufruf admin.autodiscover() in urls.py zu setzen. Dadurch konnte es bei Bedarf deaktiviert werden. Requiring admin.autodiscover(), anstatt es automatisch aufzurufen, war ein Beispiel für die Python-Philosophie 'Explicit is better than implicit' in Aktion. Denken Sie daran, dass die App django.contrib.admin optional ist, sie ist nicht auf jeder Site installiert, daher wäre es nicht sinnvoll, die AutoErmittlung immer auszuführen.

Die meiste Zeit funktioniert AutoErmittlung gut genug. Wenn Sie jedoch mehr Kontrolle benötigen, können Sie stattdessen die Admin-Dateien bestimmter Apps manuell importieren. Zum Beispiel möchten Sie vielleicht multiple admin sites mit verschiedenen Apps in jedem registrieren.

App laden war auf refactored in Django 1.7. Die autodiscover() wurde in die Standard-App-Konfiguration der Admin-App verschoben. Das bedeutet, dass die AutoErmittlung jetzt ausgeführt wird, wenn die Admin-App geladen wird. Sie müssen admin.autodiscover() nicht zu Ihrer URLs.py hinzufügen. Wenn Sie keine automatische Erkennung wünschen, können Sie sie jetzt deaktivieren, indem Sie stattdessen SimpleAdminConfig verwenden.

+6

Dies wurde in Django 1.7 geändert und jetzt AutoErmittlung wird automatisch aufgerufen und könnte deaktiviert werden. – simplylizz

3

Django erfordert keine Verwendung von Django. contrib .Admin auf jeder Website - es ist kein Kernmodul.

Verwandte Themen