nodejs - puppeteer 无头浏览器截图 JAVA后端调用

nodejs - puppeteer 无头浏览器截图 iframe-CSDN博客

nodejs - puppeteer 无头浏览器截图 - 常规例子-CSDN博客

接上面两个,java后端调用代码

复制代码
public File archiveInterfaceMethod(String url) {
        log.info("jsLocal:{}", jsLocal);
        log.info("fileLocal:{}", fileLocal);
        log.info("redirectlogin:{}", redirectlogin);


        // 从URL中提取 applicationNo 参数
        String applicationNo = extractApplicationNo(url);

        ProcessInstanceDTO proIns = processInstanceMapper.selectByApplicantNo(applicationNo);
        //归档次数,用来做网页截图等待时间用
        Integer archivesCount = 0;
        if (proIns.getArchivesCount() != null) {
            archivesCount = proIns.getArchivesCount();
        }
        log.info("流程归档,Extracted applicationNo: {}", applicationNo);
        // 对URL进行转义处理
        url = url + "&" + redirectlogin;//escapeUrl(url + "&" + redirectlogin);
        log.info("流程归档,URL after escape: {}", url);
        String[] command = {
                "node", jsLocal, "--url", url, "--applicationNo", applicationNo, "--archivesCount", archivesCount.toString()
        };
        log.info("开始执行命令: {}", String.join(" ", command));
        // 确保fileLocal变量正确指向预期的目录
        File directory = new File(fileLocal);
        if (!directory.exists()) {
            // 如果目录不存在,尝试创建它
            if (!directory.mkdirs()) {
                Log.error("无法创建目录: {}", directory);
                return null;
            }
        }
        log.info("获取文件路径: {}", directory.getAbsolutePath());

        // 构建最终生成文件的路径
        File generatedFile = new File(directory, applicationNo + ".png");

        //改成可重复归档
        //if (generatedFile.exists()) {
        //    try {
        //        return processGeneratedFile(generatedFile, applicationNo);
        //   } catch (IOException e) {
        //       log.error("处理生成的文件时发生异常:{}", e.getMessage(), e);
        //        updateInsStatus(applicationNo, 2);
        //        return null;
        //    }
        // }
        ProcessBuilder processBuilder = new ProcessBuilder(command);
        processBuilder.directory(directory);
        // 将错误输出重定向到标准输出流
        processBuilder.redirectErrorStream(true);

        // 如果文件不存在,则执行命令生成文件
        Process process = null;
        try {
            process = processBuilder.start();  // 使用ProcessBuilder启动进程
            try (BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()))) {
                String line;
                while ((line = reader.readLine()) != null) {
                    // 这将包括标准输出和错误输出
                    log.info("进程输出: {}", line);
                }
            }
            int exitCode = process.waitFor();
            log.info("进程退出码: " + exitCode);

            if (exitCode == 0) {
                return processGeneratedFile(generatedFile, applicationNo);
            } else {
                log.warn("进程失败,退出码: " + exitCode);
             
            }
        } catch (IOException | InterruptedException e) {
            log.error("执行进程时发生异常", e);
          
            // 处理中断
            Thread.currentThread().interrupt();
        }
        return generatedFile;
    }
相关推荐
程序员爱钓鱼7 分钟前
Go语言泛型-泛型约束与实践
前端·后端·go
前端小巷子8 分钟前
web从输入网址到页面加载完成
前端·面试·浏览器
江城开朗的豌豆9 分钟前
Vue路由动态生成秘籍:让你的链接'活'起来!
前端·javascript·vue.js
晓得迷路了9 分钟前
栗子前端技术周刊第 88 期 - Apache ECharts 6.0 beta、Deno 2.4、Astro 5.11...
前端·javascript·echarts
这里有鱼汤14 分钟前
“对象”?对象你个头!——Python世界观彻底崩塌的一天
后端·python
江城开朗的豌豆15 分钟前
在写vue公用组件的时候,怎么提高可配置性
前端·javascript·vue.js
江城开朗的豌豆15 分钟前
Vue路由跳转的N种姿势,总有一种适合你!
前端·javascript·vue.js
江城开朗的豌豆16 分钟前
Vue路由玩法大揭秘:三种路由模式你Pick谁?
前端·javascript·vue.js
江城开朗的豌豆17 分钟前
Vue路由守卫全攻略:给页面访问装上'安检门'
前端·javascript·vue.js
RainbowSea17 分钟前
跨域问题(Allow CORS)解决(3 种方法)
java·spring boot·后端