覆盖WebChromeClient和WebViewClient …该死的被隐藏了。
其实我有挖了一下发现了这一点。
WebView webView = (WebView)findViewById(R.id.myWebView);WebChromeClient myWebChromeClient = new WebChromeClient(){ @Override public void getVisitedHistory(ValueCallback<String[]> callback) {// called during webview initialization, original implementation does strictly nothing // and defaults to the native method WebViewCore.nativeProvideVisitedHistory() String[] myUserHistory = getVisitedUrlsFromMyOwnDatabase(userId); callback.onReceivevalue(myUserHistory); } };WebViewClient myWebViewClient = new WebViewClient(){ @Overridepublic void doUpdateVisitedHistory(WebView view, String url, boolean isReload) {// called whenever there is a new link being visited insertIfNotExistVisitedUrlIntoMyOwnDatabaseForUser(userId); super(view, url, isReload);}}webView.setWebViewClient(myWebViewClient);webView.setChromeClient(myWebChromeClient);webView.getSettings().etc(whatever)...我想我“快到了”。这是我管理的部分:到目前为止,它所做的是完全删除CSS历史记录,因此我们已经完成了一半。我无法让浏览器识别“
myUserHistory”中提供的url格式,因此实际上,此代码的唯一功能是完全重置css历史记录,但是当实例化(或创建)WebView时,它仅被调用一次没有检查),因此,要获得真正的多用户体验,您需要在每次登录时重新创建Webview。
我现在的问题是我无法正确加载urlHistory。我的Honeycomb Xoom
Web视图似乎忽略了我的数据。嗯,希望它对您有用。对我来说,只需调用callback.onReceivevalue(new String [] {});
在getVisitedHistory()中就足够了。
编辑:因为好奇,我只花了二十多分钟。此方法是委派给WebChromeClient的方法(mCallbackProxy = WebChromeClient)。
protected void populateVisitedlinks() { ValueCallback callback = new ValueCallback<String[]>() { public void onReceivevalue(String[] value) { sendMessage(EventHub.POPULATE_VISITED_linkS, (Object)value); } }; mCallbackProxy.getVisitedHistory(callback); }它在WebViewCore中受保护,WebViewCore是WebView的私有属性,没有访问器。sendMessage委托给私有的EventHub,WebViewCore充满了私有的本机方法,其中之一似乎是在初始化期间实际调用populateVisitedlinks()方法的方法。
除非Google的某人向WebView添加公共方法来触发重新填充,否则恐怕要实现目标几乎是不可能的。对不起:(
附带说明一下,所有这些本机访问的历史记录处理确实使我感到奇怪:为什么硬件制造商如此关心我们访问了哪些URL?;)



