关于前后端分离的项目,如何使用验证码进行机器人验证 - V2EX
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
wongyusing
V2EX    Python

关于前后端分离的项目,如何使用验证码进行机器人验证

  •  
  •   wongyusing 2019 年 7 月 6 日 5817 次点击
    这是一个创建于 2380 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我现在在做一个电商网站项目。
    后端使用了,django-rest-framework 作为 api。 前端使用 angular-cli

    在关于注册这里遇到了一个问题。
    为了防止机器人恶意注册,我想调用验证码来防止机器人。
    前端中 angular-cli 接入了谷歌的 recaptcha。已经实现了。
    但是,后端该怎么实现呢?? 我阅读了阅读了谷歌的 recaptcha 的文档还是没有找到方法。

    12 条回复    2019-07-06 22:52:37 +08:00
    wongyusing
        1
    wongyusing  
    OP
       2019 年 7 月 6 日
    我这里用的是 recaptcha V2 中的隐藏徽章类型。
    前端验证完成后,生成一段秘文 response。
    然后会连同 username,passwork、email 和 response 一起作为验证。
    现在问题主要是后端的该怎么处理。


    其实,撇开这个 recaptcha,我还有两种思路去处理这个**注册验证码问题**

    ## 自行生成验证码
    新建一个 captcha 表,
    里面给五个字段
    分别为:索引 ID、验证码答案、验证码图片地址、秘文 ,创建时间
    利用 python 验证码包生成一堆验证码图片,并存入数据库。
    用户访问时随机抽取一张验证码图片进行验证等操作。
    通过秘文来索引确认用户的验证是否正确。
    但是,这个思路缺陷很明显,我用之前练习**识别验证码的小 demo**都可以识别出这个验证码。
    所以,放弃。

    ## 通过邮箱发送验证码进行验证
    这个还是很好做的。
    不过用户体验很不好。
    binux
        2
    binux  
       2019 年 7 月 6 日   1
    zhwithsweet
        3
    zhwithsweet  
       2019 年 7 月 6 日 via iPhone   1
    有接口,后端拿到 authcode 去验证一下;还可以使用 accountkit
    Destiny97
        4
    Destiny97  
       2019 年 7 月 6 日 via Android
    我用过腾讯防水墙,免费的,效果还不错,楼主可以试试
    wongyusing
        5
    wongyusing  
    OP
       2019 年 7 月 6 日
    搞定了,
    Y 的,搞到我写了那么久。
    原来是 443 的原因。
    是"墙"的原因导致的错误
    wongyusing
        6
    wongyusing  
    OP
       2019 年 7 月 6 日
    @Destiny97 这个项目是我接了加拿大的外包项目。
    尽量不用国内的服务。
    已经解决问题了。
    wongyusing
        7
    wongyusing  
    OP
       2019 年 7 月 6 日
    怎么设置问题已解决啊??
    第一次提问。
    xuanbg
        8
    xuanbg  
       2019 年 7 月 6 日
    防止恶意注册最有效的办法就是用短信验证码验证手机号,一个手机号只能注册一次就完了。
    mmtromsb456
        9
    mmtromsb456  
       2019 年 7 月 6 日 via iPhone
    @wongyusing append 附言即可
    Jirajine
        10
    Jirajine  
       2019 年 7 月 6 日 via Android
    @xuanbg 那是你天朝特色吧。
    国外要手机号的服务不多,强行要手机号很大可能劝退用户。
    不是每个国家的用户都习惯了被实名制和微信强 J 的。
    wongyusing
        11
    wongyusing  
    OP
       2019 年 7 月 6 日
    @mmtromsb456 多谢。
    wongyusing
        12
    wongyusing  
    OP
       2019 年 7 月 6 日
    下面是我解决问题的写法,
    主要原因是由于一开始没有设置全局的科学网络导致的 443 错误。
    https://github.com/wongjyusing/v2ex/blob/master/test.md
    等我完成手头上的两个项目后。
    会将整个过程写成博文放到我的博客上。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2727 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 663ms UTC 03:47 PVG 11:47 LAX 19:47 JFK 22:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86