java shell 切换用户_shell 脚本 指定用户执行命令

#! /bin/bash

rurl=/data/crm/tomcat/webapps/ROOT/upload/

su - gpguser -c "gpg --recipient XXX --output $rurl$1 --encrypt $rurl$2"

if [ -f "$rurl$1" ]; then

echo "$1"

fi

因gpg加密工具是gpguser安装的,所有用java 调用shell脚本时执行gpg命令会报找不到密钥文件的错误。

可以利用”su - 用户 -c“ 来指定用户执行。

调用shell 的java 代码:

/**

* gpg加密

* @return

*/

private boolean encrypt(String outputname,String inputname){

String line = null;

Process process = null;

try {

String[] cmd = {"/bin/bash", "-c", "/data/crm/tomcat/shell/gpgEncryptFile "+outputname+" "+inputname};

process = Runtime.getRuntime().exec(cmd);

int exitValue = process.waitFor();

if (0 != exitValue) {

logger.info("call shell failed. error code is :" + exitValue);

return false;

}

logger.error("call shell code is :" + exitValue);

BufferedReader input = new BufferedReader(new InputStreamReader(process.getInputStream()));

boolean b=false;

while ((line = input.readLine()) != null) {

if(line.equals(outputname)){

b= true;

}

}

input.close();

return b;

} catch (IOException e) {

e.printStackTrace();

} catch (Throwable e) {

logger.error("call shell failed. " + e);

}

return false;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值