同步請求主要是通過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檔案的請求怎麼過濾還沒查到。