javascript - 将 CKeditor 集成到 Flask 时 CSRF 验证失败

标签 javascript python flask ckeditor csrf

我正在将 CKeditor 集成到 Flask 以添加富文本支持。但是当开启文件上传功能后,post请求总是失败。应该是csrf的问题。直接添加 {{csrf_token()} 不起作用。 CKeditor中有什么地方需要修改来添加csrf吗?

{% block content %}
<h1>Add articile:</h1>
<form>
    <input type="hidden" name="csrf_token" value="{{csrf_token()}}" />
    <textarea name="editor1" id="editor1" rows="20" cols="80">
                This is my textarea to be replaced with CKEditor.
    </textarea>
<script type="text/javascript">
CKEDITOR.replace('editor1', {
    filebrowserUploadUrl: '/ckupload',
});
</script>
</form>
{% endblock %}

处理文件上传,

def gen_rnd_filename():
    filename_prefix = datetime.datetime.now().strftime('%Y%m%d%H%M%S')
    return '%s%s' % (filename_prefix, str(random.randrange(1000, 10000)))

@app.route('/ckupload', methods=['POST', 'OPTIONS'])
def ckupload():
    """CKEditor file upload"""
    error = ''
    url = ''
    callback = request.args.get("CKEditorFuncNum")
    print callback
    print request.method
    if request.method == 'POST' and 'upload' in request.files:
        fileobj = request.files['upload']
        fname, fext = os.path.splitext(fileobj.filename)
        rnd_name = '%s%s' % (gen_rnd_filename(), fext)
        filepath = os.path.join(app.static_folder, 'upload', rnd_name)
        dirname = os.path.dirname(filepath)
        if not os.path.exists(dirname):
            try:
                os.makedirs(dirname)
            except:
                error = 'ERROR_CREATE_DIR'
        elif not os.access(dirname, os.W_OK):
            error = 'ERROR_DIR_NOT_WRITEABLE'
        if not error:
            fileobj.save(filepath)
            url = url_for('static', filename='%s/%s' % ('upload', rnd_name))
    else:
        error = 'post error'
    res = """<script type="text/javascript">
  window.parent.CKEDITOR.tools.callFunction(%s, '%s', '%s');
</script>""" % (callback, url, error)
    response = make_response(res)
    response.headers["Content-Type"] = "text/html"
    return response

最佳答案

当前我的解决方法是向此网址添加 csrf 异常(exception)。

@csrf.exempt

关于javascript - 将 CKeditor 集成到 Flask 时 CSRF 验证失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29721223/

相关文章:

javascript - 如何清除 Canvas ?

python - django 应用程序媒体文件夹中的 css 文件出现 404 错误

mysql - 如何将模型迁移到 Flask 上的 Mysql 数据库

javascript - 函数以错误的顺序执行

JavaScript 函数对象

Python/wxPython : Doing work continuously in the background

python - 有没有办法使用 python4delphi 组件调试 python 脚本?

python - 使 Flask 中的旧 session 无效

python - 如果我使用 fbone 如何运行 celery?

javascript - 更改 url 位置的最佳方法