V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
forreal
V2EX  ›  Python

请教个关于 flask-wtf 的问题

  •  
  •   forreal · 2014-07-11 20:40:57 +08:00 · 6115 次点击
    这是一个创建于 3786 天前的主题,其中的信息可能已经有所发展或是发生改变。
    第一个是页面添加了{{ csrf_token() }},并且post给后端后,将这个token和服务器端的token比对,但是服务器端的token如何获取呢?也是csrf_token()吗?我还看到api里有一个generate_csrf()。是用generate_csr函数获取服务器端token吗?还是用api里的另一个函数validate_csrf()来验证token?

    第二个问题是 RecaptchaField是验证码吗?我试了一下没有验证码图片啊。是我理解错了吗?
    顺便求一个flask验证码的扩展。

    在此多谢各位的回答
    9 条回复    2014-07-21 22:04:50 +08:00
    casparchen
        1
    casparchen  
       2014-07-11 21:09:11 +08:00
    session['csrf_token']
    casparchen
        2
    casparchen  
       2014-07-11 21:13:08 +08:00   ❤️ 1
    另外, 如果你用flask-WTF的话,是用不着你自己去做这个验证的吧
    forreal
        3
    forreal  
    OP
       2014-07-11 23:51:41 +08:00 via iPhone
    @casparchen 只想用csrf保护,其它表单想自己写
    xxr3376
        4
    xxr3376  
       2014-07-11 23:58:54 +08:00   ❤️ 1
    @forreal RecaptchaField是用的Google的reCaptcha服务,现在在国内很有可能被墙了所以没法用。以及你需要去reCaptcha申请一个公私钥才能用。
    bcxx
        5
    bcxx  
       2014-07-12 00:06:30 +08:00   ❤️ 1
    @forreal 那你不能直接自己实现一个 csrf 么?为啥还要用 flask-wtf(不是看中 wtforms 么?

    顺便帮你 @lepture 他是现在的维护者
    tokki
        6
    tokki  
       2014-07-12 00:15:01 +08:00   ❤️ 1
    其实wtf的作用就是高效率,如果你要自己去控制csrf,自己去做验证码,用wtf的意义已经减半了
    自己实现一个csrf也很简单,flask官方就有一个例子,自己搜下啦
    forreal
        7
    forreal  
    OP
       2014-07-12 00:17:15 +08:00 via iPhone
    @xxr3376 原来如此
    forreal
        8
    forreal  
    OP
       2014-07-12 00:19:47 +08:00 via iPhone
    @bcxx
    @tokki
    也对哈,刚接触flask,看到有个教程用的wtf。
    lepture
        9
    lepture  
       2014-07-21 22:04:50 +08:00
    csrf and forms should be together.
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5257 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 08:53 · PVG 16:53 · LAX 00:53 · JFK 03:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.