URL类型分析功能。
31. WebBackForwardList.java: 该对象包含WebView对象中显示的历史数据。 32. WebBackForwardListClient.java :浏览历史处理的客户接口类,所有需要接收浏览历史改变的类都需要实现该接口。
33. WebChromeClient.java: Chrome客户基类,Chrome客户对象在浏览器文档标题、进度条、图标改变时候会得到通知。
34. WebHistoryItem.java: 该对象用于保存一条网页历史数据。
35. WebIconDataBase.java: 图表数据库管理对象,所有的WebView均请求相同的图标数据库对象。
36. WebSettings.java: WebView的管理设置数据,该对象数据是通过JNI接口从底层获取。
37. WebSyncManager.java: 数据同步对象,用于RAM数据和FLASH数据的同步操作。 38. WebView.java: Web视图对象,用于基本的网页数据载入、显示等UI操作。 39. WebViewClient.java: Web视图客户对象,在Web视图中有事件产生时,该对象可以获得通知。
40. WebViewCore.java: 该对象对WebCore库进行封装,将UI线程中的数据请求发送给WebCore处理,并通过CallbackProxy的方式,通过消息通知UI线程数据处理结果。
41. WebViewDatabase.java: 该对象使用SQLiteDatabase为WebCore模块提供数据存取操作。
6.2 Java层框架
6.2.1 主要类描述
1. WebView
WebView类是WebKit模块Java层的视图类,所有需要使用Web浏览功能的Android应用程序都要创建该视图对象显示和处理请求的网络资源。目前,WebKit模块支持HTTP、HTTPS、FTP以及javascript请求。WebView作为应用程序的UI接口,为用户提供了一系列的网页浏览、用户交互接口,客户程序通过这些接口访问WebKit核心代码。 2. WebViewDatabase
WebViewDatabase是WebKit模块中针对SQLiteDatabase对象的封装,用于存储和获取运行时浏览器保存的缓冲数据、历史访问数据、浏览器配置数据等。该对象是一个单实例对象,通过getInstance方法获取WebViewDatabase的实例。WebViewDatabase是WebKit模块中的内部对象,仅供WebKit框架内部使用。 3. WebViewCore
WebViewCore类是Java层与C层WebKit核心库的交互类,客户程序调用WebView的网页浏览相关操作会转发给BrowserFrame对象。当WebKit核心库完成实际的数据分析和处理后会回调WebViweCore中定义的一系列JNI接口,这些接口会通过CallbackProxy将相关事件通知相应的UI对象。 4. CallbackProxy
CallbackProxy是一个代理类,用于UI线程和WebCore线程交互。该类定义了一系列与用户相关的通知方法,当WebCore完成相应的数据处理,则会调用CallbackProxy类中对应的方法,这些方法通过消息方式间接调用相应处理对象的处理方法。 5. BrowserFrame
BrowserFrame类负责URL资源的载入、访问历史的维护、数据缓存等操作,该类会通过JNI接口直接与WebKit C层库交互。 6. JWebCoreJavaBridge
该类为Java层WebKit代码提供与C层WebKit核心部分的Timer和Cookies操作相关的方法。
7. DownloadManagerCore
下载管理核心类,该类负责管理网络资源下载,所有的Web下载操作均有该类同一管理。该类实例运行在WebKit线程当中,与UI线程的交互是通过调用CallbackProxy对象中相应的方法完成。 8. WebSettings
该对象描述了WEB浏览器访问相关的用户配置信息。 9. DownloadListener
下载侦听接口,如果客户代码实现该接口,则在下载开始、失败、挂起、完成等情况下,DownloadManagerCore对象会调用客户代码中实现的DownloadListener方法。 10. WebBackForwardList
WebBackForwarList对象维护着用户访问历史记录,该类为客户程序提供操作访问浏览
器历史数据的相关方法。 11. WebViewClient
WebViewClient类定义了一系列事件方法,如果Android应用程序设置了WebViewClient派生对象,则在页面载入、资源载入、页面访问错误等情况发生时,该派生对象的相应方法会被调用。
12. WebBackForwardListClient
WebBackForwardListClient对象定义了对访问历史操作时可能产生的事件接口,当用户实现了该接口,则在操作访问历史时(访问历史移除、访问历史清空等)用户会得到通知。 13. WebChromeClient
WebChromeClient类定义了与浏览窗口修饰相关的事件。例如接收到Title、接收到Icon、进度变化时,WebChromeClient的相应方法会被调用。
6.2.2 数据载入器的设计
WebKit模块的Java部分框架中使用数据载入器来加载相应类型的数据,目前有CacheLoader、DataLoader以及FileLoader三类载入器,他们分别用于处理缓存数据、内存据,以及文件数据的载入操作。Java层(WebKit模块)所有的载入器都从StreamLoader继承(其父类为Handler),由于StreamLoader类的基类为Handler类,因此在构造载入器时,会开启一个事件处理线程,该线程负责实际的数据载入操作,而请求线程通过消息的方式驱动数据的载入。下图是数据载入器相关类的类图结构:
StreamLoader类定义了4个不同的消息(MSG_STATUS、MSG_HEADERS、MSG_DATA、MSG_END),分别表示发送状态消息、发送消息头消息、发送数据消息以及数据发送完毕消息。该类提供了2个抽象保护方法以及一个共有方法:setupStreamAndSendStatus保护方法主要是用于构造与通信协议相关的数据流,以及向LoadListener发送状态;buildHeaders方法是向子类提供构造特定协议消息头功能,所有载入器只有一个共有方法(load),因此当需要载入数据时,调用该方法即可。与数据载入流程相关的类还有LoaderListener以及BrowserFrame,当数据载入事件发生时,WebKit C库会更新载入进度,并且会通知BrowserFrame,BroserFrame接收到进度条变更事件后会通过CallbackProxy对象,通知View类进度条数据变更。
6.3 C层框架
略过。
6.4 WebView操作分析
6.4.1 WebKit模块初始化
Android SDK中提供了WebView类,该类为客户提供客户化浏览显示的功能,如果客户
需要加入浏览器的支持,可将该类的实例或者派生类的实例作为视图,调用Activity类的setContentView显示给用户。当客户代码中生成第一次生成WebView对象时,会初始化WebKit库(包括Java层和C层两个部分),之后用户可以操作WebView对象完成网络或者本地资源的访问。WebView对象的生成主要涉及3个类CallbackProxy、WebViewCore以及WebViewDatabase。其中CallbackProxy对象为WebKit模块中UI线程和WebKit类库提供交互功能,WebViewCore是WebKit的核心层,负责与C层交互以及WebKit模块C层类库初始化,而WebViewDatabase为WebKit模块运行时缓存、数据存储提供支持。WebKit模块初始化流程如下:
6.4.1.1 WebView实例化
1. 创建CallbackProxy对象 2. 创建WebViewCore对象
3. 调用System.loadLibrary载入webcore相关类库(C层) 4. 如果是第一次初始化WebViewCore对象,创建WebCoreTherad线程 5. 创建EventHub对象,处理WebViewCore事件 6. 获取WebIconDatabase对象实例 7. 向WebCoreThread发送初始化消息
6.4.1.2 获取WebViewDatabase实例
1. 调用System.loadLibrary方法载入webcore相关类库,该过程由Dalvik虚拟机完成,它会从动态链接库目录中寻找libWebCore.so类库,载入到内存中,并且调用WebKit初始化模块的JNI_OnLoad方法。WebKit模块的JNI_OnLoad方法中完成了如下初始化操作:
a) 初始化framebridge[register_android_webcore_framebridge]
初始化gFrameAndroidField静态变量,以及注册BrowserFrame类中的本地方法表。
b) 初始化javabridge[register_android_webcore_javabridge]
初始化gJavaBridge.mObject对象,以及注册JWebCoreJavaBridge类中的本地方法
c) 初始化资源loader[register_android_webcore_resource_loader] 初始化gResourceLoader静态变量,以及注册LoadListener类的本地方法
d) 初始化webviewcore[register_android_webkit_webviewcore]
初始化gWebCoreViewImplField静态变量,以及注册WebViewCore类的本地方法
e) 初始化webhistory[register_android_webkit_webhistory]