Ich verwende für den größten Teil der Website einen benutzerdefinierten WYSIWYG -Editor, daher ist er nicht so fortgeschritten, wie ich es gerne hätte. Aber zum Schreiben von Artikeln auf der Website wird CKEditor verwendet, ein sehr leistungsfähiger und guter Editor. Die Nuance ist, dass das Schreiben von Artikeln allen registrierten Benutzern der Website zur Verfügung steht. Aber standardmäßig erlaubt CKEditor nur Benutzern mit Mitarbeiterstatus, Bilder hochzuladen.
Für alle anderen Benutzer öffnet sich anstelle eines Dateimanagers entweder eine Fehlerseite oder die Hauptseite der Site, um nach Bildern oder einem hochgeladenen Bild zu suchen.
Ich habe die Dokumentation ein wenig durchgesehen und konnte dieses Problem beheben. Und ehrlich gesagt sieht die Lösung ziemlich seltsam aus, obwohl sie in der offiziellen Dokumentation für die Redaktion angeboten wird.
Die Quintessenz ist, dass normalerweise für das Bildlademodul URLs wie folgt verbunden sind.
urlpatterns = [ url(r'^ckeditor/', include('ckeditor_uploader.urls')), ]
Und wenn Sie in die Quellen von ckeditor schauen, können Sie Folgendes sehen
urlpatterns = patterns( '', url(r'^upload/', staff_member_required(views.upload), name='ckeditor_upload'), url(r'^browse/', never_cache(staff_member_required(views.browse)), name='ckeditor_browse'), )
Wie Sie bereits verstanden haben, schränkt die Funktion staff_member_required den Benutzerzugriff auf diese Funktionalität ein. Das heißt, nur Mitarbeiter können Bilder hochladen und über den Dateibrowser auf der Website nach Bildern suchen.
Und was bietet uns die offizielle Dokumentation statt einer Art Einstellungskennzeichen?
Das ist richtig, schreiben Sie die Pfade zu den Ansichten direkt auf, dh auf diese Weise.
urlpatterns = [ url(r'^upload/', login_required(upload), name='ckeditor_upload'), url(r'^browse/', login_required(never_cache(browse)), name='ckeditor_browse'), ]
Das heißt, wir werfen staff_member_required weg und ersetzen es durch login_required, um allen Benutzern der Website Zugriff zu gewähren, mit Ausnahme von nicht autorisierten.
Meiner Meinung nach eine ziemlich seltsame Entscheidung, wenn dies über eine Variable in den Einstellungen erfolgen könnte. Es ist ein wenig umständlich und unlogisch.
Für Django empfehle ich Timeweb-Hoster VDS-Server .
Ай малаца! Спасибо))
Здравстсвуйте Евгений, непонятно мне где эти исходники найти?
Добрый день.
На GitHub исходники, можете посмотреть в официальном репозитории
Спасибо!!!