近期做一个项目,Cordova遇到部分机型尤其是华为手机遇到ajax执行时直接进入error方法,导致很多逻辑无法执行的问题。
解决方法一:
#需要设置权限和文件
#第一
platforms->android->app->src->main->res->xml
#创建xml文件
network_security_config.xml
#编辑内容
<?xml version="1.0" encoding="utf-8"?> <network-security-config> <base-config cleartextTrafficPermitted="true" /> </network-security-config>
#第二
#打开编辑文件
platforms->android->app->src->main 下面 AndroidManifest.xml
#内容增加
<?xml version='1.0' encoding='utf-8'?>
<manifest android:hardwareAccelerated="true" android:versionCode="10000" android:versionName="1.0.0" package="io.cordova.hellocordova" xmlns:android="http://schemas.android.com/apk/res/android">
<supports-screens android:anyDensity="true" android:largeScreens="true" android:normalScreens="true" android:resizeable="true" android:smallScreens="true" android:xlargeScreens="true" />
<uses-permission android:name="android.permission.INTERNET" />
<application
android:hardwareAccelerated="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
#增加的新内容
android:networkSecurityConfig="@xml/network_security_config"
android:supportsRtl="true">
<activity
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale|smallestScreenSize|screenLayout|uiMode"
android:label="@string/activity_name"
android:launchMode="singleTop"
android:name="MainActivity"
android:theme="@android:style/Theme.DeviceDefault.NoActionBar"
android:windowSoftInputMode="adjustResize">
<intent-filter android:label="@string/launcher_name">
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
</manifest>
以上两处修改以后重新生成 android 安装包,即可解决ajax失败问题。
解决方法二:
Cordova 自带的demo的meta标记限制了行内javascript和http请求的域名范围。如下改为无限制
<!--
<meta http-equiv="Content-Security-Policy" content="default-src 'self' 'unsafe-inline' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *">
-->
<meta http-equiv="Content-Security-Policy" content="default-src *; style-src 'self' 'unsafe-inline'; script-src 'self' 'unsafe-inline' 'unsafe-eval'">
config.xml 需要设置为 <access origin="*" /> 或者自己的服务器域名
XCODE更新了网络请求的安全限制,默认强制要求https了。解决办法是在 plist 文件里添加自定义的配置
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>