_signature、 __ac_nonce、 __ac_signature参数
开始水
接口中有参数 _signature 参数

直接全局搜索这个参数,会在一个 index-*.js 中搜索到, 虽然 captcha.js 中也有,不过没用

在文件中找到该字符串位置,打断点,调试。

继续下一步,调试会跳转到 acrawler.js 文件中.

acrawler.js 文件

下一步直接将 js 文件拿出来, 执行。

1、简化 js, 删除一些没有用的东西

参数后改为空列表即可
2、node 中 window 为 global

定义
var window = global;
继续执行,缺啥补啥(调试打印 Z[S],就可以知道缺啥了 )


window.location = params.location;
window.navigator = params.navigator;
然后就可以出来短的了

有个问题加了下面的代码就会报错
window.byted_acrawler && window.byted_acrawler.init({
aid: 24,
dfp: !0
});

注释掉就可以,不知道啥原因。
长的 _signature 需要加 cookie,把 cookie 放进去就 ok 了。放在主要加密函数的后面,放在前面没用。不生效

结果:

测试一下

请求 api/pc/feed 接口时,需要在前面加上 toutiao 进行加密。
cookie 中的 __ac_nonce __ac_signature
直接请求详情,不携带 cookie, 会响应 cookie __ac_nonce


通过 __ac_nonce 生成 __ac_signature
直接调用上面的方法即可
function f2(__ac_nonce){
ac_signature = window.byted_acrawler.sign("", __ac_nonce);
return ac_signature
}

评论
