摘要:選擇該頁面綁定的標(biāo)簽指定圖片上傳處理目錄注其中為了顯示為中文,標(biāo)明了中文,同時需要下載語言包放到對應(yīng)的文件夾下。
前言
我們常因?yàn)閐jango的自帶admin后臺功能而選擇該框架,但也因?yàn)槠渥詣由傻奶厥庑远谧龀鎏貏e的更改的時候束手束腳,鑒于項(xiàng)目已經(jīng)采用了django,而后臺要求能夠直接上傳富文本內(nèi)容直接用于網(wǎng)頁顯示,定制性高,后來翻了目前較為知名的幾款富文本編輯框,覺得還是tinymce符合能夠集成到django admin的簡便條件,但是tinymce免費(fèi)版不提供圖片本地上傳的服務(wù),所以只能自己找辦法集成圖片上傳到tinymce,以下記錄一遍說明過程。
創(chuàng)建滿足條件的django項(xiàng)目項(xiàng)目環(huán)境:
python2.7.13
django1.11.6
windows 10
該環(huán)境下創(chuàng)建了一個最初始的django項(xiàng)目,models.py中添加了一個用于測試的model,其中用于關(guān)聯(lián)富文本顯示的為TextField字段,代碼如下:
models.py
# -*-coding:utf-8 -*- from django.db import models # Create your models here. class TestTinymce(models.Model): title = models.CharField("標(biāo)題", max_length=20, default="") content = models.TextField("文本", default="") class Meta: db_table = "test_tinymce" verbose_name = "測試" verbose_name_plural = "測試" def __unicode__(self): return self.title
之后使用命令建表,使得項(xiàng)目能夠運(yùn)行起來,并添加django admin登錄用戶名密碼等,使得項(xiàng)目能夠進(jìn)入到后臺界面,并且在admin.py中注冊,使得我們添加的表格能夠在django admin中使用起來,進(jìn)入以下界面:
此時的添加測試數(shù)據(jù)頁面,TextField字段顯示為普通的文本域:
Tinymce處理tinymce官方下載為https://www.tinymce.com/downl...
下載其中的Download TinyMCE Community到本地解壓,取出其中的tinymce目錄,整個復(fù)制到django項(xiàng)目中你的靜態(tài)文件目錄,目前的文件目錄如下:
整合django admin和tinymce整合tinymce和django admin重要的是需要在django后臺加載的時候初始化tinymce的初始化函數(shù),按照指定的參數(shù)生成對應(yīng)的富文本框,我們通過admin.py來加載js到對應(yīng)的model處理界面:
admin.py
# -*-coding:utf-8 -*- from django.contrib import admin import models # Register your models here. class TestTinymce_Admin(admin.ModelAdmin): class Media: js = [ "/static/tinymce/js/jquery.min.js", # 必須首先加載的jquery,手動添加文件 "/static/tinymce/js/tinymce/tinymce.min.js", # tinymce自帶文件 "/static/tinymce/js/tinymce/plugins/jquery.form.js", # 手動添加文件 "/static/tinymce/js/tinymce/textarea.js", # 手動添加文件,用戶初始化參數(shù) ] admin.site.register(models.TestTinymce, TestTinymce_Admin)
其中jquery.min.js為普通的jquery文件,版本合適即可,tinymce.min.js為tinymce自帶文件,jquery.form.js為手動添加,是一個form插件,支持ajax表單提交和ajax文件上傳,textarea.js是我自定義的一個js,寫的初始化對應(yīng)的富文本的參數(shù),包含指定圖片上傳的指定處理路徑。
textarea.js
tinymce.init({ selector: "textarea", // 選擇該頁面綁定的標(biāo)簽 themes: "modern", menubar: false, convert_urls: false, height: 450, plugins: [ "advlist autolink lists link image charmap print preview hr anchor pagebreak", "searchreplace wordcount visualblocks visualchars code fullscreen", "insertdatetime media nonbreaking save table contextmenu directionality", "emoticons template paste textcolor colorpicker textpattern imagetools", "link imageupload" ], toolbar: "undo redo | imageupload link | bold italic | styleselect fontselect fontsizeselect | bullist numlist outdent indent | alignleft aligncenter alignright alignjustify | print preview media | forecolor backcolor emoticons", content_css: [ "http://fast.fonts.net/cssapi/e6dc9b99-64fe-4292-ad98-6974f93cd2a2.css", "http://www.tinymce.com/css/codepen.min.css" ], imageupload_url: "/upload_img/", // 指定圖片上傳處理目錄 language:"zh_CN" });
注:其中為了顯示為中文,標(biāo)明了中文zh_CN,同時需要下載語言包zh_CN.js放到對應(yīng)的langs文件夾下。此時,django admin中的文本域已經(jīng)被富文本框代替,我們此時只需要把對應(yīng)的圖片上傳整合:
整合上傳圖片功能到tinymce添加圖片上傳插件imageupload到plugins文件夾下,此時就符合了我們在textarea.js中toolbar參數(shù)中添加的imageupload,同時下載jquery.form.js在符合我們在admin.py加載的路徑放置:
此時我們可以看見在富文本框上指定位置出現(xiàn)了圖片上傳的按鈕,點(diǎn)擊出現(xiàn)上傳本地文件的按鈕:
在彈出按鈕出現(xiàn)之后,我們處理imageupload_url: "/upload_img/"上傳文件的路徑背后的視圖處理,根據(jù)django的映射規(guī)則,我們在urls.py添加路徑:
url(r"^upload_img/$", views.upload_img), # 后臺富文本框上傳圖片
添加views.py中的處理接收上傳的函數(shù)upload_img:
# -*-coding:utf-8 -*- from django.shortcuts import render from django.views.decorators.csrf import csrf_exempt import json import time from PIL import Image from django.conf import settings from django.http import HttpResponse # Create your views here. static_base = "http://127.0.0.1:8000" static_url = static_base + settings.MEDIA_URL # 上傳文件展示路徑前綴 # 上傳圖片 POST @csrf_exempt def upload_img(request): file = request.FILES["file"] data = { "error":True, "path":"", } if file: timenow = int(time.time()*1000) timenow = str(timenow) try: img = Image.open(file) img.save(settings.MEDIA_ROOT + "content/" + timenow + unicode(str(file))) except Exception,e: print e return HttpResponse(json.dumps(data), content_type="application/json") imgUrl = static_url + "content/" + timenow + str(file) data["error"] = False data["path"] = imgUrl return HttpResponse(json.dumps(data), content_type="application/json")
創(chuàng)建接收上傳的文件的文件夾,按照settings.py中的配置和指定的上傳文件目錄:
其中為了防止回顯的時候不識別media路徑,在urlpatterns中添加如下:
from django.conf.urls import url from django.contrib import admin from app import views from django.conf import settings from django.conf.urls.static import static urlpatterns = [ url(r"^upload_img/$", views.upload_img), # 后臺富文本框上傳圖片 url(r"^admin/", admin.site.urls), ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
目前功能已經(jīng)全部實(shí)現(xiàn),可以看見上傳圖片成功之后回顯:
順便附上settings.py中的上傳文件和靜態(tài)文件目錄的配置:
# Internationalization # https://docs.djangoproject.com/en/1.10/topics/i18n/ LANGUAGE_CODE = "zh-hans" TIME_ZONE = "Asia/Shanghai" USE_I18N = True USE_L10N = True USE_TZ = False # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/1.8/howto/static-files/ STATIC_URL = "/static/" # 當(dāng)運(yùn)行 python manage.py collectstatic 的時候 # STATIC_ROOT 文件夾 是用來將所有STATICFILES_DIRS中所有文件夾中的文件,以及各app中static中的文件都復(fù)制過來 # 把這些文件放到一起是為了用apache等部署的時候更方便 STATIC_ROOT = os.path.join(BASE_DIR, "collected_static") # 其它 存放靜態(tài)文件的文件夾,可以用來存放項(xiàng)目中公用的靜態(tài)文件,里面不能包含 STATIC_ROOT # 如果不想用 STATICFILES_DIRS 可以不用,都放在 app 里的 static 中也可以 STATICFILES_DIRS = ( os.path.join(BASE_DIR, "common_static"), ) # 這個是默認(rèn)設(shè)置,Django 默認(rèn)會在 STATICFILES_DIRS中的文件夾 和 各app下的static文件夾中找文件 # 注意有先后順序,找到了就不再繼續(xù)找了 STATICFILES_FINDERS = ( "django.contrib.staticfiles.finders.FileSystemFinder", "django.contrib.staticfiles.finders.AppDirectoriesFinder" ) ADMIN_MEDIA_PREFIX = STATIC_URL + "admin/" MEDIA_URL = "/media/" MEDIA_ROOT = BASE_DIR + "/media/upload/"
附上GITHUB上傳的源碼:https://github.com/Z-July/dja...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/41010.html
摘要:選擇該頁面綁定的標(biāo)簽指定圖片上傳處理目錄注其中為了顯示為中文,標(biāo)明了中文,同時需要下載語言包放到對應(yīng)的文件夾下。 前言 我們常因?yàn)閐jango的自帶admin后臺功能而選擇該框架,但也因?yàn)槠渥詣由傻奶厥庑远谧龀鎏貏e的更改的時候束手束腳,鑒于項(xiàng)目已經(jīng)采用了django,而后臺要求能夠直接上傳富文本內(nèi)容直接用于網(wǎng)頁顯示,定制性高,后來翻了目前較為知名的幾款富文本編輯框,覺得還是tiny...
摘要:選擇該頁面綁定的標(biāo)簽指定圖片上傳處理目錄注其中為了顯示為中文,標(biāo)明了中文,同時需要下載語言包放到對應(yīng)的文件夾下。 前言 我們常因?yàn)閐jango的自帶admin后臺功能而選擇該框架,但也因?yàn)槠渥詣由傻奶厥庑远谧龀鎏貏e的更改的時候束手束腳,鑒于項(xiàng)目已經(jīng)采用了django,而后臺要求能夠直接上傳富文本內(nèi)容直接用于網(wǎng)頁顯示,定制性高,后來翻了目前較為知名的幾款富文本編輯框,覺得還是tiny...
摘要:社區(qū)的認(rèn)可目前已經(jīng)是相關(guān)最多的開源項(xiàng)目了,體現(xiàn)出了社區(qū)對其的認(rèn)可。監(jiān)聽事件手動維護(hù)列表這樣我們就簡單的完成了拖拽排序。 完整項(xiàng)目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺 系列二(登錄權(quán)限篇)系類文章三:手摸手,帶你用vue擼后臺 系列三(實(shí)戰(zhàn)篇)系類文章四:手摸手,帶你用vue擼后臺 系列...
摘要:社區(qū)的認(rèn)可目前已經(jīng)是相關(guān)最多的開源項(xiàng)目了,體現(xiàn)出了社區(qū)對其的認(rèn)可。監(jiān)聽事件手動維護(hù)列表這樣我們就簡單的完成了拖拽排序。 完整項(xiàng)目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺 系列二(登錄權(quán)限篇)系類文章三:手摸手,帶你用vue擼后臺 系列三(實(shí)戰(zhàn)篇)系類文章四:手摸手,帶你用vue擼后臺 系列...
摘要:簡介是基于,搭配使用組件庫形成的一套后臺集成解決方案,由前端可視化團(tuán)隊(duì)部分成員開發(fā)維護(hù)。遵守設(shè)計(jì)和開發(fā)約定,風(fēng)格統(tǒng)一,設(shè)計(jì)考究,并且更多功能在不停開發(fā)中。 showImg(https://segmentfault.com/img/remote/1460000011603206); 簡介 iView Admin 是基于 Vue.js,搭配使用 iView UI 組件庫形成的一套后臺集成解...
閱讀 1199·2023-04-26 02:42
閱讀 1641·2021-11-12 10:36
閱讀 1804·2021-10-25 09:47
閱讀 1274·2021-08-18 10:22
閱讀 1815·2019-08-30 15:52
閱讀 1225·2019-08-30 10:54
閱讀 2642·2019-08-29 18:46
閱讀 3504·2019-08-26 18:27