使用 mitmproxy,自定义脚本中,需求是把 flow 传递到其他进程去处理。查了半天好像不支持多进程?反正没查到。
目前研究的方案将 flow 存本地,也就是二进制,进程间传递文件名字,另一个进程去读。
想实现直接传 json 或者对象更好。把 flow 存为 json,har 格式,直接传 json,查了半天,没查到如何从 json 恢复为 flow。
1
momocraft 2019-01-22 21:52:51 +08:00
在 mitmproxy 进程内搞这些方便吗? 你的最终问题是 "用 mitmproxy 拦截连接然后换一个后端服务器" 无法解决的吗?
|
3
484A4B 2019-01-22 23:19:17 +08:00
另一个进程要做什么事情,拿到 json 中的信息还不够吗
|
4
bbbb OP @484A4B 拦截到请求了以后还要做其他事,开线程处理有点慢,开进程就涉及到通讯问题了,原始对象不知道如何传。其实就是想另外一个进程分担点任务。
想的流程是这样,将 flow 转为 json 字符串,还原为之前的 flow 对象,然后延用 mitmproxy 的逻辑。 看了初始化 flow 的方法,是读二进制的。转成 json 应该也能还原回来,不知道这样做的方向对不对。 自己埋头苦干,有点晕了。 |
5
momocraft 2019-01-24 14:14:10 +08:00
要做这么多很难说是“简单”了,不妨再考虑一下你的目的和手段
|
6
bbbb OP |
7
geekgu 2019-10-14 20:25:26 +08:00
楼主最后解决方案如何,mitmproxy 启动的时候类似一个 web 服务器,没有触发点去处理保存下来的 flow,我在想只是只能保存成比较通用的数据形式,然后再用 requests 等库发请求。
|