【发布时间】:2017-10-27 17:16:46
【问题描述】:
Spring CSRF 不适用于带有文件上传的多部分表单。它适用于其他请求。我的 web.xml 看起来像这样 -
<filter>
<filter-name>MultipartFilter</filter-name>
<filter-class>org.springframework.web.multipart.support.MultipartFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>MultipartFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
...
some more filters
...
<filter>
<filter-name>csrfFilter</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy
</filter-class>
</filter>
<filter-mapping>
<filter-name>csrfFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
我已经在我的 appcontext-servlet.xml 中定义了这个 bean -
<bean id="filterMultipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="100000000" />
</bean>
我还定义了 csrfFilter。定义了 filterMultipartResolver bean,我被重定向到我们的默认 404 页面。如果没有 bean,我会收到一个错误页面,说我发送了一个空令牌。当我在 chrome 开发人员工具中看到请求时,它包含以下部分以及表单的其余部分(令牌已附加两次,因为我在页面加载时使用 javascript 这样做一次,并且可能在发送时这样做一次。我是什么不见了?
------WebKitFormBoundaryHMYSQ8eg6FXpxqDA 内容处置:表单数据; name="_csrf"
16a983e0-a115-43d9-aa72-09c9576d53df ------WebKitFormBoundaryHMYSQ8eg6FXpxqDA 内容处置:表单数据; name="_csrf"
16a983e0-a115-43d9-aa72-09c9576d53df
【问题讨论】:
标签: javascript spring-security csrf multipartform-data