gpt4 book ai didi

cordova - 从 ionic iOS 原生到 WP Rest API 的 http 请求出错(适用于 Web View 和 DevApp)

转载 作者:行者123 更新时间:2023-12-02 15:19:25 25 4
gpt4 key购买 nike

我们正在尝试从我们的 ionic 应用程序向 Wordpress 服务器(REST API)发出 http 请求,并收到以下错误:{"_body":{"isTrusted":true},"status":0,"ok":false,"statusText":"","headers":{},"type":3,"url “:null}

当我们使用 Web View 或 ionic DevApp 时,请求工作正常,但在 iOS 设备上失败。

到目前为止我们做了什么:

  • 我们通过 DevApp 和 WebView 验证了请求工作正常。
  • 我们放宽了 cordova 白名单插件(请参阅下面的 config.xml)。
  • 我们已验证我们的服务器已启用 CORS(请参阅下面的 curl CORS 检查)
  • 我们检查了当请求被阻止时,iOS 设备没有发出 CORS 预检请求,因为我们可以在服务器访问日志中看到 GET 请求并且没有 OPTIONS 请求。
  • 显然,设备与服务器之间存在连接,因为我们可以看到 GET 请求。

如果您有任何建议,即使看起来很牵强,我们也非常乐意听到。

感谢您的帮助!

请求代码

import { Http, Response } from '@angular/http';

...

private requestData(path: String, params:Object = {}){
return this.http.get( this.request.url + path, {
params: {
'consumer_key': this.conf.comm.appId,
'consumer_secret': this.conf.comm.appSecret
}
})
.map( (res: Response) => this.prepareResponse(res) )
.catch( (res: Response) => this.catchError(res) );
}

config.xml

<?xml version='1.0' encoding='utf-8'?>
<widget id="app.c***r.***" version="0.0.1" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0">
<name>***</name>
<description>The ***</description>
<author email="admin@c***r.app" href="https://c***r.app">***</author>
<content src="index.html" />
<access origin="*" />
<access origin="*" subdomains="true" />
<allow-navigation href="http://*/*" />
<allow-navigation href="https://*/*" />
<allow-navigation href="localhost:8080" />
<allow-navigation href="data:*" />
<allow-intent href="http://*/*" />
<allow-intent href="https://*/*" />
<allow-intent href="mailto:*" />
<preference name="ScrollEnabled" value="false" />
<preference name="android-minSdkVersion" value="19" />
<preference name="BackupWebStorage" value="none" />
<preference name="SplashMaintainAspectRatio" value="true" />
<preference name="FadeSplashScreenDuration" value="300" />
<preference name="SplashShowOnlyFirstTime" value="false" />
<preference name="SplashScreen" value="screen" />
<preference name="SplashScreenDelay" value="3000" />
<platform name="android">
<icon density="ldpi" src="resources/android/icon/drawable-ldpi-icon.png" />
...
<splash density="port-xxxhdpi" src="resources/android/splash/drawable-port-xxxhdpi-screen.png" />
</platform>
<platform name="ios">
<icon height="57" src="resources/ios/icon/icon.png" width="57" />
...
<splash height="2732" src="resources/ios/splash/Default@2x~universal~anyany.png" width="2732" />
</platform>
<plugin name="cordova-plugin-whitelist" spec="1.3.3" />
<plugin name="cordova-plugin-statusbar" spec="2.4.2" />
<plugin name="cordova-plugin-device" spec="2.0.2" />
<plugin name="cordova-plugin-splashscreen" spec="5.0.2" />
<plugin name="cordova-plugin-ionic-webview" spec="^3.0.0" />
<plugin name="cordova-plugin-ionic-keyboard" spec="^2.0.5" />
<plugin name="cordova-sqlite-storage" spec="3.2.0" />
<engine name="ios" spec="~4.5.5" />
<engine name="android" spec="~7.1.4" />
</widget>

curl CORS 检查

* Hostname was NOT found in DNS cache
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0* Trying 18.224.***.***...
* Connected to p***r.app (18.224.***.***) port 443 (#0)
* successfully set certificate verify locations:
...
* SSL certificate verify ok.
> GET /wp-json/wc/v2/products/categories?consumer_key=ck_3***2&consumer_secret=cs_0***b&per_page=100 HTTP/1.1
> User-Agent: curl/7.38.0
> Host: p***r.app
> Accept: */*
> Origin: http://localhost:8080
>
< HTTP/1.1 200 OK
< Date: Fri, 12 Apr 2019 14:44:43 GMT
* Server Apache is not blacklisted
< Server: Apache
< X-Powered-By: PHP/7.0.31
< X-Robots-Tag: noindex
< Link: <https://p***r.app/wp-json/>; rel="https://api.w.org/"
< X-Content-Type-Options: nosniff
< Access-Control-Expose-Headers: X-WP-Total, X-WP-TotalPages
< Access-Control-Allow-Headers: Authorization, Content-Type
< X-WP-Total: 98
< X-WP-TotalPages: 1
< Cache-Control: public, max-age=2592000
< Allow: GET
< Access-Control-Allow-Origin: http://localhost:8080
< Access-Control-Allow-Methods: OPTIONS, GET, POST, PUT, PATCH, DELETE
< Access-Control-Allow-Credentials: true
< Vary: Origin
< X-Frame-Options: SAMEORIGIN
< Transfer-Encoding: chunked
< Content-Type: application/json; charset=UTF-8
<

最佳答案

该问题是由 ionic 在用作编译应用程序时发送 ionic://localhost 作为来源引起的。 WP REST 通过 rest_send_cors_headers 进行响应,它通过 esc_url_raw 传递源,并由于其协议(protocol)而拒绝该 url。

要解决此问题,只需通过过滤器 kses_allowed_protocols 将协议(protocol) ionic 添加到允许的协议(protocol)列表中即可。

顺便说一句,如果您来自 ionic 并阅读本文,请考虑使编译的应用程序的行为尽可能接近 Web View 和 DevApp,包括发送到服务器的源。

关于cordova - 从 ionic iOS 原生到 WP Rest API 的 http 请求出错(适用于 Web View 和 DevApp),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55655100/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com