- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下处理程序,用于检查给定处理程序的授权:
needsAuth :: Handler App (AuthManager App) () -> Handler App App ()
needsAuth x = with auth $ requireUser auth noUserHandler x
where noUserHandler = handleLogin (Just "must be logged in")
在Site.h
我这样指定一条路线:("/transfers", needsAuth handleTransfers)
其中 handleTransfers 的签名是 handleTransfers :: Handler App (AuthManager App) ()
.
我的应用程序中只有少数处理程序具有用户提交的表单;我想对它们使用 CSRF 检查,虽然用 CSRF 检查处理程序包装授权处理程序会很方便,所以我可以将路由更改为如下所示:
("/test", handleCSRF $ needsAuth handleTest)
基于 snap-extras 包中的想法,我创建了函数 handleCSRF:
handleCSRF :: Handler b v () -> Handler b v ()
handleCSRF x = do
m <- getsRequest rqMethod
if m /= POST
then x
else do tok <- getParam "_csrf"
s <- gets session
realTok <- withSession s csrfToken
if tok == Just (E.encodeUtf8 realTok)
then x
else writeText $ "CSRF error"
编译错误为:
Couldn't match type `SessionManager' with `AuthManager b'
When using functional dependencies to combine
MonadState v (Handler b v),
arising from the dependency `m -> s'
in the instance declaration in `snap-0.13.2.5:Snap.Snaplet.Internal.Type s'
MonadState (AuthManager b) (Handler b SessionManager),
arising from a use of `gets' at src\Site.hs:106:20-23
In a stmt of a 'do' block: s <- gets session
In the expression:
do { tok <- getParam "_csrf";
s <- gets session;
realTok <- withSession s csrfToken;
if tok == Just (E.encodeUtf8 realTok) then
x
else
writeText $ "CSRF error" }
我尝试了多种不同的变体,但出现了不同种类的编译错误……我的方向是否正确?这是 Snap 中的正确方法吗?
编辑:这里有一些附加信息:
data App = App
{ _heist :: Snaplet (Heist App)
, _sess :: Snaplet SessionManager
, _auth :: Snaplet (AuthManager App)
, _wmConfig :: WMConfig
}
makeLenses ''App
我正在像这样初始化 session snaplet:
s <- nestSnaplet "sess" sess $
initCookieSessionManager "site_key.txt" "sess" (Just 1200)
EDIT #2/Solution... @mightybyte 通过 IRC 给了我解决方案,用 realTok <- withSession sess (with sess csrfToken)
替换 realTok 行, 有效。
提前致谢,尼尔
最佳答案
试试这个:
handleCSRF :: Handler App App () -> Handler App App ()
handleCSRF x = do
m <- getsRequest rqMethod
if m /= POST
then x
else do tok <- getParam "_csrf"
realTok <- withSession sess csrfToken
if tok == Just (E.encodeUtf8 realTok)
then x
else writeText $ "CSRF error"
withSession的第一个参数应该是一个镜头,而不是 SessionManager 本身。
关于haskell - 快照 : wrapping auth handler with CSRF checker,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24004786/
我正在尝试Checker Framework使用 Java 8 的 Nullness 检查器。当我在以下代码上运行检查器时: import java.util.HashMap; import java
从 IntellijIDEA 运行 Spring 应用程序时出现以下错误。 2017-04-20 18:20:50.645 ERROR 28680 --- [main] o.s.b.d.Logging
我正在使用为我的 HTML 文件启用的 Syntastic。由于我有一个非常大的文件,并且启用了“validator w3”检查器,因此在保存文件时 GVIM 或 VIM 变得非常慢 (:w)。 是否
正如您在标题中看到的,我正在尝试编写一个程序,该程序可以为我解决“晚间标准管测验”。它的一部分。它必须能够在地铁站名称中找到字谜。我在网上找到了很多代码来检查两个单词是否是字谜。但我需要一些不同的东西
以下是如何使用 C++ Core Checker 的说明:C++ Core Guidelines Checkers available for VS 2015 Update 1. 我成功安装了 NuG
我有一张 table : CREATE TABLE MENUPOINT ( id BIGINT NOT NULL, parent BIGINT, name VARCHAR(64), C
我以前用过它,当有人问及从样式表中删除未使用的 CSS 的工具时,我想起了它。 我回到链接,但是它不见了,这是怎么回事?它永远消失了还是有人知道备份?或者仍然可以根据 HTML 检查您的 CSS 并去
我在我的 React 应用程序的控制台中收到这条奇怪的警告消息。 Warning: Failed propType: checker is not a function Check the rende
如标题所述,我使用 bundle 搜索插件查找依赖项漏洞,但在我的项目中找不到任何漏洞。 我用的是IntelliJ IDEA 2022.1.3(旗舰版),我检查了一下,比如把spring-boot-s
为什么在下面的代码中,使用数组切片有效,但使用 Vec 的切片却无效? use rand::{rngs::adapter::ReadRng, RngCore}; use std::io::Read;
看起来 checkZip 函数是在用户的 zip 绑定(bind)到参数之前触发的。有没有更好的方法使用 Angular 工具来完成此任务?我想在用户输入正确的邮政编码后立即启动用户流程的下一步。 H
我指的是nullness-example in the docs (检查框架版本:2.1.14) 当我按照建议运行示例来检查NullnessExampleWithWarnings.java时: jav
我安装了 Eclipse 4.6.2 和插件“Checker Framework Feature”2.1.7。 首次使用该插件时(例如,当我右键单击并将鼠标悬停在上下文菜单项“Checker Fram
我正在尝试检查两个单词是否是变位词,并尝试使用 LinkedList 来做到这一点。为此,首先,我创建了一个名为 LinkedList 的类: class LinkedList { priv
我已经将 Checker Framework v2.1.6 引入到一个 java8 项目中,并修复了所有的 nullness 错误,但我仍然遇到以下错误 Main.java:52: error: [a
abi-compliance-checker 是一个 perl 程序,可以检查 linux 上库的 ABI ( https://lvc.github.io/abi-compliance-checker
我目前正在使用 Alexander Potochkin 的 AspectJ EDTChecker code (帖子底部的相关代码)。 此代码(基于我对 AspectJ 的一点了解)提示在 Swing
我正在开发一个基于多模块 Maven 的项目,其中一个模块包含一些注释处理器,用于其他模块使用的自定义注释。当我将注释处理器模块的依赖项添加到任何其他模块时,该模块的注释将由这些注释处理器处理。 但最
我想使用我自定义的列表来实现列表的常规应用实例: import Control.Monad import Test.QuickCheck import Test.QuickCheck.Checkers
考虑这个 github 存储库。 https://github.com/dfabulich/bazel-checker-framework-bug 它包括一个样本 X.java公然违反 @Nonnul
我是一名优秀的程序员,十分优秀!