如何配置Thinkphp5.1以支持uni-app H5跨域请求接口?

2026-04-02 03:211阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计464个文字,预计阅读时间需要2分钟。

如何配置Thinkphp5.1以支持uni-app H5跨域请求接口?

场景:使用uni-app结合Vue框架开发混合APP,虽然APP或小程序没有跨域问题,但希望实现一个既包含H5,又有APP和小程序的多平台应用,最好通过后端解决跨域问题。但不确定是Vue的原因还是其他因素导致跨域问题。

情景:

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

如何配置Thinkphp5.1以支持uni-app H5跨域请求接口?

分析:

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

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

2. 添加后请求,报错“Access to XMLHttpRequest at 'www.unxxx.com/api/v1.user/login' from origin '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 'www.xxxxxx.com/api/v1.user/login' from origin '192.168.2.121:8000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource。

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

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

标签:跨域请求

本文共计464个文字,预计阅读时间需要2分钟。

如何配置Thinkphp5.1以支持uni-app H5跨域请求接口?

场景:使用uni-app结合Vue框架开发混合APP,虽然APP或小程序没有跨域问题,但希望实现一个既包含H5,又有APP和小程序的多平台应用,最好通过后端解决跨域问题。但不确定是Vue的原因还是其他因素导致跨域问题。

情景:

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

如何配置Thinkphp5.1以支持uni-app H5跨域请求接口?

分析:

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

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

2. 添加后请求,报错“Access to XMLHttpRequest at 'www.unxxx.com/api/v1.user/login' from origin '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 'www.xxxxxx.com/api/v1.user/login' from origin '192.168.2.121:8000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource。

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

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

标签:跨域请求