javascript - Puppeteer:将截获的图像请求的 URL 更改为 base64 图像

标签 javascript node.js webdriver puppeteer

我需要拦截 .jpg.gif 图像并将它们替换为 base64 图像。 base64 图像将在屏幕截图中可见。

下面的代码阻止了原始图像的加载,但是 base64 图像并没有加载到原始图像的位置。

如何将原始图像的 src 替换为 base64 图像?


await page.setRequestInterception(true);

page.on('request', request => {

const resourceUrl = request.url().toLowerCase();
const base64Image = '';

if (request.resourceType() == 'image' && resourceUrl.indexOf('.png') === -1 && 
    resourceUrl.indexOf('.svg') === -1 ||
    resourceUrl.indexOf('.jpg') !== -1 ||
    resourceUrl.indexOf('.jpeg') !== -1 ||
    resourceUrl.indexOf('.gif') !== -1) {

        request.respond({
            status: 200,
            contentType: 'image/jpeg',
            headers: {
            // location: base64Image
            // path: base64Image
            url: base64Image
          },
        });

       return; // prevent calling continue twice

}

request.continue();

});


最佳答案

问题

request.respond 不能与 base64 响应一起使用。引自 docs :

NOTE Mocking responses for dataURL requests is not supported.

解决方案

相反,您可以先使用需要从 base64 转换为二进制表示形式的缓冲数据来回答:

const base64Data = 'iVBORw0KGgoAAA...'; // ony the base64 data, without "data:image/png;base64,"
const buffer = Buffer.from(base64Data, 'base64');

// ...

request.respond({
    status: 200,
    contentType: 'image/png',
    body: buffer
});

关于javascript - Puppeteer:将截获的图像请求的 URL 更改为 base64 图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61390748/

相关文章:

node.js - id 未定义(sails.socket.emit)

selenium - WebDriverException 元素必须是用户可编辑的才能清除它

java - 如何为 Selenium WebDriverManager 配置 Log4j?出现log4j错误

javascript - 获取不同列中的隐藏输入[type=hidden]

javascript - 循环对象数组 - TypeError : Cannot read property 'name' of undefined

javascript - Javascript 异步性的背后是什么 - 事件驱动系统

node.js - Node JS 可以为 UI 提供什么吗?

Node.js - 返回 res.status VS res.status

ruby - WebDriver/Ruby 测试报告?

javascript - SetTimeout 递归 (Javascript)