Java에서 쉘 스크립트를 실행할 때 오류가 발생하는 방법은 무엇입니까?

Java에서 쉘 스크립트를 실행할 때 오류가 발생하는 방법은 무엇입니까?

Java를 사용하여 쉘 스크립트를 실행하고 있는데 잘 작동합니다. 이제 이 스크립트에서 오류를 가져오고 싶습니다. 예를 들어 스크립트가 있고 오류가 있는데 해당 오류의 행과 메시지를 가져오고 싶습니다.

이것은 쉘 스크립트를 실행하는 코드입니다.

 try {
                 JSch jsch=new JSch();
                 com.jcraft.jsch.Session session=jsch.getSession(jTextField1.getText() ,jTextField3.getText(),22);
                 session.setPassword(jTextField2.getText());

          java.util.Properties config = new java.util.Properties(); 
          config.put("StrictHostKeyChecking", "no");
        session.setConfig(config);


                 session.connect();
                 ChannelExec channel=(ChannelExec) session.openChannel("exec");
                 channel.setInputStream(System.in);
                 channel.setOutputStream(System.out);
                 /*cp .mbb.sh to /
                 chmod +x mbb.sh
                 ./mbb.sh param1 param2*/

                 //chaine de caractére pour concatener les parametres 
                 String param="";
                 for ( int j=0 ; j<list.size();j++){
                     param=param+" "+list.get(j).getText();
                 }
                 DB_Operation db = new DB_Operation();
                 db.getConnection();

                 channel.setCommand("bash"+" "+valeururl+ param);
                                      //channel.setCommand("bash script.sh");


                 channel.connect(30000);
                 InputStream in = channel.getInputStream();
                 BufferedReader reader = new BufferedReader(new InputStreamReader(in));
                 String line ; 
                result.add("Build successful \n");
                 while((line =reader.readLine())!=null){
                     result.add(line);
                 }



                 if  ( session.isConnected()){
                     JOptionPane.showMessageDialog(rootPane, "Connecté");
                Resultexec  rs =new Resultexec(result);
                     xx.dispose();
                    rs.createAndShowGUI();

                 }



             } catch (JSchException ex) {

                 result.clear();
                  result.add("Build failed \n");
                 msg_console = ex.getMessage();
                 result.add(msg_console);

                       JOptionPane.showMessageDialog(rootPane, "Erreur de connexion ");
                Resultexec  rs =new Resultexec(result);
                     xx.dispose();
                    rs.createAndShowGUI();

             } catch (IOException ex) {
                 result.clear();
                 result.add("Build failed \n");
                 msg_console = ex.getMessage();                    
                 result.add(msg_console);   


                Resultexec  rs =new Resultexec(result);
                     xx.dispose();
                    rs.createAndShowGUI();

             }

답변1

안녕하세요, 코드를 일부 수정했는데 작동합니다.

package dashboard;
import com.jcraft.jsch.Channel;
import com.jcraft.jsch.ChannelExec;
import com.jcraft.jsch.JSch;
import com.jcraft.jsch.JSchException;

import java.awt.Color;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.JButton;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.border.LineBorder;
import javax.swing.border.TitledBorder;

/**
 *
 * @author ASUS
 */
public class NewJFrame extends javax.swing.JFrame  {
  private int valeurcol ; 
private static NewJFrame xx =new NewJFrame();
private static List <JTextField> list = new ArrayList();
 ArrayList<String> li = new ArrayList();
 private static List <String> result= new ArrayList();
 String valeururl;
String msg_console="";

// une variable pour récuperer warming message au cours de la connexion 



