Cordova iOS 本地文件上的“Access-Control-Allow-Origin 不允许 Origin null”

Jor*_*yes 4 cordova cordova-ios

我在 Cordova CLI 上开发一个项目并在物理 iPhone 上编译应用程序,但在控制台中出现访问控制源错误。

这是消息:

[Error] Origin null is not allowed by Access-Control-Allow-Origin.
[Error] Failed to load resource: Origin null is not allowed by Access-Control-Allow-Origin. (bootstrap.min.css, line 0)
Run Code Online (Sandbox Code Playgroud)

该错误来自本地文件,也来自 ajax。

我的config.xml的配置是:

<?xml version='1.0' encoding='utf-8'?>
<widget android-versionCode="14" defaultlocale="es-ES" id="com..." version="2.0.0" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0">
    <name>TEXT</name>
    <description>TEXT</description>
    <author email="MYEMAIL" href="MYURL">
        MYNAME
    </author>
    <content src="index.html" />
    <access origin="*" />        
    <allow-navigation href="*" />
    <preference name="windows-target-version" value="10.0" />
    <preference name="KeyboardDisplayRequiresUserAction" value="false" />
    <allow-intent href="http://*/*" />
    <allow-intent href="https://*/*" />
    <allow-intent href="tel:*" />
    <allow-intent href="sms:*" />
    <allow-intent href="mailto:*" />
    <allow-intent href="geo:*" />
Run Code Online (Sandbox Code Playgroud)

在我的项目的所有 html 文件中,元数据是:

<!DOCTYPE html>
<html lang="es">
    <head>
        <meta charset="utf-8">
        <meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src * data: content:; connect-src *;">
        <meta name="format-detection" content="telephone=no">
        <meta name="msapplication-tap-highlight" content="no">
Run Code Online (Sandbox Code Playgroud)

我的项目的数据是:

Cordova version 10.0.0
cordova-ios version  6.1.1
Run Code Online (Sandbox Code Playgroud)

有人可以帮我解决这个问题吗?我非常感谢你

ada*_*ort 19

使用 Cordova-ios@6,您需要根据此处的scheme文档指定和:hostname

此外,此版本还引入了 WKURLSchemeHandler 支持。使用自定义方案通过修复由于 WKWebView 对文件方案应用了严格的安全策略而存在的 CORS 问题来提供应用程序内容。您可以通过在 config.xml 文件中设置首选项方案和主机名,轻松将 Cordova 项目配置为使用自定义方案。

<preference name="scheme" value="app" />
<preference name="hostname" value="localhost" />
Run Code Online (Sandbox Code Playgroud)

app://localhost这将从而不是 为您的应用程序提供服务file://,并且您的originxhr 请求也将是app://localhost。由于此源是与 CORS 请求一起发送的,因此您可能需要更改主机名以匹配远程域(如果您的应用程序使用远程域),不过只要将其添加到 CORS 标头中,一切都应该没Access-Control-Allow-Origin问题响应。