您的当前位置:首页>全部文章>文章详情

【AntDesignPro】Ant Design Pro学习记录—前后端分离跨域设置,解决跨域session不一致

CrazyPanda发表于:2023-11-28 21:21:19浏览:551次TAG:

目录

前言

一、为什么跨域

二、跨域配置

三、跨域请求session不一致


前言

第一次做前后端分离,也是踩了很多坑,记录一下AntDesignPro跨域解决的方式。

服务器系统使用Nginx,服务端使用thinkphp6。

AntDesignPro正式build放到服务器上后,提示登录成功,但一直登录不上,后来发现是跨域session不同导致的,登录的时候session和登录成功后session的id不同,导致提示登录成功,就是登录不进去的情况。


一、为什么跨域

不想知道为什么要跨域,只想知道怎么解决。

二、跨域配置

网上有很多跨域配置的解决方案,可是针对不同实际情况有的有效,有的无效,这里记录一下我的调查结果,就下面这几行代码很简单,放到nginx配置文件就行。

我的实际情况:把这几行代码放到配置文件的server内,停止后再启动nginx就是不生效,换个位置还是不行,最后干脆直接放到配置文件server外面,这就可以了,一脸懵,不知道为什么,但这样他就行了;

我原先也配置 Access-Control-Allow-Origin:*,没有写请求的具体地址,后来为了解决无法识别同一个session的问题,又给配上了具体地址。

最后发现后台框架已经封装了跨域,直接就使用封装好的跨域配置了,也就把nginx的配置去掉了,不过总体就是这几行配置。

# 允许跨域请求的“域”
add_header 'Access-Control-Allow-Origin' *;
# 允许客户端提交Cookie
add_header 'Access-Control-Allow-Credentials' 'true';
# 允许客户端的请求方法
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, DELETE, PUT';
# 允许客户端提交的的请求头
add_header 'Access-Control-Allow-Headers' 'Origin, x-requested-with, Content-Type, Accept, Authorization';
# 允许客户端访问的响应头
add_header 'Access-Control-Expose-Headers' 'Cache-Control, Content-Language, Content-Type, Expires, Last-Modified, Pragma';

三、跨域请求session不一致

参考thinkphp中session跨域问题怎么处理 - 编程语言 - 亿速云

跨域请求基本就是配置 withCredentials: true,服务端跨域Access-Control-Allow-Origin要配置具体地址,不能使用 *

但前端请求的实际情况都不同,完全跨域,AntDesignPro请求跨域请求要怎么处理,对新手来说还是难,想来AntDesignPro都发展到V5版本了,这点小问题应该是有处理方式的,资料太少,废了好大劲才给试出来。

直接在API接口配置credentials:'include'就行了。

1.png

2.png

request中withCredentials的配置说明如下图,credentials要配置include才行,而credentials的值有三个,另外两个没有细究,但是注意配置好后一定要清除浏览器缓存才行

3.png

4.png

5.png

之后就可以正常登录了。


 总结

AntDesignPro配置很全,但资料太少,研究一点是一点。


猜你喜欢

