java如何打印ProcessBuilder启动的另一个jar的日志信息


在 Java 中,可以使用 `ProcessBuilder` 启动另一个 `jar` 文件,并获取其输出流来打印日志信息。以下是一个示例代码: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; public class RunJarAndPrintLogs { public static void main(String[] args) { try { // 创建 ProcessBuilder 对象,指定要执行的命令,这里是启动另一个 jar 文件 ProcessBuilder processBuilder = new ProcessBuilder("java", "-jar", "yourJarFile.jar"); // 启动进程 Process process = processBuilder.start(); // 获取进程的输入流,该输入流包含了另一个 jar 文件的输出信息 InputStream inputStream = process.getInputStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream)); String line; // 逐行读取输出信息并打印 while ((line = reader.readLine()) != null) { System.out.println(line); } // 等待进程执行完毕并获取返回值 int exitCode = process.waitFor(); System.out.println("Process exited with code " + exitCode); } catch (IOException | InterruptedException e) { e.printStackTrace(); } } } ``` 代码解释: 1. 创建 `ProcessBuilder` 对象:使用 `ProcessBuilder` 来构建要执行的命令,这里是启动另一个 `jar` 文件。 2. 启动进程:调用 `start()` 方法启动进程。 3. 获取进程的输入流:通过 `getInputStream()` 方法获取进程的输入流,该输入流包含了另一个 `jar` 文件的输出信息。 4. 读取并打印输出信息:使用 `BufferedReader` 逐行读取输入流中的信息,并打印到控制台。 5. 等待进程执行完毕:调用 `waitFor()` 方法等待进程执行完毕,并获取其返回值。 额外注意的逻辑点: 1. 确保 `yourJarFile.jar` 存在于当前工作目录中,或者使用完整的文件路径。 2. 如果另一个 `jar` 文件有错误输出,可以通过 `getErrorStream()` 方法获取错误流,并进行类似的处理。 3. 在处理输入流时,要注意可能出现的 `IOException` 和 `InterruptedException`,需要进行适当的异常处理。 [2025-06-26 15:56:49 | AI写代码神器 | 542点数解答]
- import javax.swing.*; import java.awt.*; import java.awt.datatransfer.clipboard; import java.awt.datatransfer.stringselection; import java.awt.datatransfer.transferable; import java.awt.event.*; import java.io.*; import java.nio.file.files; import java.nio.file.path; import java.nio.file.paths; import java.time.localdatetime; import java.util.hashmap; import java.util.list; import java.util.map; import java.util.random; public class copy { static private final jtextarea textarea = new jtext(1497点数解答 | 2024-08-25 09:40:33)325
- java.lang.illegalargumentexception: invalid character found in method name [0x160x030x010x070x120x010x000x070x0e0x030x03q0xdd0xa1$3e!0x0cp0xa00xa90x9f0xb3o0x880xdc0xa50xf8j0xe10xd50xf80xfd0x800xf40x1c0xa20x020x1b0xa30xec ]. http method names must be tokens at org.apache.coyote.http11.http11inputbuffer.parserequestline(http11inputbuffer.java:419) ~[tomcat-embed-core-9.0.68.jar:9.0.68] at org.apache.coyote.http11.http11processor.service(http11processor.java:271) ~[tomcat-embed-core-9.0.68.jar:9.(321点数解答 | 2024-12-03 17:34:09)303
- dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.driver.(598点数解答 | 2024-10-15 15:48:38)227
- 问题排查:dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.dr(403点数解答 | 2024-10-15 15:48:41)920
- java调用python接口 以下方法 //调用吧ppt转换成图片的py脚本 string pythonscriptpathpng = "ruoyi-edu\\src\\main\\java\\com\\gtvote\\edu\\python\\pptutils.py"; processbuilder pbpng = new processbuilder("python", pythonscriptpathpng, pptfilepath, "png"); process ppng = pbpng.start(); // 读取python脚本的输出 bufferedreader in = new bufferedreader(new inputstreamreader(ppng.getinputstream())); string line = null;(295点数解答 | 2024-06-06 17:07:15)232
- java调用python接口使用了以下方法 string pythonscriptpathpng = "ruoyi-edu\\src\\main\\java\\com\\gtvote\\edu\\python\\pptutils.py"; processbuilder pbpng = new processbuilder("python", pythonscriptpathpng, pptfilepath, "png"); process ppng = pbpng.start(); // 读取python脚本的输出 bufferedreader in = new bufferedreader(new inputstreamreader(ppng.getinputstream())); string line = null; while ((line = in.readline()) != null) { system.out.println(line); } ppng.waitfor(); // 等待 python 脚本执行完成 但是传入的中文会变成乱码(263点数解答 | 2024-06-06 17:07:59)265
- java调用python接口使用的string pythonscriptpathpng = "ruoyi-edu\\src\\main\\java\\com\\gtvote\\edu\\python\\pptutils.py"; processbuilder pbpng = new processbuilder("python", pythonscriptpathpng, pptfilepath, "png"); process ppng = pbpng.start(); // 读取 python 脚本写入的文件 bufferedreader reader = new bufferedreader(new filereader("count.txt")); ppng.waitfor(); 传入的中文是乱码(160点数解答 | 2024-06-06 17:18:39)298
- java调用python接口使用的 string pythonscriptpathpng = "ruoyi-edu\\src\\main\\java\\com\\gtvote\\edu\\python\\pptutils.py"; processbuilder pbpng = new processbuilder("python", pythonscriptpathpng, pptfilepath, "png"); process ppng = pbpng.start(); // 读取 python 脚本写入的文件 bufferedreader reader = new bufferedreader(new filereader("count.txt")); ppng.waitfor(); 传入的中文变成了乱码(344点数解答 | 2024-06-06 17:19:55)412
- java调用python接口使用的 string pythonscriptpathpng = "ruoyi-edu\\src\\main\\java\\com\\gtvote\\edu\\python\\pptutils.py"; processbuilder pbpng = new processbuilder("python", pythonscriptpathpng, pptfilepath, "png"); process ppng = pbpng.start(); // 读取 python 脚本写入的文件 bufferedreader reader = new bufferedreader(new filereader("count.txt")); ppng.waitfor(); java传入的中文值变成了乱码(264点数解答 | 2024-06-06 17:27:09)273
- slf4j: found binding in [jar:file:/d:/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/org/slf4j/impl/staticloggerbinder.class](116点数解答 | 2023-10-07 00:17:42)295
- 1.定义一个抽象类,并设计两个子类继承该抽象类,演示它们的使用。 具体过程为,定义一个类vehicle并将它声明为抽象类。在类vehicle中声明一个infoofwheels方法,返回值为字符串类型。创建两个类car和motorbike从vehicle类继承而来,并在这两个类中实现info0fwheels方法。在car类中,应当返回“四轮车”信息:而在motorbike类中,应当返回“双轮车”信息。创建另一个带main方法的测试类test,在该类中创建car和motorbike的实例,并在控制台分别显示它们返回的信息。(440点数解答 | 2024-06-06 23:18:54)227
- 1.使用pandas库读取数据“data.csv”,展示其前5行数据。 2.对数据进行探索,查看数据类型、缺失值以及数据基本的数值统计详细信息。 3.对数据data日期格式数据做日期转换。 4.查看data**信息统计情况。 (1)查看发布**信息中所在城市city的岗位数量统计信息,统计**信息较多的前五名城市。 (2)保留学历是本科和大专的**信息. 0618220232 061822( (3)修改“district”列,如“高新区”,需要改成“成都-高新区” (4)找出"positionadvantage”职位优势这一列中有“双休”条件的**信息,在所有发布的**信息中的占比,保留2位小数。(5)根据“salary”工资列,新增最低工资和最高工资两列,列名分别设置为“最低工资”和“最高工资”,(如10k-30k,则最低 工资为10k,最高工资为20k) 5.对数据data作统计分析(642点数解答 | 2024-06-30 15:39:49)259