问题描述
我正在编写一个调用其他程序的Java程序,其中一些程序需要以root用户身份运行。
我考虑过以root用户身份运行整个JAR,但这听起来像是存在安全风险,我宁愿只以root用户身份运行某些程序。
当前,我在命令sudo -S pacman <...>
上创建一个ProcessBuilder并使用其getStandardOutput方法实例化Writer。 (-S表示“从标准输入中读取”。)
然后,我使用该读取器注入密码并刷新它,到目前为止一切正常。
但是,当pacman期望输入时(例如,在询问交互式“是/否”问题时),并且我尝试再次写入Writer时,由于流关闭,它失败并出现IOException。
我如何获得可以实际将字符发送到pacman
且其他程序以root身份运行的Writer?
该程序只能在UNIX(Arch Linux,Debian,MacOS以及Window的WSL)上运行,因此特定于UNIX的解决方案很好,如果可能的话,我宁愿不使用JNI,因为它需要多次编译,但是如果那是唯一的解决方案,那很好。只要还可以以root用户身份运行,我也可以用其他方式替换sudo。
解决方法
如果这不是一项长期服务,则可以运行sudo -v
以使sudo
缓存凭据,然后在Java程序中调用sudo
,而无需输入密码。如果您通过以下方式调用Java程序,则效果最佳:
#!/bin/bash
sudo -v
java -jar ...