天天看點

webkit 中資源請求方法

同步請求主要是通過FrameLoader的

unsigned long loadResourceSynchronously(const ResourceRequest&, ResourceError&, ResourceResponse&, Vector<char>& data);

而這個請求又通過

ResourceHandle::loadResourceSynchronously來送出請求

ResourceHandle::loadResourceSynchronously這個是平台各不相同的函數,由于依賴的的底層網絡庫不一樣,實作也各不相同

qt中是QNetworkReplyHandler來實作的。

而異步的則由

bool ResourceLoader::load(const ResourceRequest& r)

進而通過

DocumentLoader::scheduleArchiveLoad安排一個新的下載下傳活動

 m_pendingSubstituteResources.set(loader, resource);

    deliverSubstituteResourcesAfterDelay();

bool ResourceHandle::start(Frame* frame)

是以如果過濾是url過濾可以在start函數中報錯,return false,那麼就不會向網絡發送請求了。

這些都是一些簡單粗淺的分析,主要是為實作adblock plus做準備。

總之,webkit各種圖檔,腳本同步情況下可以在ResourceHandler:start,異步可以在ResourceHandle:loadResourceSynchronously來過濾

這些過濾隻有url資訊,而沒有伺服器傳回的mime資訊,如果要通過傳回的http頭進行過濾,那麼可以在

SubresourceLoader::didReceiveResponse進行過濾,這是異步的情況下

同步時可以一直等到有響應為止

這些都是資源下載下傳,而一些html檔案的請求怎麼過濾還沒查到。

繼續閱讀