Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >合法用户如何在Rails中提交无效的CSRF令牌?

合法用户如何在Rails中提交无效的CSRF令牌?
EN

Stack Overflow用户
提问于 2017-01-05 02:26:54
回答 5查看 2.5K关注 0票数 10

我们的错误日志偶尔包含导致ActionController::InvalidAuthenticityToken错误的合法表单提交。

我的假设是,存储在用户会话cookie中的CSRF令牌在加载表单之后但在提交之前已经发生了更改。这会导致POSTed令牌与cookie中的令牌不匹配,从而导致此错误。

如果Rails会话cookie仅在浏览会话结束时(即当web浏览器关闭时)到期,那么在不关闭浏览器的情况下,如何更改此cookie (及其包含的CSRF令牌)?

我们使用cookie来存储会话数据,这是Rails的默认行为。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2017-01-17 14:20:06

以下是我们所知道的:

  • 导致InvalidAuthenticityToken异常的合法表单提交以某种方式丢失了原始的CSRF令牌。
  • 令牌保存在会话中,会话保存在加密的cookie中。因此,此错误意味着自表单生成以来,它们的会话cookie已经发生了更改。
  • 除非用户的浏览器窗口关闭,否则会话cookie不会过期。

我现在认为,合法用户可以提交无效的CSRF令牌的方式有两种。

请注意,这些方法特别适用于Rails 4.2。据我所知,Rails 5中的“每种形式的CSRF令牌”功能可能会减轻它们的影响。

1.另一个选项卡中的会话更改

根据@crazymykl的回答,用户可以打开表单,然后在另一个选项卡中注销。这将导致存储在用户浏览器中的会话cookie发生更改。当它们返回到原始选项卡并提交表单时,来自表单的令牌将与会话中的令牌不匹配,并且会弹出错误。

2.缓存

根据这个rails错误,在某些情况下,Safari的缓存行为很奇怪。告诉它使用与上次相同的窗口重新打开(通过Safari > Preferences > General),打开表单和退出Safari将导致表单被重新显示。

提交缓存的表单会导致CSRF错误。当bug的开场白结束时,Safari似乎缓存了页面,但删除了会话cookie。因此出现了错配。

这个问题的解决方案是使用指令Cache-Control设置一个no-store头。( no-cacheno-store的差异解释了这里)。

欢迎更多的例子:)。

票数 5
EN

Stack Overflow用户

发布于 2017-01-10 10:46:10

用户可以注销并重新登录,但是有一个选项卡,其中有一个从旧会话打开的表单。那会送出旧的记号。

票数 9
EN

Stack Overflow用户

发布于 2017-01-17 04:29:53

您是否使用Ajax表单来提交请求?您的页面有多个表单吗?如果是,请检查您的代码是否与请求一起提交了正确的csrf令牌。我们有类似的问题,页面是用一个csrf令牌呈现的,我们使用这个令牌来提交一个表单,我们本来可以得到另一个csrf令牌,但是第二个是发送导致错误的旧csrf令牌。我不知道这有什么帮助,但想和大家分享我面临的类似问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41482561