    /**
     * Creates new form NewJFrame1
     */
    public NewJFrame() {
        initComponents(); 





        this.setExtendedState(this.MAXIMIZED_BOTH);
        this.setSize(Toolkit.getDefaultToolkit().getScreenSize());
              System.out.println(jLabel3.getLocation());

    }
    NewJFrame(int valeurcol, String valeururl)  {
            initComponents();
            this.valeururl=valeururl;
                  this.setExtendedState(this.MAXIMIZED_BOTH);
        this.setSize(Toolkit.getDefaultToolkit().getScreenSize());

       try {
           this.valeurcol = valeurcol ;



           DB_Operation db=new DB_Operation();
           ResultSet rs= db.searchQuery("select * from utilitaires where id_script='"+valeurcol+"'");
           while(rs.isBeforeFirst()){
               while(rs.next()){
                   descri.setText(rs.getString(3));
                     nscript.setText(rs.getString(2));
               }
           }          DB_Operation db1=new DB_Operation();
           ResultSet rs1 = db1.searchQuery("select * from parametres where id_script='"+valeurcol+"'");
           int cpt = 0 ; 

           while (rs1.isBeforeFirst()){
               while (rs1.next()){
                   // pur récuperer le libelé 
                    li.add(rs1.getString(2));
                   cpt++;

               }
           }
                 LineBorder a =new javax.swing.border.LineBorder(Color.black);


jTextField1.setBorder(a); 
jTextField2.setBorder(a); 
jTextField3.setBorder(a);


 for ( int  j =0 ; j<cpt ; j++){
          JTextField c=new JTextField();
            c.setText("");
            c.setBorder(a);
            c.setSize(190, 28);
         list.add(c);
            c.setLocation(263,456+55*j);
            jPanel1.add(c);
            jPanel1.revalidate();
            jPanel1.repaint();  


          JLabel l = new JLabel();
            l.setLocation(157,456+49*j);
            l.setSize(120, 20);
            l.setText(li.get(j));
            jPanel1.add(l);


          }
          JButton bt_exec = new JButton();
          bt_exec.setSize(100, 30);
          bt_exec.setText("Exécuter");
          bt_exec.setLocation(263, 456+55*cpt);
          jPanel1.add(bt_exec);

         bt_exec.addActionListener(new ActionListener() {
             @Override
               public void actionPerformed(ActionEvent e) {

                 try {
                     JSch jsch=new JSch();
                     com.jcraft.jsch.Session session=jsch.getSession(jTextField1.getText() ,jTextField3.getText(),22);
                     session.setPassword(jTextField2.getText());

              java.util.Properties config = new java.util.Properties(); 
config.put("StrictHostKeyChecking", "no");
session.setConfig(config);


                     session.connect();
                       Channel channel = null;
                      channel= session.openChannel("exec");

                     String param="";
                     for ( int j=0 ; j<list.size();j++){
                         param=param+" "+list.get(j).getText();
                     }
                     DB_Operation db = new DB_Operation();
                     db.getConnection();
                     ( ( ChannelExec ) channel ).setCommand( "bash"+" "+valeururl+ param );

       channel.connect();

        BufferedReader reader = new BufferedReader( new InputStreamReader( channel.getInputStream() ) );
            BufferedReader errorReader = new BufferedReader( new InputStreamReader(
                    ( ( ChannelExec ) channel ).getErrStream() ) );



                     String lineerror ; 
                    result.add("Build successful \n");
                     while((lineerror =errorReader.readLine())!=null){
                         result.add(lineerror);

                     }
                   String line1 ; 
                    result.add("Build successful \n");
                     while((line1 =reader.readLine())!=null){
                         result.add(line1);

                     }

      reader.close();
            errorReader.close();


                if  ( session.isConnected()){
                         JOptionPane.showMessageDialog(rootPane, "Connecté");
                    Resultexec  rs =new Resultexec(result);
                         xx.dispose();
                        rs.createAndShowGUI();

                     }



                 } catch (JSchException ex) {

                     result.clear();
                      result.add("Build failed \n");
                     msg_console = ex.getMessage();
                     result.add(msg_console);

                           JOptionPane.showMessageDialog(rootPane, "Erreur de connexion ");
                    Resultexec  rs =new Resultexec(result);
                         xx.dispose();
                        rs.createAndShowGUI();

                 } catch (IOException ex) {

                     result.clear();
                     result.add("Build failed \n");
                     msg_console = ex.getMessage();                    
                     result.add(msg_console);   


                    Resultexec  rs =new Resultexec(result);
                         xx.dispose();
                        rs.createAndShowGUI();

                 } 
               }
           });

          JPanel exec = new JPanel();
           TitledBorder x =new javax.swing.border.TitledBorder(a);

             x.setTitle("Zone d'éxecution");
              exec.setBorder(x);
            exec.setLocation(100, 456+55*(cpt+1));
           exec.setSize(721, 257);
           exec.setBackground(Color.white);
       //  jPanel1.add(exec);


       } catch (SQLException ex) {
           Logger.getLogger(NewJFrame.class.getName()).log(Level.SEVERE, null, ex);
       }


    }
    /**
     * This method is called from within the constructor to initialize the form.
     * WARNING: Do NOT modify this code. The content of this method is always
     * regenerated by the Form Editor.
     */
    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">                          
    private void initComponents() {

        jPanel2 = new javax.swing.JPanel();
        jScrollPane1 = new javax.swing.JScrollPane();
        jPanel1 = new javax.swing.JPanel();
        jLabel4 = new javax.swing.JLabel();
        nscript = new javax.swing.JLabel();
        jScrollPane2 = new javax.swing.JScrollPane();
        descri = new javax.swing.JTextArea();
        jLabel1 = new javax.swing.JLabel();
        jTextField1 = new javax.swing.JTextField();
        jLabel2 = new javax.swing.JLabel();
        jLabel3 = new javax.swing.JLabel();
        jTextField2 = new javax.swing.JTextField();
        jTextField3 = new javax.swing.JTextField();
        jLabel5 = new javax.swing.JLabel();
        jLabel13 = new javax.swing.JLabel();

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        jPanel2.addAncestorListener(new javax.swing.event.AncestorListener() {
            public void ancestorMoved(javax.swing.event.AncestorEvent evt) {
                jPanel2AncestorMoved(evt);
            }
            public void ancestorAdded(javax.swing.event.AncestorEvent evt) {
            }
            public void ancestorRemoved(javax.swing.event.AncestorEvent evt) {
            }
        });

        javax.swing.GroupLayout jPanel2Layout = new javax.swing.GroupLayout(jPanel2);
        jPanel2.setLayout(jPanel2Layout);
        jPanel2Layout.setHorizontalGroup(
            jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 1174, Short.MAX_VALUE)
        );
        jPanel2Layout.setVerticalGroup(
            jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGap(0, 955, Short.MAX_VALUE)
        );

