Puppeteer:将截获的图像请求的 URL 更改为 Base64 图像

tur*_*_34 4 javascript webdriver node.js puppeteer

我需要截取.jpg.gif图像并将其替换为 Base64 图像。然后,base64 图像将在屏幕截图中可见。

以下代码阻止加载原始图像,但不会在原始图像的位置加载 Base64 图像。

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


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();

});


Run Code Online (Sandbox Code Playgroud)

Tho*_*orf 5

问题

request.respond不能与响应一起使用base64。引用文档

注意不支持 dataURL 请求的模拟响应。

解决方案

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
});
Run Code Online (Sandbox Code Playgroud)