リモートサーバーに ajax リクエストを行う jquerymobile を使用して、javascript/HTML アプリケーションを開発しています。アプリケーションは Chrome (Web セキュリティを無効にして Chrome を起動する場合のみ) で正常に動作しますが、Android アプリケーション (単純な Web ビュー) の assets/ ディレクトリに埋め込むと、リモート ajax 呼び出しが失敗します。したがって、クロスドメインの問題である可能性があると思います。phonegap にはこの問題がないことは承知していますが、可能であれば phonegap を使用したくありません。問題は、Android WebView アプリケーションでクロス ドメイン保護を無効にするにはどうすればよいかということです。
これはアクティビティ コードです。
public class Moby extends Activity {
@SuppressLint("NewApi")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_moby);
WebView mbrowser = (WebView) findViewById(R.id.webView1); //get the WebView from the layout XML
if (Build.VERSION.SDK_INT >= VERSION_CODES.JELLY_BEAN)
mbrowser.getSettings().setAllowUniversalAccessFromFileURLs(true);
//mbrowser.setWebChromeClient(new WebChromeClient());
mbrowser.setWebViewClient(new WebViewClient());
mbrowser.loadUrl("file:///android_asset/index.html"); //set the HTML
WebSettings settings = mbrowser.getSettings();
settings.setJavaScriptEnabled(true);
}
}
<uses-permission android:name="android.permission.INTERNET" />
そして、私はすでにHTMLページでjquerymobileクロスドメインパラメータを設定しています:
<script src="script/jquery-1.8.2.js"></script>
<script>
$(document).bind("mobileinit", function(){
$.support.cors = true;
$.mobile.allowCrossDomainPages = true;
});
</script>
<script src="script/jquery.mobile-1.2.0.js"></script>