2018-06-13 django的admin中使用KindEditor富文本编辑器

由于django后台管理没有富文本编辑器,展示出来的页面不美观,所以我们想要引入第三方富文本编辑器。网上搜寻了一番,但还是有些问题,不能完全适用,自己就把遇到的问题总结一下吧。

一开始没有想到用哪种,同事说kindeditor吧,那我就好吧,就直接用这个吧,我是有多懒-_-||

文本编辑器。之所以选择这个编辑器主要看是它功能齐全还美观。下面这张图是kindeditor的样子,没错功能就是这么多,外观就是这么好看。

本地环境是Anaconda3的Python3环境,为了项目昨天搭建了Python2的环境+django,所以整个环境是Python2.7.15+django1.11.10+Pycharm2018.1.3

好了开始我们的django 使用kindeditor之路。

第一步,到官网下载kindeditor 

第二步,下载到本地后,删除无用项

第三步,把剩余文件引入到项目中去

django中配置

 第一步:在setting.py中配置静态文件上传目录,编辑器中上传的文件将保存在这里。

STATIC_URL = '/static/'

STATIC_URL = '/static/' STATICFILES_DIRS = ( os.path.join(BASE_DIR, 'static'), )


 第二步:在项目的urls.py配置文件中配置

url(r'^uploads/(?P.*)$', serve, {'document_root': settings.MEDIA_ROOT, }),

出错的地方也是这里,网上找的资料是下面这种写法,但是在我的环境中会报错,报TypeError: view must be a callable or a list/tuple in the case of include().

url(r'^uploads/(?P.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT, }),

后来查了半天才发现,django1.10不再支持 url(r'^uploads/(?P.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT, }),这种用法了

第三步:在自己的应用中的view.py中加入下面的代码(ps:这段代码我是网上找的)

from django.http import HttpResponse

from django.conf import settings

from django.views.decorators.csrf import csrf_exempt

import os

import uuid

import json

import datetime as dt

@csrf_exempt

def upload_image(request, dir_name):

    result = {"error": 1, "message": "上传出错"}

    files = request.FILES.get("imgFile", None)

    if files:

        result = image_upload(files, dir_name)

    return HttpResponse(json.dumps(result), content_type="application/json")

# 目录创建

def upload_generation_dir(dir_name):

    today = dt.datetime.today()

    dir_name = dir_name + '/%d/%d/' % (today.year, today.month)

    if not os.path.exists(settings.MEDIA_ROOT + dir_name):

        os.makedirs(settings.MEDIA_ROOT + dir_name)

    return dir_name

# 图片上传

def image_upload(files, dir_name):

    # 允许上传文件类型

    allow_suffix = ['jpg', 'png', 'jpeg', 'gif',

                    'bmp', 'zip', "swf", "flv",

                    "mp3", "wav", "wma", "wmv",

                    "mid", "avi", "mpg", "asf",

                    "rm", "rmvb", "doc", "docx",

                    "xls", "xlsx", "ppt", "htm",

                    "html", "txt", "zip", "rar",

                    "gz", "bz2"]

    file_suffix = files.name.split(".")[-1]

    if file_suffix not in allow_suffix:

        return {"error": 1, "message": "图片格式不正确"}

    relative_path_file = upload_generation_dir(dir_name)

    path = os.path.join(settings.MEDIA_ROOT, relative_path_file)

    if not os.path.exists(path):  # 如果目录不存在创建目录

        os.makedirs(path)

    file_name = str(uuid.uuid1()) + "." + file_suffix

    path_file = os.path.join(path, file_name)

    file_url = settings.MEDIA_URL + relative_path_file + file_name

    open(path_file, 'wb').write(files.file.read())

    return {"error": 0, "url": file_url}


第四步:配置应用中的url

from app.viewsimport upload_image

urlpatterns = [

url(r'^upload/(?P[^/]+)$', upload_image, name='upload_image'),

]

第五步,在kindeditor-4.1.11文件下新建一个config文件

KindEditor.ready(function (k) {

window.editor = k.create('#id_profile',{

resizeType:1,

        allowPreviewEmoticons :false,

        allowImageRemote :false,

        uploadJson :'/upload/kindeditor',

        width:'800px',

        height:'400px',

    });

})

这边的“id_profile”是我需要把text变成富文本的元素的id,根据你的需要来填写,例如后面我换了个元素,这个id值也变了

网上有建议将settings.py中间件的crsf注释掉,说是有可能post请求会报错,目前mei没发现问题,后面若发现问题,我就把它注释掉。

第六步,去admin.py中注册模型类。将其kindeditor的js文件引入到admin中

导入模型类,这里我的模型类是UserInfo ,这个按照自己的模型类修改就可以了。原来的# admin.site.register(UserInfo) 这样的注册方法直接注释掉

from django.contrib import admin

@admin.register(UserInfo)

class UserInfoAdmin(admin.ModelAdmin):

# list_display = ['title']

    class Media:

def __init__(self):

pass

        js = (

'/static/js/kindeditor-4.1.11/kindeditor-all.js',

            '/static/js/kindeditor-4.1.11/lang/zh_CN.js',

            '/static/js/kindeditor-4.1.11/config.js',

        )

这边网上的资料看到的都会list_display = ['title']或者list_display = ('title'),但是我都试过,都会报错,所以只好注释掉

因为不需要写页面,所以没写js文件,也没有jsp文件引用,不同字段引用,只能用不同的config,但如果一个Model中有多个字段要运用的,要怎么弄,暂时没想好[・_・?]

我的模型类是这个,富文本编辑器是用在profile这个字段上。

最后,起一下服务看一下效果

可以加图片和表情,成功\(^o^)/

每个人的环境啊多种因素,会导致代码的不通用,所以每个人还是根据自己的情况进行变通吧^_^

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容