DRF跨域后端解决之django-cors-headers

在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员,因此我要通过后端的程序实现跨域。当然如果前端框架是Vue的话,则可以代理服务实现跨域,我也就知道一点点,如果有兴趣,大家可以自行搜索哦。
DRF后端实现跨域第三方扩展———djangocorsheaders,在介绍之前,我先介绍两个概念:同源策略、跨域

同源策略

同源策略/SOP(Same origin policy)是一种约定,是浏览器的一种安全机制。这里同源需要"协议+域名+端口"三者都相同,否则不能进行Ajax访问。

跨域

不同源之间的网站通信就是跨域。

安装

pip install django-cors-headers

注册

INSTALLED_APPS = (
    'corsheaders',
)

添加中间件

MIDDLEWARE = [
    'corsheaders.middleware.CorsMiddleware', #最好添加至第一行
]

配置白名单

#单个配置
CORS_ORIGIN_WHITELIST  =(
     ' 域名',
)
#正则配置:
CORS_ORIGIN_REGEX_WHITELIST  =(r'^(https?://)?(\w+\.)?jim\.com $',)

或者直接允许所有主机跨域

CORS_ORIGIN_ALLOW_ALL = True 默认为False

请求头及请求方法的配置:

#默认可以使用的非标准请求头,需要使用自定义请求头时,就可以进行修改
CORS_ALLOW_HEADERS = (
    'accept',
    'accept-encoding',
    'authorization',
    'content-type',
    'dnt',
    'origin',
    'user-agent',
    'x-csrftoken',
    'x-requested-with',
)
#默认请求方法
CORS_ALLOW_METHODS = (
    'DELETE',
    'GET',
    'OPTIONS',
    'PATCH',
    'POST',
    'PUT',
)

防止CSRF

#添加信任的站点 django1.9引入
CSRF_TRUSTED_ORIGINS = (
    'change.allowed.com',
)

一般情况下,我们配置这些就足够,当然最为一个出名的扩展,肯定做的很完美,更多的配置,请访问:https://github.com/ottoyiu/dj...

Django REST Framework (DRF) 是一套用于构建高效、功能丰富的 API 的 Python 框架。它是基于 Django Web 应用框架的一个独立组件,并提供了一系列工具和服务,旨在简化 API 开发过程。 ### 功能特点: #### 简化 API 创建: - DRF 提供了一套完整的、易于使用的 API 创建工具,包括认证、权限控制、序列化和分页等功能。 - 可以快速生成 CRUD(创建、读取、更新、删除)操作所需的视图和序列化器,降低了开发成本和提高了开发效率。 #### 高度自定义性: - DRF 允许开发者高度定制 API 行为,包括路由配置、错误处理、响应渲染等。 - 支持多种验证机制和权限系统,使得安全性得到保障。 #### 易于集成: - 它可以与 Django 无缝集成,也可以作为一个独立项目与其他框架配合工作,如 Flask 或 FastAPI。 - 提供了丰富的文档和示例,便于学习和使用。 #### 强大的功能集: - **模型绑定**:自动将数据模型映射到 API 资源上,简化数据管理。 - **序列化与反序列化**:强大的序列化能力允许轻松转换数据格式,并支持 JSON、XML 等多种格式。 - **动态路由**:可以根据需要动态生成和修改路由,增加灵活性。 - **过滤与排序**:提供丰富的方式对查询结果进行过滤和排序,提升用户体验。 ### 示例使用场景: - 开发需要大量数据交互的应用程序,例如电子商务平台、社交媒体应用、企业管理系统等,特别是当需要对外提供 RESTful 格式的 API 接口时。 ### 相关问题: 1. Django REST Framework 与其他后端框架相比有何优势? 2. 如何开始使用 Django REST Framework 开发自己的 API? 3. Django REST Framework 中如何实现更复杂的数据处理逻辑?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值