复制
相关文章
iOS APP添加桌面快捷方式
新接到一个需求,需要APP内的某些功能,能够把入口添加到桌面,点击桌面到入口可以直接跳转APP对应界面(类似于下面这张示例图),于是就做了一番调研。
莫空9081
2021/06/08
5.4K0
iOS APP添加桌面快捷方式
2)客户端通过OpenUrl调起Safari,再二次跳转到data url 技术实现方案是首先通过调起Safari,然后跳到一个Data URI Scheme形式下的HTML页面,而添加到主屏幕的也是这个Data URI Scheme形式下的HTML页面。 OpenUrl调起Safari的实现为: [[UIApplicationsharedApplication] openURL:[NSURL URLWithString:@"http:www.xxx.com"]]; 通过该方法即可调起Safari,让Safari访问附带的URL链接,在该功能实现中,URL链接指向一个Data URI Scheme形式下的HTML页面。如下图所示:
用户5521279
2019/06/03
7.4K3
如何向图形添加曲形文本
R语言数据分析指南
2023/08/18
2190
如何向图形添加曲形文本
如何向数组里添加元素
一般数组是不能添加元素的,因为数组在初始化时就已定好长度了,不能改变长度,我们如何做到向其中添加元素。
算法与编程之美
2023/01/03
3.5K0
kali添加桌面快捷方式
终端输入:sudo gedit /usr/share/applications/Pycharm.desktop 粘贴模板: [Desktop Entry] Type=Application Name=Pycharm GenericName=Pycharm3 Comment=Pycharm3:The Python IDE Exec=sh /opt/pycharm/bin/pycharm.sh Icon=/opt/pycharm/bin/pycharm.png Terminal=pycharm Categor
昨天50还没用完
2018/06/29
2.3K0
java如何向数组中添加元素[数组的添加]
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说java如何向数组中添加元素[数组的添加],希望能够帮助大家进步!!!
Java架构师必看
2022/04/06
7.7K0
java如何向数组里添加元素
1、一般数组是不能添加元素的,因为他们在初始化时就已定好长度了,不能改变长度。 但有个可以改变大小的数组为ArrayList,即可以定义一个ArrayList数组,然后用add(element)方法往里添加元素即可,还可add(index,element)往指定下标处添加元素;例子如下:
全栈程序员站长
2022/06/27
20.6K0
Windows中的键盘快捷方式大全
Windows有很多键盘快捷方式,使用键盘快捷方式能够大大提高使用windows的效率,同时还能提升自己的逼格,背熟几个快捷方式,操作起来行云流水犹如大神一般!
用户7657330
2020/08/14
5.7K0
如何向已有的项目中添加C/C++代码?
  我们需要在src/main下面建立一个cpp目录,然后在其中写一个CMakeLists.txt文件和一个cpp文件,直接给出代码:
故乡的樱花开了
2023/10/22
2930
给App的应用页面注册快捷方式
元数据不单单能传递简单的字符串参数,还能传送更复杂的资源数据,从Android7.1开始新增的快捷方式便用到了这点,譬如在手机上桌面长按支付宝图标,会弹出如下图所示的菜单。
aqi00
2020/05/12
9680
Python 中如何向列表或数组添加元素
然而,与其它编程语言不同,数组在 Python 中不是一个内置的数据结构。Python 使用列表取代传统的数组。
Python学习者
2023/09/11
3600
向邮件添加附件
可以将附件添加到电子邮件或消息部分(具体地说,是添加到%Net.MailMessagePart或%Net.MailMessage的实例)。要执行此操作,请使用以下方法:
用户7741497
2022/06/09
2.1K0
如何从Windows切换到Linux
微软已经马上准备在2020年1月份终止对Windows 7的支持,这意味着您将不再获得bug修复或安全更新。如果您是Windows 7的最终支持者之一,并且不想陷入一个不安全的系统,则可以选择:升级到Windows 10或完全切换到其他版本。
用户6543014
2020/02/10
3.9K0
如何添加windows定时计划任务?
“ 我们常常使用linux添加定时任务,windows也可以吗?答案是肯定的——编程三分钟”
机智的程序员小熊
2019/12/11
1.7K0
Windows如何添加TrustedInstaller权限
权限添加,一同加的Administrator、Users、TrustedInstaller(英文分号隔开)然后点检索名称,Administrator和Users都能找到,唯独TrustedInstaller不行
Windows技术交流
2020/04/08
4.1K0
如何使用 Bootstrap class 向按钮添加下拉菜单
如何使用 Bootstrap class 向按钮添加下拉菜单。如需向按钮添加下拉菜单,只需要简单地在一个 .btn-group 容器中放置按钮和下拉菜单即可。您也可以使用 <span class="caret"></span> 来指示按钮作为下拉菜单。
好派笔记
2021/09/18
5.6K0
短视频app源码开发,如何添加启动界面
打开短视频app源码时,一般都会有一个启动界面,启动界面除了会展示APP的logo外,大多数都会将广告直接放到上面,起到引流盈利的目的。
云豹科技程序员
2021/06/21
6700
点击加载更多

相似问题

如何向windows快捷方式添加命令参数

124

如何向App添加社交功能?

43

Android:如何向App添加阴影

13

如何从azure向windows mobile cordova app发送推送通知

112

向APp添加项

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文