uni-app部署h5到php,Thinkphp5.1允许uni-app的H5跨域请求接口解决方法

情景:

uni-app使用vue框架开发夹杂APP,虽然APP或者小程序没有跨域,但希望就是写完这个既有H5,又有APP,小程序等,所以能通过后端解决跨域最好。然则不知道是vue的缘故原由照样什么,在PHP接口基类中添加了header头完全不起作用。官方给出的方式也有,详细可以看https://uniapp.dcloud.io/api/request/request。

剖析:

1. 以前的做法是在接口添加以下部门就可以解决ajax的跨域(虽然也用过jsonp)。

// 指定允许其他域名接见 // header('Access-Control-Allow-Origin:*'); // // 响应类型 // header('Access-Control-Allow-Methods:*'); // // 响应头设置 // header('Access-Control-Allow-Headers:*');

2. 添加后请求,报错“Access to XMLHttpRequest at ‘http://www.unxxx.com/api/v1.user/login’ from origin ‘http://192.168.2.121:8000’ has been blocked by CORS policy: Request header field token is not allowed by Access-Control-Allow-Headers in preflight response.”;自定义的请求头token不被允许。由于接口请求需要带上token,把token放在自定义请求头上再传到PHP。

3. 于是就将token改为通俗参数方式通报,但依然报错,Access to XMLHttpRequest at ‘http://www.xxxxxx.com/api/v1.user/login’ from origin ‘http://192.168.2.121:8000’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource。

fc2430c0ab08ade976006c5d14536082.png

4. 以上可以看出就是通俗跨域报错了,然后看一下浏览器的请求响应报文。

bc82b5bde9bb4b75ef519cec4ae67d47.png

5. 发现返回过来的头部信息完全不是自己在接口上指定的,抱着试一试的念头,把跨域请求放到了TP5.1的入口文件\public\index.php,竟然就可以正常请求了,现在我也不清楚缘故原由是什么。

60d188ac0d0efc874b208c0b0410b9c2.png

待续

后面就可以加域名白名单等等。坑虽然避开了,然则问题并没有解决 ,若是人人有知道缘故原由的可以加我微信一起谈论。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值