2016-06-28 8 views
0

私は、Apacheのmina sshdを使用して、Junitのテスト目的のために模擬sshサーバを設定します。 apache minaのドキュメントはかなり不明なので、私はテストでの認証問題に対処する方法を理解できません。Junitテストでjsch.addIdentity()を回避するには?

コード基本的にJschを使ってローカルからリモートにファイルを転送してテストしたいと思います。

public static void scpTo(String rfilePath, String lfilePath, String user, String host, String keyPath, int port) { 
    FileInputStream fis=null; 
    try { 
     while(true) { 
      String rfile = rfilePath; 
      String lfile = lfilePath; 

      JSch jsch = new JSch(); 
      jsch.addIdentity(keyPath); 
      java.util.Properties config = new java.util.Properties(); 
      config.put("StrictHostKeyChecking", "no"); 

      Session session = jsch.getSession(user, host, port); 
      session.setConfig(config); 

      session.connect(); 

      // exec 'scp -t rfile' remotely 
      String command = "scp " + " -t " + rfile; 
      Channel channel = session.openChannel("exec"); 
      ((ChannelExec) channel).setCommand(command); 

      // get I/O streams for remote scp 
      OutputStream out = channel.getOutputStream(); 
      InputStream in = channel.getInputStream(); 

      channel.connect(); 

      if (checkAck(in) != 0) { 
       System.exit(0); 
      } 

      File _lfile = new File(lfile); 
      if(!_lfile.exists()) { 
       System.err.println("Local file not existing"); 
      } 

      //check file existing 
      File _rfile = new File(rfile); 
      if (_rfile.exists()) { 
       System.out.println("Remote file already existed"); 
       break; 
      } 

      // send "C0644 filesize filename", where filename should not include '/' 
      long filesize = _lfile.length(); 
      command = "C0644 " + filesize + " "; 
      if (lfile.lastIndexOf('/') > 0) { 
       command += lfile.substring(lfile.lastIndexOf('/') + 1); 
      } else { 
       command += lfile; 
      } 
      command += "\n"; 
      out.write(command.getBytes()); 
      out.flush(); 
      if (checkAck(in) != 0) { 
       System.exit(0); 
      } 

      // send a content of lfile 
      fis = new FileInputStream(lfile); 
      byte[] buf = new byte[1024]; 
      while (true) { 
       int len = fis.read(buf, 0, buf.length); 
       if (len <= 0) break; 
       out.write(buf, 0, len); //out.flush(); 
      } 
      fis.close(); 
      fis = null; 
      // send '\0' 
      buf[0] = 0; 
      out.write(buf, 0, 1); 
      out.flush(); 
      if (checkAck(in) != 0) { 
       System.exit(0); 
      } 
      out.close(); 

      channel.disconnect(); 
      session.disconnect(); 

      //System.exit(0); 

      Thread.sleep(2000); 
     } 
    } catch (Exception e) { 
     System.out.println(e); 
     try { 
      if (fis != null) fis.close(); 
     } catch (Exception ee) { 
     } 
    } 
} 

テスト用setUp。自分のリソースフォルダにある特定のキーファイルを使用して、すべてのユーザー&ホストペアを認証したい場合は、setUpのために何をする必要がありますか?現在のsetUpの場合、Auth failエラーが発生します。あなたはこの行を変更する必要が

@Before 
public void setup() { 
    user = "siyangli"; 
    host = "localhost"; 
    //pick a port not occupied for tesing 
    port = 22998; 
    sshd = SshServer.setUpDefaultServer(); 
    sshd.setPort(port); 
    keyPath = "/Users/siyangli/.ssh/id_rsa"; 
    //it will change the key file??? do not know why, how to work around the authentication key?? 
    sshd.setKeyPairProvider(new FileKeyPairProvider(new String[]{"/Users/siyangli/.ssh/id_rsa"})); 
    //sshd.setKeyPairProvider(new SimpleGeneratorHostKeyProvider(keyPath)); 
    sshd.setPasswordAuthenticator(new PasswordAuthenticator() { 
     public boolean authenticate(String username, String password, ServerSession session) { 
      return true; 
     } 
    }); 
    sshd.setPublickeyAuthenticator(new PublickeyAuthenticator() { 
     @Override 
     public boolean authenticate(String username, PublicKey key, ServerSession session) { 
      return true; 
     } 
    }); 
    CommandFactory myCommandFactory = new CommandFactory() { 
     public Command createCommand(String command) { 
      System.out.println("Command: " + command); 
      return null; 
     } 
    }; 
    sshd.setCommandFactory(new ScpCommandFactory(myCommandFactory)); 
    List<NamedFactory<UserAuth>> userAuthFactories = new ArrayList<NamedFactory<UserAuth>>(); 
    userAuthFactories.add(new UserAuthPassword.Factory()); 
    sshd.setUserAuthFactories(userAuthFactories); 
    List<NamedFactory<Command>> namedFactoryList = new ArrayList<NamedFactory<Command>>(); 
    namedFactoryList.add(new SftpSubsystem.Factory()); sshd.setSubsystemFactories(namedFactoryList); 
    try { 
     sshd.start(); 
    } catch (IOException e) { 
     System.out.println(e.getMessage()); 
     e.printStackTrace(); 
    } 
    System.out.println("Finished setup !!! "); 
} 
+0

ヒント:あなたのメソッドscpToは** **多くの**ものへの道をしています。私は真剣にあなたがロバートマーティンによって "クリーンコード"を調べることをお勧めします...またはhttps://www.youtube.com/playlist?list=PLD0011D00849E1B79を見ていくつかの時間を費やした...あなたのコードは非常にそれを行うことから利益を得ることができます。 .. – GhostCat

答えて

0

: userAuthFactories.add(新しいUserAuthPassword.Factoryを()); 〜 userAuthFactories.add(新しいUserAuthPublicKey.Factory());

関連する問題