0

我创建了一个经过身份验证的 webview,它允许用户使用关键字搜索以在 webview 中显示内容。但是,webview 在每个页面上都设置了身份验证,因此如果我在 webview 中导航,我必须再次进行身份验证,在我的情况下,我使用 sharedprefs 管理器来记住登录名和密码,从而自动对其进行身份验证。但是,每次我导航到 web 视图中的不同页面时,它都会弹出一个屏幕,询问“您已注销,因为您登录到另一台设备 [取消|登录]”如何阻止此警报消息显示我经过身份验证的 webview,这显然是由于身份验证而发生的。我正在使用 cookie,但我不确定我是否以正确的方式使用它们。这是我的代码的一个潜行高峰:

 public class MyWebViewClient extends WebViewClient {
        private String loginCookie;
        public MyWebViewClient(AnswersWebViewFragment answersWebViewFragment, WebView webview) {
            super();
        }
        @Override
        public void onPageStarted(WebView view, String url, Bitmap favicon) {
            view.setVisibility(View.VISIBLE);

        }

        @Override
        public void onPageFinished(WebView view, String url) {
            view.setVisibility(View.VISIBLE);
            CookieManager cookieManager = CookieManager.getInstance();
            cookieManager.setCookie(url, loginCookie);
            final Animation fade = new AlphaAnimation(0.0f, 1.0f);
            fade.setDuration(200);
            view.startAnimation(fade);
            view.setVisibility(View.VISIBLE);
            progressBar.setVisibility(View.GONE);

        }
        @Override
        public void onReceivedError( WebView view, int errorCode, String description, String failingUrl ) {
            Toast.makeText(view.getContext(), "Authentication Error", Toast.LENGTH_LONG).show();
        }

        @Override
        public void onLoadResource( WebView view, String url ){
            //CookieManager cookieManager = CookieManager.getInstance();
            //loginCookie = cookieManager.getCookie(url);
        }

        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {

                return super.shouldOverrideUrlLoading(view, url);


        }
        @Override
        public void onReceivedSslError( WebView view, SslErrorHandler handler, SslError error ) {
            handler.proceed();
        }

        @Override
        public void onReceivedHttpAuthRequest( WebView view, final HttpAuthHandler handler, final String host, final String realm ){


                handler.proceed(USERNAME,PASSWORD);

    }


    }

在其他课程中,这是我存储用户名和传递的方式:

SharedPreferencesManager manager = SharedPreferencesManager.getInstance();
    private static  String URL;
    private final  String USERNAME = manager.getLoginUsername();
    private final  String PASSWORD = manager.getDecryptedLoginPassword();

知道怎么做吗?

4

1 回答 1

0

注释掉搜索页面中验证登录的代码

于 2013-09-25T10:50:20.503 回答