WebViewで特定のURLを呼び出したい。このページは、ユーザーがすでにログインした後にのみ呼び出すことができます。ログイン呼び出しを実行するには、AsyncHttpClientライブラリを使用します。ログインに成功した後、WebViewを介してurlをロードしても、適切なヘッダーesp cookieが認識されないようです。私の疑いは、HttpClientとWebViewのHttpClientの間でCookieが正しく同期されていないことです。なぜだろうか? 。ここに私が使用する方法がありますWebView
final WebView webView = (WebView) content.findViewById(R.id.web_travel_advisory);
String url = "http://mydomainurl.com/get_data_after_login";
webView.setWebViewClient(new WebViewClient());
CookieSyncManager.createInstance(getActivity());
CookieSyncManager.getInstance().startSync();
CookieManager.getInstance().setAcceptCookie(true);
webView.getSettings().setJavaScriptEnabled(true);
webView.loadUrl(url);
助けを感謝します。
ああ、数時間後、私はついにそれが機能することを理解しました。最初に CookieSyncManager は、ドキュメントによると、api 21以降のAndroidの以降のバージョンでは非推奨です。そのため、もう使用しないことにしました。次に、 CookieManager を使用してWebViewのCookieを保存します。
最終コード
CookieManager cookieManager = CookieManager.getInstance();
cookieManager.setAcceptCookie(true);
List<Cookie> cookies = WSHelper.cookieStore.getCookies();
cookieManager.removeAllCookie();
if (cookies != null) {
for (Cookie cookie : cookies) {
if (cookie.getName().contains("session")){
String cookieString = cookie.getName() + "=" + cookie.getValue() + "; Domain=" + cookie.getDomain();
cookieManager.setCookie(cookie.getDomain(), cookieString);
Log.d("CookieUrl",cookieString + " ");
}
}
}
webView.loadUrl(url);
ソリューションの主な変更点は、明示的なドメインの代わりにcookie.getDomain()を使用することです。
cookieManager.setCookie(cookie.getDomain(), cookieString);
いくつかの変更が私のために働いた後、このコードを試してください:
public class WebViewActivity extends Activity{
private SharedPreferences mPreferences;
String token="";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.webviewpage);
mPreferences = getSharedPreferences("CurrentUser", MODE_PRIVATE);
}
public void LaunchWebView(View view) {
WebView myWebView = (WebView) findViewById(R.id.myWebView);
myWebView.getSettings().setJavaScriptEnabled(true);
myWebView.getSettings().setSaveFormData(false);
CookieSyncManager.createInstance(this);
CookieSyncManager.getInstance().startSync();
CookieManager cookieManager = CookieManager.getInstance();
cookieManager.setAcceptCookie(true);
CookieManager.getInstance().setAcceptThirdPartyCookies(myWebView, true);
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
String token2= mPreferences.getString("auth_token","");
HashMap<String, String> map = new HashMap<String, String>();
map.put("x-auth-token", token);
myWebView.getSettings().setAppCacheEnabled(true);
myWebView.setWebViewClient(new WebViewClient() {
public boolean shouldOverrideUrlLoading(WebView view,String url) {
view.loadUrl(url);
return true;
}
});
myWebView.loadUrl("YOUR_URL", map);
}
}
私の問題は少し異なっていましたが、@ Tixeonからの回答はそれを解決するための鍵をくれました。 Cookieを作成してWebViewリクエストに追加していましたが、AndroidがCookieをオーバーライドして独自のCookieを送信していたことを発見しました。まず、すべてのCookieを配列を作成してから、独自のCookieを作成します。これがサンプルコードです。
// Note that my project has minSdkVersion 21, so I can directly use methods only available in Lollipop
private fun loadUrlInWebView(url: String) {
webView.settings.apply {
builtInZoomControls = false
javaScriptEnabled = true
useWideViewPort = true
loadWithOverviewMode = true
setSupportMultipleWindows(false)
}
CookieManager.getInstance().apply {
setAcceptThirdPartyCookies(webView, true) // My minSdkVersion is 21
removeAllCookies { value ->
Log.d("Cookies", "Removed all cookies from CookieManager")
}
}
webView.apply {
isVerticalScrollBarEnabled = true
isHorizontalScrollBarEnabled = true
loadUrl(
url,
mutableMapOf(
"Cookie" to "ThisIsMyCookieWithMyValues",
"Accept" to "*/*",
"Accept-Encoding" to "gzip, deflate",
"Cache-Control" to "no-cache",
"Content-type" to "application/x-www-form-urlencoded"
)
)
}
}
これで、リクエストにAndroidが提供するデフォルトのCookieではなくCookieが含まれるようになり、WebViewでのセッションが機能します。これが誰かの助けになることを願って