java代码操作linux

import java.io.Serializable;

/**
 * shell脚本执行结果
 * 先通过getSuccess方法判断命令是否执行成功
 * 执行成功的时候采用result作为返回值
 * 执行不成功采用errorOut作为返回值
 */
public class ShellResult implements Serializable {

    private static final long serialVersionUID = -110281463872334425L;

    /** 脚本输出结果 */
    private String result;
    /** 异常输出结果 */
    private String errorMsg;
    /** 回话退出状态 */
    private int exitStatus;

    public ShellResult() {
    }

    public ShellResult(String result, String errorOut, int exitStatus) {
        this.result = result.trim();
        this.errorMsg = errorOut.trim();
        this.exitStatus = exitStatus;
    }

    public String getResult() {
        return result;
    }

    public void setResult(String result) {
        this.result = result.trim();
    }

    public String getErrorMsg() {
        return errorMsg;
    }

    public void setErrorMsg(String errorMsg) {
        this.errorMsg = errorMsg.trim();
    }

    public int getExitStatus() {
        return exitStatus;
    }

    public void setExitStatus(int exitStatus) {
        this.exitStatus = exitStatus;
    }

    /** 是否成功关闭会话 */
    public boolean getSuccess() {
        return this.exitStatus == 0;
    }
}
import ch.ethz.ssh2.ChannelCondition;
import ch.ethz.ssh2.Connection;
import ch.ethz.ssh2.Session;
import ch.ethz.ssh2.StreamGobbler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;

public class GanymedUtils {
    private static final Logger logger = LoggerFactory.getLogger(GanymedUtils.class);

    /** 超时时间 */
    private static final int TIME_OUT = 1000 * 5 * 60;

    /**
     * 登录远端服务器
     *
     * @param ip       主机地址
     * @param userName 用户名
     * @param password 密码
     * @return 当前的连接
     * @throws IOException
     */
    public static Connection login(String ip, String userName, String password) throws IOException {
        Connection connection = new Connection(ip);
        connection.connect();
        return connection.authenticateWithPassword(userName, password) ? connection : null;
    }

    /**
     * 执行一个命令
     *
     * @param ip       主机ip
     * @param userName 用户名
     * @param password 密码
     * @param scripts  需要执行的脚本
     * @param charset  字符编码
     * @return ShellResult类
     * @throws Exception
     */
    public static ShellResult exec(String ip, String userName, String password, String scripts, Charset charset) throws IOException {

        Connection connection = login(ip, userName, password);
        if (connection == null) {
            throw new RuntimeException("登录远程服务器出现异常,ip为:" + ip);
        }

        // Open a new {@link Session} on this connection
        Session session = connection.openSession();

        try (
                InputStream stdOut = new StreamGobbler(session.getStdout());
                InputStream stdErr = new StreamGobbler(session.getStderr())
        ) {
            // Execute a command on the remote machine.
            //session.execCommand(scripts);//不太优秀

            session.requestPTY("bash");
            session.startShell();
            // 准备输入命令
            PrintWriter out = new PrintWriter(session.getStdin());
            // 输入待执行命令
            out.println(scripts);
            out.println("pwd");
            out.println("exit");//目前来一定要执行 
            // 6. 关闭输入流
            out.close();
            // 7. 等待,除非1.连接关闭;2.输出数据传送完毕;3.进程状态为退出;4.超时
            session.waitForCondition(ChannelCondition.CLOSED | ChannelCondition.EOF | ChannelCondition.EXIT_STATUS , 30000);


 //           InputStream stderr = new StreamGobbler(session.getStderr());
 //           InputStream in = new StreamGobbler(session.getStdout());

            String outStr = processStream(stdOut, charset.name());
            String outErr = processStream(stdErr, charset.name());
            session.waitForCondition(ChannelCondition.EXIT_STATUS, TIME_OUT);
            int exitStatus = session.getExitStatus();
            return new ShellResult(outStr, outErr, exitStatus);
        }
    }

