Djang+React配合开发遇到 axios发出post,但后端接收不到参数的解决方案

在Django与React集成开发中,遇到Axios发送POST请求时,Django后端无法接收到参数的问题。原因是Django仅在'Content-Type': 'application/x-www-form-urlencoded'时处理request.POST。解决方案是修改后端,从请求body中加载数据。

在尝试把Django作为一个单纯的REST框架配合React进行web开发的时候遇到了使用axios发出post请求,但Django后端收不到数据的情况。
axios代码是很普通的样例代码:

axios({
   
   

	method: 'post',
	url: '/api/../register',
	data: {
   
   
		username:'aaaa',
		pwd:'123'
	}
})

### 如何在项目中集成Django和React #### 创建Django项目 为了创建一个新的 Django 项目,需安装 Django 并运行命令来启动新项目。这一步骤会建立项目的结构框架。 ```bash django-admin startproject myproject cd myproject ``` #### 设置Django作为API服务器 为了让 React 应用与之交互,应设置 Django 来提供 RESTful API 接口。为此,通常引入 `Django Rest Framework` (DRF),这是一个强大的工具包用于构建 Web APIs[^1]。 ```bash pip install djangorestframework ``` 编辑 `INSTALLED_APPS` 添加 `'rest_framework'`: ```python # settings.py INSTALLED_APPS = [ ... 'rest_framework', ] ``` #### 构建React应用程序 对于前端部分,在 Django 项目目录下利用 Create React App 工具快速搭建新的 React 应用程序。 ```bash npx create-react-app frontend cd frontend npm start ``` 此过程将初始化一个独立于后端服务的前端环境,允许两者分开部署或联合调试[^2]。 #### 连接前后端 要使两个平台协同工作,需要配置 CORS(跨域资源共享),以便让来自不同源的 HTTP 请求合法化。可以通过安装 django-cors-headers 中间件实现这一点。 ```bash pip install django-cors-headers ``` 接着修改 `settings.py` 文件中的中间件列表以及CORS策略: ```python MIDDLEWARE = [ ..., 'corsheaders.middleware.CorsMiddleware', # 尽量放在最上面 ] CORS_ORIGIN_ALLOW_ALL = True # 开发环境中可暂时全部放行;生产环境下建议指定白名单 ``` 另外,还需调整静态文件路径以支持 React 打包后的资源加载,并确保 URL 路由不会冲突[^3]。 #### 使用 Axios 发送请求 最后,在 React 组件内可通过 AxiosDjango 提供的服务发起 GET/POST 等类型的网络调用,从而完成数据交换。 ```javascript import axios from "axios"; const fetchData = async () => { try { const response = await axios.get('/api/data/'); console.log(response.data); } catch (error) { console.error(error); } }; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值