django中tinymce添加图片上传功能

 

主要参考以下:

https://pixabay.com/en/blog/posts/direct-image-uploads-in-tinymce-4-42/

http://blog.csdn.net/tianlanzhixie/article/details/50240071

 

这里还有个用php使用的,可以参考http://zhaoda.net/tinymce-upload/example.html

 

大体思路就是

添加js的一个函数,这个是tinymec自带的

file_picker_callback: function(callback, value, meta) {
                if(meta.filetype=='image') {
                    console.log('ddd');
                    $('#my_form input').click();
                }
            }

  

然后添加html中的上传按钮

 <iframe id="form_target" name="form_target" style="display:none"></iframe>
        <form id="my_form" action="{% url 'blog.views.upload' %}" target="form_target" method="post" enctype="multipart/form-data" style="width:0px;height:0;overflow:hidden">{% csrf_token %}
            <input name="image" type="file" οnchange="$('#my_form').submit();this.value='';">
        </form>

  

然后去django中添加上传的函数,就是url到view的那一套

def upload(request):
    try:
        file = request.FILES['image']
        #form提交的文件的名字,上面html里面的name
        img = Image.open(file)
        img.thumbnail((500, 500), Image.ANTIALIAS)
        img.save('static/upload/images/'+file.name, img.format)
        #图片的name和format都是动态获取的,支持png,jpeg,gif等
    except Exception as e:
        return HttpResponse('error %s' % e)
    path = '/site_media/'+file.name
    return HttpResponse("<script>top.$('.mce-btn.mce-open').parent().find('.mce-textbox').val('%s').closest('.mce-window').find('.mce-primary').click();</script>" % path)

  

注意这里的site_media是固定的哟,

static/upload/images/才是自己放代码的路径
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值