前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >19.2.16日报:script的文本解码流程

19.2.16日报:script的文本解码流程

作者头像
龙泉寺扫地僧
发布2019-03-06 09:57:17
7000
发布2019-03-06 09:57:17
举报
文章被收录于专栏:盟主来了盟主来了

起源是https://zhitongche.taobao.com/ 有个url(g.alicdn.com/kissy/k/1.4.4/seed.js)老是解码错误。

原因是阿里的垃圾程序员,在url里明明写着是GBK的页面,js却是utf-8编码。

blink会在下面堆栈里预加载js:

blink::TextResource::TextResource(const blink::Resou blink::ScriptResource::ScriptResource(const blink::R blink::ScriptResource::ScriptResourceFactory::create blink::ResourceFetcher::createResourceForLoading(bli blink::ResourceFetcher::requestResource(blink::Fetch blink::ScriptResource::fetch(blink::FetchRequest & r blink::DocumentLoader::startPreload(blink::Resource: blink::HTMLResourcePreloader::preload(WTF::PassOwnPt blink::ResourcePreloader::takeAndPreload(WTF::Vector blink::HTMLDocumentParser::processParsedChunkFromBac blink::HTMLDocumentParser::pumpPendingSpeculations() blink::HTMLDocumentParser::resumeParsingAfterYield() blink::HTMLParserScheduler::continueParsing() 行 169

然后会在

node.dll!blink::ScriptLoader::fetchScript(const WTF::String  node.dll!blink::ScriptLoader::prepareScript(const WTF::TextP node.dll!blink::HTMLScriptRunner::runScript(blink::Element * node.dll!blink::HTMLScriptRunner::execute(WTF::RawPtr<blink: node.dll!blink::HTMLDocumentParser::runScriptsForPausedTreeB node.dll!blink::HTMLDocumentParser::processParsedChunkFromBa node.dll!blink::HTMLDocumentParser::pumpPendingSpeculations( node.dll!blink::HTMLDocumentParser::resumeParsingAfterYield( node.dll!blink::HTMLParserScheduler::continueParsing() 行 16 node.dll!WTF::FunctionWrapper<void (__thiscall blink::HTMLPa

里真正去加载js。但会在ResourceFetcher::requestResource里,因为第一次预加载了,所以只会取出request去用。

我打算在这两个地方做个hook,把这个url强制改成utf-8解码。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年02月17日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档