        jPanel1.setBackground(new java.awt.Color(255, 255, 255));

        jLabel4.setIcon(new javax.swing.ImageIcon(getClass().getResource("/dashboard/Image/unnamed.jpg"))); // NOI18N

        nscript.setFont(new java.awt.Font("Tahoma", 1, 36)); // NOI18N
        nscript.setForeground(new java.awt.Color(102, 204, 204));
        nscript.setText("Nom script");

        descri.setEditable(false);
        descri.setColumns(20);
        descri.setRows(5);
        jScrollPane2.setViewportView(descri);

        jLabel1.setText("User");

        jTextField1.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                jTextField1ActionPerformed(evt);
            }
        });

        jLabel2.setText("Password");

        jLabel3.setText("Serveur");

        jTextField3.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                jTextField3ActionPerformed(evt);
            }
        });

        jLabel5.setIcon(new javax.swing.ImageIcon(getClass().getResource("/dashboard/Image/back.png"))); // NOI18N

        javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1);
        jPanel1.setLayout(jPanel1Layout);
        jPanel1Layout.setHorizontalGroup(
            jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(jPanel1Layout.createSequentialGroup()
                .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                    .addGroup(jPanel1Layout.createSequentialGroup()
                        .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                            .addGroup(jPanel1Layout.createSequentialGroup()
                                .addGap(100, 100, 100)
                                .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                                    .addGroup(jPanel1Layout.createSequentialGroup()
                                        .addGap(57, 57, 57)
                                        .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
                                            .addComponent(jTextField2, javax.swing.GroupLayout.PREFERRED_SIZE, 190, javax.swing.GroupLayout.PREFERRED_SIZE)
                                            .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
                                                .addGroup(jPanel1Layout.createSequentialGroup()
                                                    .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                                                        .addComponent(jLabel1)
                                                        .addComponent(jLabel2))
                                                    .addGap(50, 50, 50)
                                                    .addComponent(jTextField1, javax.swing.GroupLayout.PREFERRED_SIZE, 190, javax.swing.GroupLayout.PREFERRED_SIZE))
                                                .addGroup(jPanel1Layout.createSequentialGroup()
                                                    .addComponent(jLabel3)
                                                    .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
                                                    .addComponent(jTextField3, javax.swing.GroupLayout.PREFERRED_SIZE, 190, javax.swing.GroupLayout.PREFERRED_SIZE)))))
                                    .addComponent(jScrollPane2, javax.swing.GroupLayout.PREFERRED_SIZE, 721, javax.swing.GroupLayout.PREFERRED_SIZE)))
                            .addGroup(jPanel1Layout.createSequentialGroup()
                                .addGap(339, 339, 339)
                                .addComponent(nscript)))
                        .addGap(0, 330, Short.MAX_VALUE))
                    .addGroup(jPanel1Layout.createSequentialGroup()
                        .addComponent(jLabel4, javax.swing.GroupLayout.PREFERRED_SIZE, 240, javax.swing.GroupLayout.PREFERRED_SIZE)
                        .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
                        .addComponent(jLabel5)))
                .addContainerGap())
        );
        jPanel1Layout.setVerticalGroup(
            jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(jPanel1Layout.createSequentialGroup()
                .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                    .addComponent(jLabel4, javax.swing.GroupLayout.PREFERRED_SIZE, 60, javax.swing.GroupLayout.PREFERRED_SIZE)
                    .addGroup(jPanel1Layout.createSequentialGroup()
                        .addContainerGap()
                        .addComponent(jLabel5)))
                .addGap(26, 26, 26)
                .addComponent(nscript)
                .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED)
                .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
                    .addGroup(jPanel1Layout.createSequentialGroup()
                        .addComponent(jScrollPane2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
                        .addGap(59, 59, 59)
                        .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
                            .addComponent(jTextField1, javax.swing.GroupLayout.PREFERRED_SIZE, 28, javax.swing.GroupLayout.PREFERRED_SIZE)
                            .addComponent(jLabel1))
                        .addGap(27, 27, 27)
                        .addComponent(jTextField2, javax.swing.GroupLayout.PREFERRED_SIZE, 28, javax.swing.GroupLayout.PREFERRED_SIZE))
                    .addComponent(jLabel2))
                .addGap(27, 27, 27)
                .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
                    .addComponent(jTextField3, javax.swing.GroupLayout.PREFERRED_SIZE, 28, javax.swing.GroupLayout.PREFERRED_SIZE)
                    .addComponent(jLabel3))
                .addContainerGap(1239, Short.MAX_VALUE))
        );

        jScrollPane1.setViewportView(jPanel1);

        jLabel13.setIcon(new javax.swing.ImageIcon(getClass().getResource("/dashboard/Image/back (1).png"))); // NOI18N
        jLabel13.addMouseListener(new java.awt.event.MouseAdapter() {
            public void mouseClicked(java.awt.event.MouseEvent evt) {
                jLabel13MouseClicked(evt);
            }
        });

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(layout.createSequentialGroup()
                .addGap(5, 5, 5)
                .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
                .addGap(0, 4, Short.MAX_VALUE))
            .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
                .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
                .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
            .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                .addGroup(layout.createSequentialGroup()
                    .addGap(579, 579, 579)
                    .addComponent(jLabel13)
                    .addContainerGap(580, Short.MAX_VALUE)))
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(layout.createSequentialGroup()
                .addContainerGap()
                .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 933, javax.swing.GroupLayout.PREFERRED_SIZE)
                .addGap(40, 40, 40)
                .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
            .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                .addGroup(layout.createSequentialGroup()
                    .addGap(934, 934, 934)
                    .addComponent(jLabel13, javax.swing.GroupLayout.PREFERRED_SIZE, 25, javax.swing.GroupLayout.PREFERRED_SIZE)
                    .addContainerGap(980, Short.MAX_VALUE)))
        );

        pack();
    }// </editor-fold>                        

    private void jPanel2AncestorMoved(javax.swing.event.AncestorEvent evt) {                                      
        // TODO add your handling code here:
    }                                     

    private void jTextField1ActionPerformed(java.awt.event.ActionEvent evt) {                                            
        // TODO add your handling code here:
    }                                           

    private void jTextField3ActionPerformed(java.awt.event.ActionEvent evt) {                                            
        // TODO add your handling code here:
    }                                           

    private void jLabel13MouseClicked(java.awt.event.MouseEvent evt) {                                      
        PageAdmin pa = new PageAdmin();
        this.dispose();
        pa.setVisible(true);
    }                                     

    /**
     * @param args the command line arguments
     */
    public static void main(String args[]) {
        /* Set the Nimbus look and feel */
        //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
        /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
         * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html 
         */
        try {
            for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
                if ("Nimbus".equals(info.getName())) {
                    javax.swing.UIManager.setLookAndFeel(info.getClassName());
                    break;
                }
            }
        } catch (ClassNotFoundException ex) {
            java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (InstantiationException ex) {
            java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (IllegalAccessException ex) {
            java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (javax.swing.UnsupportedLookAndFeelException ex) {
            java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        }
        //</editor-fold>

        /* Create and display the form */
        java.awt.EventQueue.invokeLater(new Runnable() {
            public void run() {
                xx.setVisible(true);
            }
        });
    }

    // Variables declaration - do not modify                     
    private javax.swing.JTextArea descri;
    private javax.swing.JLabel jLabel1;
    private javax.swing.JLabel jLabel13;
    private javax.swing.JLabel jLabel2;
    private javax.swing.JLabel jLabel3;
    private javax.swing.JLabel jLabel4;
    private javax.swing.JLabel jLabel5;
    private javax.swing.JPanel jPanel1;
    private javax.swing.JPanel jPanel2;
    private javax.swing.JScrollPane jScrollPane1;
    private javax.swing.JScrollPane jScrollPane2;
    private javax.swing.JTextField jTextField1;
    private javax.swing.JTextField jTextField2;
    private javax.swing.JTextField jTextField3;
    private javax.swing.JLabel nscript;
    // End of variables declaration                   




}

관련 정보