    /**
     * 执行脚本
     *
     * @param in      输入流
     * @param charset 字符编码
     * @return
     * @throws IOException
     */
    private static String processStream(InputStream in, String charset) throws IOException {
        byte[] buf = new byte[1024];
        StringBuilder sb = new StringBuilder();
        while (in.read(buf) != -1) {
            sb.append(new String(buf, charset));
        }
        return sb.toString();
    }
	//ip:"000.00.00.00"
	//username:"username"
	//password:"password"
    public static void main(String[] args) {
        String ls = "cd /home/";
        try {
            ShellResult status = exec("000.00.00.00", "username", "password", ls, StandardCharsets.UTF_8);
            System.out.println(">>>>>>Result>>>>>>>");
            System.out.println(status.getResult());

            //ShellResult status = exec("192.168.183.145", "root", "sunway123", "lsof -i:8002", StandardCharsets.UTF_8);
            /*System.out.println(">>>>>>Result>>>>>>>");
            System.out.println(status.getResult());
            String pidStr = status.getResult().split("\n")[1];
            String value[] = pidStr.split(" ");
            for (String str:value) {
                if(StringUtils.isNotEmpty(str)&&StringUtils.isNumber(str)){                 
                    int pid = StringUtils.parseInt(str);
                    ShellResult killstatus = exec("000.000.000.000", "user", "password", "kill -9 "+pid, StandardCharsets.UTF_8);
                    System.out.println(">>>>>>Result>>>>>>>");
                    System.out.println(killstatus.getResult());
                    break;
                }
            }*/

            System.out.println(">>>>>>ErrorMsg>>>>>>>>");
            System.out.println(status.getErrorMsg());
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

}

main方法运行结果:
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Java代码操作Linux服务器的防火墙,需要使用 iptables 工具。下面是一个使用 iptables4j 库的示例代码,它提供了一个Java接口,可以让我们方便地构建和管理Linux防火墙规则: ```java import org.brekka.firewall.v4.Ipv4AccessList; import org.brekka.firewall.v4.Ipv4AccessListRule; import org.brekka.firewall.v4.Ipv4AccessListService; import org.brekka.xml.firewall.v4.model.Ipv4AccessListDocument; import java.net.Inet4Address; public class FirewallManager { private final Ipv4AccessListService ipv4AccessListService; public FirewallManager(Ipv4AccessListService ipv4AccessListService) { this.ipv4AccessListService = ipv4AccessListService; } public void allowTcpPort(Inet4Address ipAddress, int port) throws Exception { Ipv4AccessList accessList = ipv4AccessListService.createAccessList("allow-tcp-port-" + port); Ipv4AccessListRule rule = new Ipv4AccessListRule(); rule.setProtocol("tcp"); rule.setSourceIpAddress(ipAddress.getHostAddress() + "/32"); rule.setDestinationPort(port); accessList.getRule().add(rule); ipv4AccessListService.updateAccessList(accessList); } public void blockIpAddress(Inet4Address ipAddress) throws Exception { Ipv4AccessList accessList = ipv4AccessListService.createAccessList("block-ip-" + ipAddress.getHostAddress()); Ipv4AccessListRule rule = new Ipv4AccessListRule(); rule.setProtocol("all"); rule.setSourceIpAddress(ipAddress.getHostAddress() + "/32"); rule.setAction("deny"); accessList.getRule().add(rule); ipv4AccessListService.updateAccessList(accessList); } public void deleteAccessList(String name) throws Exception { ipv4AccessListService.deleteAccessList(name); } } ``` 这个示例代码定义了一个 FirewallManager 类,它允许我们添加和删除防火墙规则。`allowTcpPort` 方法允许我们允许来自指定IP地址的TCP端口流量,而 `blockIpAddress` 方法允许我们阻止指定IP地址的所有流量。最后,`deleteAccessList` 方法允许我们删除指定名称的防火墙规则。 请注意,使用iptables工具需要root权限,因此您需要在运行此代码的服务器上以root身份运行Java应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值