- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我真的被困住了。这就是我想要做的。
本地一切正常。一旦将其投入生产,我就开始收到 CSRF 错误。以下是一切的运作方式。
我看到了所有的答案,从关闭 CSRF 到允许所有的一切。我想正确地做这件事,而不是关闭所有东西然后打开所有东西,然后以安全漏洞告终。
所以,这就是我所拥有的。
已安装:django-cors-标题django-rest-框架drf-嵌套路由器...和其他
我的 api 在 api.websitename.com 上运行,Vue.js 应用程序在 websitename.com 上运行。
GET 请求非常有效。OPTION 请求似乎有效。
任何有风险的请求都不行。
对于我的 CORS,我在其他 MIDDLEWARE
之前安装了 'corsheaders.middleware.CorsMiddleware',
。
那么我的 CORS 设置是:
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_WHITELIST = (
'*.websitename.com',
)
我的 CSRF 设置是:
CSRF_TRUSTED_ORIGINS = [
"api.websitename.com",
]
无论我怎么玩这些,我最终都会遇到 CSRF token 错误。
我已经尝试在我的 Vue App.vue 文件中执行类似的操作:
mounted () {
this.getCSRFToken()
},
methods: {
getCSRFToken () {
return axios.get('token/').then(response => {
axios.defaults.headers.common['x-csrftoken'] = Cookies.get('csrftoken')
}).catch(error => {
return Promise.reject(error.response.data)
})
}
}
我的想法是,一旦应用程序加载到浏览器中,我就会获得一个 CSRF token 。但即便如此,当应用程序尝试执行除 GET 或 OPTION 之外的任何操作时,我仍会收到失败的 CSRF token 错误。
这是返回 token 的 View ,以防您好奇:
class CSRFTokenView(APIView):
permission_classes = (permissions.AllowAny,)
@method_decorator(ensure_csrf_cookie)
def get(self, request):
return HttpResponse()
我意识到我可能会在这里混淆问题,但欢迎任何可以帮助我解决问题的建议。
最佳答案
首先你要使用SessionAuthentication :
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.SessionAuthentication',
)
}
这将强制执行 CSRF,匿名用户除外(稍后会详细介绍)。对于浏览器前端,最简单的解决方案是让(浏览器)前端和后端都在同一个域下——这可以让你避免 CORS——正如上面评论所建议的那样。如果您有其他客户端,则只需使用 token (DRF token 或 JWT)——但由于存在 XSS 攻击的危险,这些对于浏览器的使用并不安全(将 token 存储在 localStorage 中本质上是不安全的)。
由于您使用的是 axios,因此 CSRF 设置非常简单:
import axios from 'axios'
axios.defaults.xsrfHeaderName = 'X-CSRFToken'
axios.defaults.xsrfCookieName = 'csrftoken'
因此,您应该在强制执行 CSRF 的情况下进行安全 session 。几乎。引用上面的链接页面:
Warning: Always use Django's standard login view when creating login pages. This will ensure your login views are properly protected.
CSRF validation in REST framework works slightly differently to standard Django due to the need to support both session and non-session based authentication to the same views. This means that only authenticated requests require CSRF tokens, and anonymous requests may be sent without CSRF tokens. This behaviour is not suitable for login views, which should always have CSRF validation applied.
这很棘手 - 您要么只使用 Django 服务器端 View ,这会使您的 SPA 设计稍微复杂一些,要么在 DRF 中重新创建登录和其他身份验证 View ,但要注意使用 @csrf_protect方法装饰器在这些“匿名” View 上强制执行 CSRF。显然,这样的 View 会破坏使用 token 的客户端,因此您可能希望为这些使用不同的端点(可能重新使用相同的基类)。因此,您的浏览器登录使用 /auth/browser/login/ 和您的移动登录 /auth/mobile/login/,前者使用 @csrf_protect 包裹>.
在研究了 contrib auth 源代码之后,应该仔细地从头开始重新创建登录和其他 auth View ;对于 Vanilla 要求,我会推荐预先存在的解决方案,如 django-rest-auth和 django-all-auth .然而,django-rest-auth 包并不是为浏览器前端设计的,它强制使用 token 生成,而且您需要如上所述包装 View 。另一方面,all-auth 为 JS 客户端提供 AJAX 响应,可能是更好的选择。
关于django - 让 Django、VUE、CORS 和 CSRF 与真实世界的例子一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54836387/
我想要的是能够在输入获得焦点或失去焦点时执行某些操作(两个事件)。 我尝试了以下方法,但这按事件单独工作(单独编码时):仅在焦点上,或仅在失去焦点时。 另外,我希望它尽可能跨平台(包括触摸设备),这是
我分别研究了TableView的Filtering和Pagination。 过滤: this帖子帮助我满足了我的需要 分页: this , this帖子也帮助了我 我想像这样将它们组合在一起: 详情-
我是 TDD 方法的新手,所以我想知道是否有人经历过这种机智可以启发我一点。我想获得一些关于如何一起使用 UML 和 TDD 方法的线索。 我已经习惯了:用 UML 设计 --> 生成骨架类(然后保持
我尝试使用入口点和 cmd 设置 Docker。 FROM debian:stretch RUN apt-get update && \ apt install gnupg ca-certificat
我想要一个 Class 对象,但我想强制它所代表的任何类扩展类 A 并实现接口(interface) B。 我能做到: Class 或者: Class 但我不能两者兼得。有办法做到这一点吗? 最佳答案
我是 Rubymine 的长期用户。 Rubymine 非常适合基于 html 的 Rails 应用程序,但我现在正在做更多的 SPA 客户端工作(例如 javascript/react)。我发现我真
我注意到我使用的某个脚本依赖于原型(prototype)。 (Lightbox 2) 它会与 jQuery 在同一页面上一起工作吗?有没有办法确保它们不冲突? 最佳答案 可以,但你需要采取 speci
我需要对表中显示的数据进行分页并通过 ajax 调用获取它 - 这是我通过使用具有以下配置的 dataTables 插件来完成的 - bServerSide : true; sAjaxSource :
我是 gtk 新手,所以想知道在 C 语言中归档和 gtk 是否可以一起使用?例如,我可以从 .txt 文件中读取,然后在相同的代码中使用 gtk 在标签或其他内容中显示它吗?如果是,怎么办? 谢谢!
有没有人设法得到Bck2Brwsr最近与 Java 8/JavaFX 8 一起工作?有没有兼容的机会?我找不到太多关于它的信息,也没有一个好的起点。使用给定的 Maven archetype我遇到了几
在我的应用程序中,用户通过 openid(与 stackoverflow 相同)登录/注销。 我想通过 oauth 向第三方应用程序开放我的应用程序。 如何创建我的 openid-consumer 应
我在启动和运行 Hibernate 和 Spring 时遇到一些问题。我有一个网络服务器项目,它使用了其他几个具有持久实体的项目。我遇到的问题是,对于存储在 WEB-INF/libs 内的另一个 ja
我有 @ControllerAdvice 类,它处理一组异常。我们还有一些其他异常,这些异常用 @ResponseStatus 注释进行注释。为了结合这两种方法,我们使用博客文章中描述的技术:http
我想在屏幕上使用进度条而不是 progressDialog。 我在我的 XML View 文件中插入了一个进度条,我想让它在加载时显示并在不加载时禁用它。 所以我使用的是可见的,但它发生了,所以其余的
CREATE TABLE `users` ( `id` int(11) AUTO_INCREMENT, `academicdegree` varchar(255),
IN() 中使用的查询返回:1, 2。然而,整个查询返回 0 行,这是不可能的,因为它们存在。我在这里做错了什么? SELECT DISTINCT li.auto_id FROM links
亲们, 我如何在使用 Jade 生成的表单上实现 jQuery 样式?我想做的是美化 表单并使它们可点击。我在 UI 方面很糟糕。期间。 我如何在表单上实现这个可选择的方法? http://jquer
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我可以: auto o1 = new Content; 但不能: std::shared_ptr o1(new Content); std::unique_ptr o1(new Content); 我
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 4 年前。 Improve this qu
我是一名优秀的程序员,十分优秀!