首页 > 其他分享 >mitmproxy 抓包神器-5.mock功能使用

mitmproxy 抓包神器-5.mock功能使用

时间:2023-02-14 21:47:56浏览次数:43  
标签:返回 http request flow mitmproxy 抓包 response mock

前言

mitmproxy 可以抓到请求后重定向到另外一个地址,也可以自定义返回的 response 内容

重定向请求

在实际工作中,调试接口的时候,有时候需要把线上的接口地址替换成本地地址去调试接口,可以用转发域名的方式

"""Redirect HTTP requests to another server."""
from mitmproxy import http


def request(flow: http.HTTPFlow) -> None:
    # pretty_host takes the "Host" header of the request into account,
    # which is useful in transparent mode where we usually only have the IP
    # otherwise.
    if flow.request.pretty_host == "example.org":
        flow.request.host = "mitmproxy.org"

mock 返回指定数据

抓到对应接口,也可以指定返回 response 内容

"""Send a reply from the proxy without sending any data to the remote server."""
from mitmproxy import http


def request(flow: http.HTTPFlow) -> None:
    if flow.request.pretty_url == "http://example.com/path":
        flow.response = http.Response.make(
            200,  # (optional) status code
            b"Hello World",  # (optional) content
            {"Content-Type": "text/html"},  # (optional) headers
        )

也可以使用response函数重写返回

from mitmproxy import http
# 作者:上海-悠悠 微信号:283340479

def response(flow: http.HTTPFlow):
    if "http://httpbin.org/get" in flow.request.url:
        # 状态码
        print(f'状态码: {flow.response.status_code}')
        # 返回内容,已解码
        print(f'返回内容: {flow.response.text}')
        # 返回内容, bytes类型
        print(f'返回内容bytes类型: {flow.response.content}')
        # 取得响应的文本
        print(f'应的文本: {flow.response.get_text}')
        # 修改响应 的文本
        flow.response.set_text('{"code": 0, "message": "success"}')

标签:返回,http,request,flow,mitmproxy,抓包,response,mock
From: https://www.cnblogs.com/yoyoketang/p/17119160.html

相关文章

  • mitmproxy 抓包神器-4.拦截请求实现篡改请求和返回数据
    前言fiddler工具有个打断点功能非常实用,可以实现拦截请求,篡改请求和返回的数据。mitmproxy可以用python代码写插件的方式实现拦截请求,篡改请求和返回数据。fiddler打......
  • mitmproxy 抓包神器-3.抓取网站数据或图片
    前言Mitmproxy是一个免费的开源交互式的HTTPS代理。MITM即中间人攻击(Man-in-the-MiddleAttack)。mitmproxy工具有以下三个组件构成mitmproxy是具有SSL/TLS功能的交......
  • 学习笔记jira项目4-对比常见mock方案
    第一种方式第二种 3接口管理工具  4本地node服务器  ......
  • Python黑客编程之scapy抓包发包
    目的用scapy进行二层发包,实现arp欺骗,并抓取本地网卡的数据报,来截获目标机器和网关之间的流量scapy介绍scapy是python中一个可用于网络嗅探的非常强大的第三方库,可以......
  • wireshark抓包教程详解
    https://blog.csdn.net/lixinkuan328/article/details/122985439 1、打开wireshark 2、选择菜单栏上Capture->Option,勾选WLAN网卡(这里需要根据各自电脑网卡使用情......
  • 用了10年Postman,没想到它的Mock功能也如此强大
    最近在做一些app,前后端分离的开发模式是必须的。一直用的pythonflask做后端的快速POC,python本身就是一门胶水语言,开发起来方便快捷,而flask又是一个极简的webserver框架(比......
  • (转)Fiddler抓包工具之详细使用步骤(超详细)
    原文:https://blog.csdn.net/qq_42961150/article/details/122545929Fiddler抓包工具,前端开发中进行调试的时候,可以作为辅助工具进行数据模拟。下面详细的写下使用步骤。......
  • Python mock
    官方链接:https://docs.python.org/zh-cn/3/library/unittest.mock-examples.htmlMock备注:常用的有两个mock类:Mock和MagicMock,在多数示例中,Mock与MagicMock两个类......
  • DHCP-ack抓包
    No.TimeSourceDestinationProtocolInfo20.013341192.168.137.1255.255.255.255DHCPDHCPACK-TransactionID0xf6d7ec89Fra......
  • dhcp Request抓包
    No.TimeSourceDestinationProtocolInfo7099.872742192.168.137.199192.168.137.1DHCPDHCPRequest-TransactionID0x5f2d512aFra......