django理解02 前后端分离中的问题

前后端分离相对于传统方式的问题

  • 前后端数据交换的问题
  • 跨域问题

页面js往自身程序(django服务)发送请求,这是浏览器默认接受响应

而请求其它地方是浏览器认为存在潜在危险。自动隔离请求!!!

跨域问题的解决:

从后端入手(前端也可以)

安装模块

bash 复制代码
pip install django-cors-headers

settings.py中

  • 注册,添加中间件等配置
python 复制代码
INSTALLED_APPS = (
    ...
    'corsheaders'
)


MIDDLEWARE = [
    ...
    'corsheaders.middleware.CorsMiddleware',
    #'django.middleware.common.CommonMiddleware',     这个是原本就存在的
]
#跨域处理
#跨域增加忽略
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True
CORS_ORIGIN_WHITLIST = (
    '*'
)

CORS_ALLOW_METHODS = (
    'GET',
    'POST',
)

CORS_ALLOW_HEADERS = (
    'XMLHttpRequest',
    'X_FILENAME',
    'accept-encoding',
    'authorization',
    'content-type',
    'dnt',
    'origin',
    'user-agent',
    'x-csrftoken',
    'x-requested-with',
    'Pragma',
)

解决后的测试:

后端:

python 复制代码
#api test
def get(request):
        data_list = [
            {"comment":"今天天气很好","date":"11.18","name":"左xx"},
            {"comment":"今天很开心","date":"3.21","name":"刘xx"},
            {"comment": "乐", "date": "3.3", "name": "靖xx"}
        ]
        request_data = {"code":200,"message":"请求成功"}
        request_data["data"] = data_list
        return JsonResponse(request_data)

前端:

javascript 复制代码
<template>
    <div>
        <h1>Part1</h1>
        <el-table
            :data="tableData"
            height="250"
            border
            style="width: 100%">
            <el-table-column
            prop="date"
            label="日期"
            width="180">
            </el-table-column>
            <el-table-column
            prop="name"
            label="姓名"
            width="180">
            </el-table-column>
            <el-table-column
            prop="comment"
            label="评论">
            </el-table-column>
        </el-table>
        <el-pagination
            background
            layout="prev, pager, next"
            :total="1000">
        </el-pagination>
    </div>
</template>

<script>
    import axios from 'axios';

  export default {
    data() {
      return {
        tableData: [],
      }
    },
    methods:{

    },
    mounted(){
        //发送异步请求,获取数据
        axios.get("http://127.0.0.1:8000/get/").then((result) =>{
            this.tableData=result.data.data;       //从返回的result中获取需要的信息
        });
        // alert(this.tableData);
    }

  }
</script>

效果图:

下一步

考虑加入数据库

相关推荐
IT_陈寒10 分钟前
React 18并发渲染实战:5个核心API让你的应用性能飙升50%
前端·人工智能·后端
韩曙亮14 分钟前
【人工智能】AI 人工智能 技术 学习路径分析 ① ( Python语言 -> 微积分 / 概率论 / 线性代数 -> 机器学习 )
人工智能·python·学习·数学·机器学习·ai·微积分
一 乐20 分钟前
购物|明星周边商城|基于springboot的明星周边商城系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·spring
y1y1z29 分钟前
Spring框架教程
java·后端·spring
V***u45342 分钟前
【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元
前端·spring boot·后端
喵叔哟1 小时前
6.配置管理详解
后端·python·flask
yuuki2332331 小时前
【C++】类和对象(上)
c++·后端·算法
曾经的三心草1 小时前
基于正倒排索引的Java文档搜索引擎3-实现Index类-实现搜索模块-实现DocSearcher类
java·python·搜索引擎
韩数1 小时前
小白也能看懂! 今年爆火的 MCP 协议究竟是什么?写给普通人的 MCP 指南
后端·aigc·mcp
l***46681 小时前
SSM与Springboot是什么关系? -----区别与联系
java·spring boot·后端