【AntDesignPro】Ant Design Pro学习记录—ModalForm的使用(三)
一、 Form.useForm()的使用之前使用表单的时候,一直在为表单赋值纠结,找了一些资料,也感觉很复杂,使用多了之后,感觉表单赋值也挺简单的。1、 创建一个formconst [theForm] = Form.useForm();2、 绑定表单组件无论是ProForm、ModalForm、还是DrawerForm,都可以绑定我们的theForm,使用属性form={theForm}绑定,代码如下<ProForm    &nb
发表于:2024-02-20 浏览:466 TAG:
【AntDesignPro】Ant Design Pro学习记录—自定义菜单选中
页面增删改查,打开子页面时,要让父页面菜单选中,参考官网给出的方案菜单的高级用法 - Ant Design Pro 使用的V5版本,直接设置 parentKeys:['/product'] 即可export default [   {     path: '/product',     // 不展示菜单  
发表于:2023-11-28 浏览:756 TAG:
【AntDesignPro】使用高德地图设置考勤区域
参考高德开放平台https://lbs.amap.com/api/javascript-api-v2/guide/abc/amap-react功能要求:使用AntDesignPro开发系统管理端,考勤模块需要设置APP考勤打卡区域,需要页面显示地图定位并设置考勤范围(地图上画圈),以便APP在画圈范围内打卡使用。1、 准备2、 下载react类组件代码参考官网流程,可正常加载出地图组件,下面是我的页面和组件文件组件文件3、 安装并引入AmAP Loadernpm i @ama
发表于:2023-12-14 浏览:737 TAG:
【AntDesignPro】Ant Design Pro学习记录—ModalForm的使用(二)
 目录一、ModalForm高度设置二、ModalForm点击阴影背景,不隐藏弹框三、ProFormSelect联动四、ProFormText关联赋值一、ModalForm高度设置在modalProps中设置bodyStyle:{height:500,overflowY:'scroll'}编辑效果如下:编辑二、ModalForm点击阴影背景,不隐藏弹框同样在modalProps里面,配置maskClosable: false,就可以实现点击弹框外阴影,不隐藏弹框<
发表于:2023-11-28 浏览:1178 TAG:
【React】前端框架 React 学习总结
目录一、React在HTML里的运用二、React框架的常用操作项目打包1、JSX基础语法规则2、state数据的使用3、生命周期4、数据的双向绑定与Ref5、PropTypes验证规则6、React里的插槽7、错误边界8、直接操作refs元素9、高阶组件的运用案例10、性能优化11、Hook生命周期钩子的使用12、React里的计算属性三、组件之间的传值1、父子组件之间传值2、子向父传值3、context实现跨层级通信context hook案例四、网络请求框架使用五、React路由的使用声明
发表于:2023-12-05 浏览:879 TAG: #php
【AntDesignPro】Ant Design Pro学习记录—ModalForm的使用(四)
一、 ModalForm自定义footer按钮参考官网,Modal弹框是可以自定义按钮的,原想着ModalForm的modalprops可以设置自定义footer,结果设置一直不生效,最终还是使用Modal嵌套了ProForm实现了功能,在此记录一下。ant design pro使用的V5版本。1、Modal自定义footer参考官网https://ant-design.antgroup.com/components/modal-cn?from=msidevs.net#components-mo
发表于:2024-02-20 浏览:354 TAG:
【React】使用React实现一个内容滑动组件
最近在做项目时遇到一个需求,需要让一个列表能够通过点击按钮进行滚动,每次都是一屏的距离,不足则结束。并且,这个列表项是在react-grid-layout中的某一个模块内。所以包裹这个列表的容器会随时发生变化。在完成这个组件后,通过这篇文章总结一下。UI/原型分析那么从上面的功能描述以及项目中的UI,我们可以分析得到这样一个假想图:我们需要实现一个容器来作为我们的可视区域,并且这个容器是可以伸缩的。列表内容如果超出容器的可视区域,那么就会被隐藏。需要左右都有按钮,来支持用户左右滑动内容来查看,每
发表于:2024-04-10 浏览:318 TAG:
【AntDesignPro】Ant Design Pro学习记录—默认主题配色修改
 版本: Ant Design Pro V5先参考下官网定制主题 - Ant Design再参考这篇文章antd pro 修改全局样式_tankpanv的博客-CSDN博客_antd修改全局样式最后自己实验:第一步,在config.ts文件中配置theme: {     'primary-color': defaultSettings.primaryColor,   },这种配置需
发表于:2023-11-28 浏览:777 TAG:
【AntDesignPro】Ant Design Pro学习记录—DrawerForm的使用
在AntDesignPro中,ModalForm和DrawerForm是我最常用的两个表单组件,配置上,他们有很多相同的地方,也有差异的地方,相比较而言,DrawerForm我使用的更多。ModalForm<ModalForm         title={标题}         width={600}   &n
发表于:2024-05-17 浏览:461 TAG:
【React】16 个实用的 React 库
Web开发中,经常会需要使用第三方库来提高开发效率。今天给大家分享16个非常实用的React第三方库,使用好这些库你可以更轻松、更快速的开发项目,让我们一起看看吧!1.react-hook-formReact-hook-form 是一个用于构建 Web 应用程序的表单库。它支持多种表单类型,包括输入框、下拉框、单选框、多选框等。它还提供了一些自定义选项,可以自定义表单的外观和行为。官方地址:https://react-hook-form.com/2.rechartsRecharts 是一个用于构
发表于:2024-04-01 浏览:297 TAG: