Cordova PhoneGap“;加载资源失败:服务器响应状态为404(未找到)";

Cordova PhoneGap“;加载资源失败:服务器响应状态为404(未找到)";,cordova,permissions,Cordova,Permissions,我最近尝试将一个web应用程序转换为PhoneGap,但由于某种原因,在我的android上运行它时,它无法访问互联网。通过usb使用chrome进行调试时,我看到所有外部请求都出现错误“加载资源失败:服务器响应状态为404(未找到)”(例如,从html中的font.googleapis.com将google字体作为样式表加载,并从我的js调用firebase) 我使用的是默认的指令,据我所知,它应该允许完全访问 我完整的config.xml如下: <widget xmlns="http:

我最近尝试将一个web应用程序转换为PhoneGap,但由于某种原因,在我的android上运行它时,它无法访问互联网。通过usb使用chrome进行调试时,我看到所有外部请求都出现错误“加载资源失败:服务器响应状态为404(未找到)”(例如,从html中的
font.googleapis.com
将google字体作为样式表加载,并从我的js调用firebase)

我使用的是默认的
指令,据我所知,它应该允许完全访问

我完整的
config.xml
如下:

<widget xmlns="http://www.w3.org/ns/widgets" xmlns:gap="http://phonegap.com/ns/1.0" id="com.phonegap.helloworld" version="1.0.0">
  <name>MyApp</name>
  <description>MyDescription</description>
  <author href="http://phonegap.com" email="support@phonegap.com">PhoneGap Team</author>
  <content src="index.html"/>
  <preference name="permissions" value="none"/>
  <preference name="orientation" value="default"/>
  <preference name="target-device" value="universal"/>
  <preference name="fullscreen" value="true"/>
  <preference name="webviewbounce" value="true"/>
  <preference name="prerendered-icon" value="true"/>
  <preference name="stay-in-webview" value="false"/>
  <preference name="ios-statusbarstyle" value="black-opaque"/>
  <preference name="detect-data-types" value="true"/>
  <preference name="exit-on-suspend" value="false"/>
  <preference name="show-splash-screen-spinner" value="true"/>
  <preference name="auto-hide-splash-screen" value="true"/>
  <preference name="disable-cursor" value="false"/>
  <preference name="android-minSdkVersion" value="14"/>
  <preference name="android-installLocation" value="auto"/>
  <gap:plugin name="org.apache.cordova.battery-status" source="npm"/>
  <gap:plugin name="org.apache.cordova.camera" source="npm"/>
  <gap:plugin name="org.apache.cordova.console" source="npm"/>
  <gap:plugin name="org.apache.cordova.contacts" source="npm"/>
  <gap:plugin name="org.apache.cordova.device" source="npm"/>
  <gap:plugin name="org.apache.cordova.device-motion" source="npm"/>
  <gap:plugin name="org.apache.cordova.device-orientation" source="npm"/>
  <gap:plugin name="org.apache.cordova.dialogs" source="npm"/>
  <gap:plugin name="org.apache.cordova.file" source="npm"/>
  <gap:plugin name="org.apache.cordova.file-transfer" source="npm"/>
  <gap:plugin name="org.apache.cordova.geolocation" source="npm"/>
  <gap:plugin name="org.apache.cordova.globalization" source="npm"/>
  <gap:plugin name="org.apache.cordova.inappbrowser" source="npm"/>
  <gap:plugin name="org.apache.cordova.media" source="npm"/>
  <gap:plugin name="org.apache.cordova.media-capture" source="npm"/>
  <gap:plugin name="org.apache.cordova.network-information" source="npm"/>
  <gap:plugin name="org.apache.cordova.splashscreen" source="npm"/>
  <gap:plugin name="org.apache.cordova.vibration" source="npm"/>
  <icon src="icon.png"/>
  <icon src="www/res/icon/android/icon-36-ldpi.png" gap:platform="android" gap:qualifier="ldpi"/>
  <icon src="www/res/icon/android/icon-48-mdpi.png" gap:platform="android" gap:qualifier="mdpi"/>
  <icon src="www/res/icon/android/icon-72-hdpi.png" gap:platform="android" gap:qualifier="hdpi"/>
  <icon src="www/res/icon/android/icon-96-xhdpi.png" gap:platform="android" gap:qualifier="xhdpi"/>
  <icon src="www/res/icon/blackberry/icon-80.png" gap:platform="blackberry"/>
  <icon src="www/res/icon/blackberry/icon-80.png" gap:platform="blackberry" gap:state="hover"/>
  <icon src="www/res/icon/ios/icon-57.png" gap:platform="ios" width="57" height="57"/>
  <icon src="www/res/icon/ios/icon-72.png" gap:platform="ios" width="72" height="72"/>
  <icon src="www/res/icon/ios/icon-57-2x.png" gap:platform="ios" width="114" height="114"/>
  <icon src="www/res/icon/ios/icon-72-2x.png" gap:platform="ios" width="144" height="144"/>
  <icon src="www/res/icon/webos/icon-64.png" gap:platform="webos"/>
  <icon src="www/res/icon/windows-phone/icon-48.png" gap:platform="winphone"/>
  <icon src="www/res/icon/windows-phone/icon-173-tile.png" gap:platform="winphone" gap:role="background"/>
  <gap:splash src="www/res/screen/android/screen-ldpi-portrait.png" gap:platform="android" gap:qualifier="port-ldpi"/>
  <gap:splash src="www/res/screen/android/screen-mdpi-portrait.png" gap:platform="android" gap:qualifier="port-mdpi"/>
  <gap:splash src="www/res/screen/android/screen-hdpi-portrait.png" gap:platform="android" gap:qualifier="port-hdpi"/>
  <gap:splash src="www/res/screen/android/screen-xhdpi-portrait.png" gap:platform="android" gap:qualifier="port-xhdpi"/>
  <gap:splash src="www/res/screen/blackberry/screen-225.png" gap:platform="blackberry"/>
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait.png" gap:platform="ios" width="320" height="480"/>
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait-2x.png" gap:platform="ios" width="640" height="960"/>
  <gap:splash src="www/res/screen/ios/screen-iphone-portrait-568h-2x.png" gap:platform="ios" width="640" height="1136"/>
  <gap:splash src="www/res/screen/ios/screen-ipad-portrait.png" gap:platform="ios" width="768" height="1024"/>
  <gap:splash src="www/res/screen/ios/screen-ipad-landscape.png" gap:platform="ios" width="1024" height="768"/>
  <gap:splash src="www/res/screen/windows-phone/screen-portrait.jpg" gap:platform="winphone"/>
  <access origin="*"/>
  <access uri="https://*.firebaseio.com" subdomains="true"/>
  <plugin name="cordova-plugin-whitelist" version="1"/>
  <allow-intent href="http://*/*"/>
  <allow-intent href="https://*/*"/>
  <allow-intent href="tel:*"/>
  <allow-intent href="sms:*"/>
  <allow-intent href="mailto:*"/>
  <allow-intent href="geo:*"/>
  <platform name="android">
    <allow-intent href="market:*"/>
  </platform>
  <platform name="ios">
    <allow-intent href="itms:*"/>
    <allow-intent href="itms-apps:*"/>
  </platform>
</widget>

可能是您没有为phonegap编译器设置版本。这是你需要知道的

从您点击的:

  • #6不为编译器设置“phonegap版本”
  • #7不为插件设置“版本”
  • #10不在config.xml中添加新的“白名单”和“白名单插件”参数。
从Phonegap构建论坛:

我想补充一点:在没有宣布的情况下,PGB将默认PGB版本从3.7.0更改为cli-5.2.0。这导致所有没有在config.xml中设置“phonegap版本”的人都会突然需要splashscreen和白名单插件以及配置和html中的额外白名单规范

另外,有几个插件似乎无法使用cli-5.2.0正确构建,从而导致关于“Class***.java”的日志文件错误消息

第六和第七节

对于CLI版本,如果未为平台分配版本,或者在“Phonegap构建”中,如果未在config.xml中设置Phonegap版本,则将获得最新版本。如果你幸运的话,你的程序就像预期的那样工作。如果你运气不好,你会得到一组级联错误

幸运的是,霍莉·辛斯基(Holly Schinsky)写了一篇很好的博客文章来解释这一切:

Cordova/PhoneGap版本混淆

10英镑

这个相对新的要求意味着什么?要访问web上的任何网站或资源,必须使用白名单和白名单插件。如果您使用cordova,此要求将生效-android@4.0.0或者更好;包括cli-5.1.1。但是,如果您的版本在4.0.0之前,比如说3.5.0或3.7.0,那么您将不必添加白名单要求

要明确的是,“白名单”已经存在了一段时间,但是插件和需求是非常新的。正如您所预料的,当添加“白名单”时,事实上的开放访问功能被弃用。或者换一种方式说,事实上的开放存取功能已经计划好并计划取消。此更改标志着删除开放存取功能的一个步骤

此外,内容安全策略(CSP)吸引了众多开发者,因为它的宣传太少了。这个CSP需要进入您使用的每个HTML页面,就像您必须等待“deviceready”一样。文档隐藏在许多最新文档页面的底部

相关链接

Phonegap构建论坛:现在需要白名单


使用桌面应用程序和PhoneGap构建时,我也遇到了同样的问题

问题是在桌面应用程序中首次创建时,
index.html
config.xml
不在根目录中。这是根据法律要求的

因为它们在不同的文件夹中,没有配置,也没有白名单被加载到应用程序中,导致了一堆404


为了解决这个问题,我刚刚将
config.xml
移动到与
index.html
相同的根目录中,并在PhoneGap Build上重建。

对于那些在使用PhoneGap 6.3.1时出现此问题的用户,您应该正确地将URL列为白名单并使用

请继续阅读,了解如何做到这一点


首先,确保已将要打开的URL列为白名单。您可以通过将它们添加到项目根目录下config.xml文件中的
标记、
标记和
允许导航
标记的HREF来完成此操作您需要所有三个标记。类似以下内容:

<?xml version='1.0' encoding='utf-8'?>
<widget id="com.phonegap.helloworld" version="1.0.0"
        xmlns="http://www.w3.org/ns/widgets"
        xmlns:gap="http://phonegap.com/ns/1.0">

    ...

    <access origin="*" />
    <allow-intent href="*" />
    <allow-navigation href="*" />

    ...

</widget>

404错误来自服务器,而不是其他地方。检查你的URL。@JesseMonroy650,URL实际上是正常的。我对问题进行了编辑,将其包括在内。但是你说得对,在某个地方必须有一台服务器,也许是安卓内部的一台服务器在响应?谢谢,我不知道如何使用白名单。通配符应该允许完全访问,对吗?我降到了3.7.0版,删除了白名单插件,现在我没有这些404。不过,我现在确实有一个不同的问题,我有时仍然无法从firebase获得数据。最小化应用程序,然后重新打开它有时会有所帮助。“但我想这是另外一个问题了。”塔鲁拉,很高兴听到你的东西起作用了。在firebase上,这是另一个问题,但我可以帮你。请开始一个新的线程。确保使用
cordova
标签,我会看到它。FWIW,如果您没有看到预期的数据-您可能需要使用
push()
而不是
set()
update()
祝您好运
<?xml version='1.0' encoding='utf-8'?>
<widget id="com.phonegap.helloworld" version="1.0.0"
        xmlns="http://www.w3.org/ns/widgets"
        xmlns:gap="http://phonegap.com/ns/1.0">

    ...

    <access origin="*" />
    <allow-intent href="*" />
    <allow-navigation href="*" />

    ...

</widget>
<script type="text/javascript">
    document.addEventListener('deviceready', function() {
        var url = 'https://www.google.com' // change to whatever you want
        cordova.InAppBrowser.open(url, '_self', 'location=no');
    }, false)
</script>
phonegap run ios --verbose --stack-trace
phonegap run android --verbose --stack-trace