2017-08-10 289 views
0

我正在研究java方法將文件從一個位置複製到另一個遠程位置。我的代碼如下。我嘗試使用jsch 0.1.42 & 0.1.50 & 0.1.54SFTP Java - 管道關閉Jsch異常

 public static void processFiles(ArrayList<String> FilesToBeCopied, String destFilePath) throws IOException { 
     SftpClient client = new SftpClient("karthick"); 
     String keyFilePath = "/ab/c/d/id_rsa"; 
     String sftpUser = "karthickkb"; 
     client.login(sftpUser, keyFilePath, null); 
     client.changeWorkingDirectory(destFilePath); 
     Configuration conf = new Configuration(); 
     FileSystem fs = FileSystem.get(conf); 
     FSDataInputStream fsdisPath = null; 
     String filePath = null; 
     for (String sourcefilePath : FilesToBeCopied) { 
      try { 
       filePath = sourcefilePath; 
       Path inputPath = new Path(filePath); 
       fsdisPath = fs.open(inputPath); 
       BufferedInputStream bis = new BufferedInputStream(fsdisPath); 
       client.storeFile(inputPath.getName(), bis); 
       fsdisPath.close(); 
       fsdisPath = null; 
      } catch (Exception ex) { 
       ex.printStackTrace(); 
      } finally { 
       try { 
        if (client != null) { 
         client.disconnect(); 


     } 
       if (fsdisPath != null) { 
        fsdisPath.close(); 
       } 
      } catch (Exception ex) { 
       ex.printStackTrace(); 
      } 
     } 
    } 

} 

} 

錯誤代碼,當我用Jsch 0.1.42是 ,當我用jsch 0.1.42我接收到的下面的錯誤代碼。

 java.io.IOException: java.io.IOException: Pipe closed 
    at org.mule.transport.sftp.SftpClient.storeFile(SftpClient.java:390) 
    at karthickArchive.archiveMigration.sftpFileUtil.processFiles(sftpFileUtil.java:58) 
    at karthickArchive.archiveMigration.getFileUtility.main (getFileUtility.java:69) 

    17/08/14 07:06:41 ERROR sftp.SftpClient: Error writing data over SFTP service, error was: java.io.IOException: Pipe closed 
    4: java.io.IOException: Pipe closed 
    at com.jcraft.jsch.ChannelSftp._put(ChannelSftp.java:578) 
    at com.jcraft.jsch.ChannelSftp.put(ChannelSftp.java:439) 
    at com.jcraft.jsch.ChannelSftp.put(ChannelSftp.java:406) 
    at org.mule.transport.sftp.SftpClient.storeFile(SftpClient.java:385) 
    at karthickArchive.archiveMigration.sftpFileUtil.processFiles(sftpFileUtil.java:58) 
    at karthickArchive.archiveMigration.getFileUtility.main(getFileUtility.java:69) 
    Caused by: java.io.IOException: Pipe closed 
    at java.io.PipedInputStream.read(PipedInputStream.java:308) 
    at java.io.PipedInputStream.read(PipedInputStream.java:378) 
    at com.jcraft.jsch.ChannelSftp.fill(ChannelSftp.java:2325) 
    at com.jcraft.jsch.ChannelSftp.header(ChannelSftp.java:2351) 
    at com.jcraft.jsch.ChannelSftp._put(ChannelSftp.java:474) 
    ... 5 mor 

當我使用jsch 0.1.50,錯誤如下

Exception in thread "main" java.lang.NoSuchFieldError: identities 
    at com.jcraft.jsch.UserAuthPublicKey.start(UserAuthPublicKey.java:39) 
    at com.jcraft.jsch.Session.connect(Session.java:463) 
    at com.jcraft.jsch.Session.connect(Session.java:183) 

我試圖探索不夠,我不能得到一個明確的答覆我的問題,我想我失去了一些東西。任何建議將不勝感激。

Maven的依賴關係樹,當我使用jsch 0.1.50

[INFO] Scanning for projects... 
[INFO]                   
[INFO] ------------------------------------------------------------------------ 
[INFO] Building archiveMigration 0.0.1-SNAPSHOT 
[INFO] ------------------------------------------------------------------------ 
[INFO] 
[INFO] --- maven-dependency-plugin:2.8:tree (default-cli) @ archiveMigration --- 
[INFO] tdiArchive:archiveMigration:jar:0.0.1-SNAPSHOT 
[INFO] +- org.apache.hadoop:hadoop-hdfs:jar:2.5.0-cdh5.3.2:compile 
[INFO] | +- com.google.guava:guava:jar:11.0.2:compile 
[INFO] | | \- (com.google.code.findbugs:jsr305:jar:1.3.9:compile - omitted for duplicate) 
[INFO] | +- org.mortbay.jetty:jetty:jar:6.1.26.cloudera.4:compile 
[INFO] | | \- (org.mortbay.jetty:jetty-util:jar:6.1.26.cloudera.4:compile - omitted for duplicate) 
[INFO] | +- org.mortbay.jetty:jetty-util:jar:6.1.26.cloudera.4:compile 
[INFO] | +- com.sun.jersey:jersey-core:jar:1.9:compile 
[INFO] | +- com.sun.jersey:jersey-server:jar:1.9:compile 
[INFO] | | +- asm:asm:jar:3.1:compile 
[INFO] | | \- (com.sun.jersey:jersey-core:jar:1.9:compile - omitted for duplicate) 
[INFO] | +- commons-cli:commons-cli:jar:1.2:compile 
[INFO] | +- commons-codec:commons-codec:jar:1.4:compile 
[INFO] | +- commons-io:commons-io:jar:2.4:compile 
[INFO] | +- commons-lang:commons-lang:jar:2.6:compile 
[INFO] | +- commons-logging:commons-logging:jar:1.1.3:compile 
[INFO] | +- commons-daemon:commons-daemon:jar:1.0.13:compile 
[INFO] | +- javax.servlet.jsp:jsp-api:jar:2.1:compile 
[INFO] | +- log4j:log4j:jar:1.2.17:compile 
[INFO] | +- com.google.protobuf:protobuf-java:jar:2.5.0:compile 
[INFO] | +- javax.servlet:servlet-api:jar:2.5:compile 
[INFO] | +- org.codehaus.jackson:jackson-core-asl:jar:1.8.8:compile 
[INFO] | +- org.codehaus.jackson:jackson-mapper-asl:jar:1.8.8:compile 
[INFO] | | \- (org.codehaus.jackson:jackson-core-asl:jar:1.8.8:compile - omitted for duplicate) 
[INFO] | +- tomcat:jasper-runtime:jar:5.5.23:compile 
[INFO] | | +- (javax.servlet:servlet-api:jar:2.4:compile - omitted for conflict with 2.5) 
[INFO] | | \- commons-el:commons-el:jar:1.0:compile 
[INFO] | |  \- (commons-logging:commons-logging:jar:1.0.3:compile - omitted for conflict with 1.1.3) 
[INFO] | +- xmlenc:xmlenc:jar:0.52:compile 
[INFO] | \- io.netty:netty:jar:3.6.2.Final:compile 
[INFO] +- org.apache.hadoop:hadoop-common:jar:2.5.0-cdh5.3.2:compile 
[INFO] | +- org.apache.hadoop:hadoop-annotations:jar:2.5.0-cdh5.3.2:compile 
[INFO] | | \- jdk.tools:jdk.tools:jar:1.6:system 
[INFO] | +- (com.google.guava:guava:jar:11.0.2:compile - omitted for duplicate) 
[INFO] | +- (commons-cli:commons-cli:jar:1.2:compile - omitted for duplicate) 
[INFO] | +- org.apache.commons:commons-math3:jar:3.1.1:compile 
[INFO] | +- (xmlenc:xmlenc:jar:0.52:compile - omitted for duplicate) 
[INFO] | +- commons-httpclient:commons-httpclient:jar:3.1:compile 
[INFO] | | +- (commons-logging:commons-logging:jar:1.0.4:compile - omitted for conflict with 1.1.3) 
[INFO] | | \- (commons-codec:commons-codec:jar:1.2:compile - omitted for conflict with 1.4) 
[INFO] | +- (commons-codec:commons-codec:jar:1.4:compile - omitted for duplicate) 
[INFO] | +- (commons-io:commons-io:jar:2.4:compile - omitted for duplicate) 
[INFO] | +- commons-net:commons-net:jar:3.1:compile 
[INFO] | +- commons-collections:commons-collections:jar:3.2.1:compile 
[INFO] | +- (javax.servlet:servlet-api:jar:2.5:compile - omitted for duplicate) 
[INFO] | +- (org.mortbay.jetty:jetty:jar:6.1.26.cloudera.4:compile - omitted for duplicate) 
[INFO] | +- (org.mortbay.jetty:jetty-util:jar:6.1.26.cloudera.4:compile - omitted for duplicate) 
[INFO] | +- (com.sun.jersey:jersey-core:jar:1.9:compile - omitted for duplicate) 
[INFO] | +- com.sun.jersey:jersey-json:jar:1.9:compile 
[INFO] | | +- org.codehaus.jettison:jettison:jar:1.1:compile 
[INFO] | | +- com.sun.xml.bind:jaxb-impl:jar:2.2.3-1:compile 
[INFO] | | | \- javax.xml.bind:jaxb-api:jar:2.2.2:compile 
[INFO] | | |  +- javax.xml.stream:stax-api:jar:1.0-2:compile 
[INFO] | | |  \- (javax.activation:activation:jar:1.1:compile - omitted for conflict with 1.1-osgi) 
[INFO] | | +- (org.codehaus.jackson:jackson-core-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | +- (org.codehaus.jackson:jackson-mapper-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | +- org.codehaus.jackson:jackson-jaxrs:jar:1.8.3:compile 
[INFO] | | | +- (org.codehaus.jackson:jackson-core-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | | \- (org.codehaus.jackson:jackson-mapper-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | +- org.codehaus.jackson:jackson-xc:jar:1.8.3:compile 
[INFO] | | | +- (org.codehaus.jackson:jackson-core-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | | \- (org.codehaus.jackson:jackson-mapper-asl:jar:1.8.3:compile - omitted for conflict with 1.8.8) 
[INFO] | | \- (com.sun.jersey:jersey-core:jar:1.9:compile - omitted for duplicate) 
[INFO] | +- (com.sun.jersey:jersey-server:jar:1.9:compile - omitted for duplicate) 
[INFO] | +- tomcat:jasper-compiler:jar:5.5.23:runtime 
[INFO] | +- (tomcat:jasper-runtime:jar:5.5.23:runtime - omitted for duplicate) 
[INFO] | +- (javax.servlet.jsp:jsp-api:jar:2.1:runtime - omitted for duplicate) 
[INFO] | +- (commons-el:commons-el:jar:1.0:compile - scope updated from runtime; omitted for duplicate) 
[INFO] | +- (commons-logging:commons-logging:jar:1.1.3:compile - omitted for duplicate) 
[INFO] | +- (log4j:log4j:jar:1.2.17:compile - omitted for duplicate) 
[INFO] | +- net.java.dev.jets3t:jets3t:jar:0.9.0:compile 
[INFO] | | +- (commons-codec:commons-codec:jar:1.4:compile - omitted for duplicate) 
[INFO] | | +- (commons-logging:commons-logging:jar:1.1.1:compile - omitted for conflict with 1.1.3) 
[INFO] | | +- org.apache.httpcomponents:httpclient:jar:4.1.2:compile 
[INFO] | | | \- (org.apache.httpcomponents:httpcore:jar:4.1.2:compile - omitted for duplicate) 
[INFO] | | +- org.apache.httpcomponents:httpcore:jar:4.1.2:compile 
[INFO] | | \- com.jamesmurty.utils:java-xmlbuilder:jar:0.4:compile 
[INFO] | +- (commons-lang:commons-lang:jar:2.6:compile - omitted for duplicate) 
[INFO] | +- commons-configuration:commons-configuration:jar:1.6:compile 
[INFO] | | +- (commons-collections:commons-collections:jar:3.2.1:compile - omitted for duplicate) 
[INFO] | | +- (commons-lang:commons-lang:jar:2.4:compile - omitted for conflict with 2.6) 
[INFO] | | +- (commons-logging:commons-logging:jar:1.1.1:compile - omitted for conflict with 1.1.3) 
[INFO] | | +- commons-digester:commons-digester:jar:1.8:compile 
[INFO] | | | +- (commons-beanutils:commons-beanutils:jar:1.7.0:compile - omitted for conflict with 1.8.0) 
[INFO] | | | \- (commons-logging:commons-logging:jar:1.1:compile - omitted for conflict with 1.1.3) 
[INFO] | | \- commons-beanutils:commons-beanutils-core:jar:1.8.0:compile 
[INFO] | |  \- (commons-logging:commons-logging:jar:1.1.1:compile - omitted for conflict with 1.1.3) 
[INFO] | +- org.slf4j:slf4j-api:jar:1.7.5:compile 
[INFO] | +- (org.slf4j:slf4j-log4j12:jar:1.7.5:compile - scope updated from runtime; omitted for duplicate) 
[INFO] | +- (org.codehaus.jackson:jackson-core-asl:jar:1.8.8:compile - omitted for duplicate) 
[INFO] | +- (org.codehaus.jackson:jackson-mapper-asl:jar:1.8.8:compile - omitted for duplicate) 
[INFO] | +- org.apache.avro:avro:jar:1.7.6-cdh5.3.2:compile 
[INFO] | | +- (org.codehaus.jackson:jackson-core-asl:jar:1.9.13:compile - omitted for conflict with 1.8.8) 
[INFO] | | +- (org.codehaus.jackson:jackson-mapper-asl:jar:1.9.13:compile - omitted for conflict with 1.8.8) 
[INFO] | | +- com.thoughtworks.paranamer:paranamer:jar:2.3:compile 
[INFO] | | +- org.xerial.snappy:snappy-java:jar:1.0.5:compile 
[INFO] | | +- (org.apache.commons:commons-compress:jar:1.4.1:compile - omitted for duplicate) 
[INFO] | | \- (org.slf4j:slf4j-api:jar:1.6.4:compile - omitted for conflict with 1.7.5) 
[INFO] | +- (com.google.protobuf:protobuf-java:jar:2.5.0:compile - omitted for duplicate) 
[INFO] | +- com.google.code.gson:gson:jar:2.2.4:compile 
[INFO] | +- org.apache.hadoop:hadoop-auth:jar:2.5.0-cdh5.3.2:compile 
[INFO] | | +- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | +- (commons-codec:commons-codec:jar:1.4:compile - omitted for duplicate) 
[INFO] | | +- (log4j:log4j:jar:1.2.17:runtime - omitted for duplicate) 
[INFO] | | +- (org.slf4j:slf4j-log4j12:jar:1.7.5:runtime - omitted for duplicate) 
[INFO] | | +- (org.apache.httpcomponents:httpclient:jar:4.2.5:compile - omitted for conflict with 4.1.2) 
[INFO] | | +- org.apache.directory.server:apacheds-kerberos-codec:jar:2.0.0-M15:compile 
[INFO] | | | +- org.apache.directory.server:apacheds-i18n:jar:2.0.0-M15:compile 
[INFO] | | | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | | +- org.apache.directory.api:api-asn1-api:jar:1.0.0-M20:compile 
[INFO] | | | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | | +- org.apache.directory.api:api-util:jar:1.0.0-M20:compile 
[INFO] | | | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | +- (org.apache.zookeeper:zookeeper:jar:3.4.5-cdh5.3.2:compile - omitted for duplicate) 
[INFO] | | \- org.apache.curator:curator-framework:jar:2.6.0:compile 
[INFO] | |  +- (org.apache.curator:curator-client:jar:2.6.0:compile - omitted for duplicate) 
[INFO] | |  +- (org.apache.zookeeper:zookeeper:jar:3.4.6:compile - omitted for conflict with 3.4.5-cdh5.3.2) 
[INFO] | |  \- (com.google.guava:guava:jar:16.0.1:compile - omitted for conflict with 11.0.2) 
[INFO] | +- (com.jcraft:jsch:jar:0.1.42:compile - omitted for conflict with 0.1.50) 
[INFO] | +- org.apache.curator:curator-client:jar:2.6.0:compile 
[INFO] | | +- (org.slf4j:slf4j-api:jar:1.7.6:compile - omitted for conflict with 1.7.5) 
[INFO] | | +- (org.apache.zookeeper:zookeeper:jar:3.4.6:compile - omitted for conflict with 3.4.5-cdh5.3.2) 
[INFO] | | \- (com.google.guava:guava:jar:16.0.1:compile - omitted for conflict with 11.0.2) 
[INFO] | +- org.apache.curator:curator-recipes:jar:2.6.0:compile 
[INFO] | | +- (org.apache.curator:curator-framework:jar:2.6.0:compile - omitted for duplicate) 
[INFO] | | +- (org.apache.zookeeper:zookeeper:jar:3.4.6:compile - omitted for conflict with 3.4.5-cdh5.3.2) 
[INFO] | | \- (com.google.guava:guava:jar:16.0.1:compile - omitted for conflict with 11.0.2) 
[INFO] | +- com.google.code.findbugs:jsr305:jar:1.3.9:compile 
[INFO] | +- org.apache.zookeeper:zookeeper:jar:3.4.5-cdh5.3.2:compile 
[INFO] | | +- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | +- org.slf4j:slf4j-log4j12:jar:1.7.5:compile 
[INFO] | | | +- (org.slf4j:slf4j-api:jar:1.7.5:compile - omitted for duplicate) 
[INFO] | | | \- (log4j:log4j:jar:1.2.17:compile - omitted for duplicate) 
[INFO] | | \- (log4j:log4j:jar:1.2.17:compile - omitted for duplicate) 
[INFO] | \- org.apache.commons:commons-compress:jar:1.4.1:compile 
[INFO] |  \- org.tukaani:xz:jar:1.0:compile 
[INFO] +- org.mule.transports:mule-transport-sftp:jar:3.4.0:compile 
[INFO] | +- (com.jcraft:jsch:jar:0.1.44-1:compile - omitted for conflict with 0.1.42) 
[INFO] | +- org.mule:mule-core:jar:3.4.0:compile 
[INFO] | | +- commons-beanutils:commons-beanutils:jar:1.8.0:compile 
[INFO] | | +- org.safehaus.jug:jug:jar:asl:2.0.0:compile 
[INFO] | | +- (commons-cli:commons-cli:jar:1.2:compile - omitted for duplicate) 
[INFO] | | +- (commons-collections:commons-collections:jar:3.2.1:compile - omitted for duplicate) 
[INFO] | | +- (commons-io:commons-io:jar:1.4:compile - omitted for conflict with 2.4) 
[INFO] | | +- (commons-lang:commons-lang:jar:2.4:compile - omitted for conflict with 2.6) 
[INFO] | | +- commons-pool:commons-pool:jar:1.5.3:compile 
[INFO] | | +- javax.activation:activation:jar:1.1-osgi:compile 
[INFO] | | +- org.apache.geronimo.specs:geronimo-jta_1.1_spec:jar:1.1.1:compile 
[INFO] | | +- org.apache.geronimo.specs:geronimo-j2ee-connector_1.5_spec:jar:1.1-osgi:compile 
[INFO] | | +- javax.annotation:jsr250-api:jar:1.0:compile 
[INFO] | | +- org.slf4j:jcl-over-slf4j:jar:1.6.1:compile 
[INFO] | | | \- (org.slf4j:slf4j-api:jar:1.6.1:compile - omitted for conflict with 1.7.5) 
[INFO] | | +- (org.slf4j:slf4j-api:jar:1.6.1:compile - omitted for conflict with 1.7.5) 
[INFO] | | +- (org.slf4j:slf4j-log4j12:jar:1.6.1:compile - omitted for conflict with 1.7.5) 
[INFO] | | +- (log4j:log4j:jar:1.2.16:compile - omitted for conflict with 1.2.17) 
[INFO] | | +- (asm:asm:jar:3.1:compile - omitted for duplicate) 
[INFO] | | +- asm:asm-commons:jar:3.1:compile 
[INFO] | | | \- asm:asm-tree:jar:3.1:compile 
[INFO] | | |  \- (asm:asm:jar:3.1:compile - omitted for duplicate) 
[INFO] | | +- org.mvel:mvel2:jar:2.1.3.Final:compile 
[INFO] | | +- org.jgrapht:jgrapht-jdk1.5:jar:0.7.3:compile 
[INFO] | | \- org.mule.common:mule-common:jar:0.11.0:compile 
[INFO] | \- (org.mule.transports:mule-transport-file:jar:3.4.0:compile - omitted for duplicate) 
[INFO] +- org.mule.transports:mule-transport-file:jar:3.4.0:compile 
[INFO] | \- org.mule.modules:mule-module-spring-config:jar:3.4.0:compile 
[INFO] |  +- (org.mule:mule-core:jar:3.4.0:compile - omitted for duplicate) 
[INFO] |  +- org.mule.modules:mule-module-annotations:jar:3.4.0:compile 
[INFO] |  | +- (org.mule:mule-core:jar:3.4.0:compile - omitted for duplicate) 
[INFO] |  | \- cglib:cglib-nodep:jar:2.2:compile 
[INFO] |  +- org.springframework:spring-context:jar:3.2.1.RELEASE:compile 
[INFO] |  | +- org.springframework:spring-beans:jar:3.2.1.RELEASE:compile 
[INFO] |  | | \- (org.springframework:spring-core:jar:3.2.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  | +- org.springframework:spring-aop:jar:3.2.1.RELEASE:compile 
[INFO] |  | | +- (org.springframework:spring-beans:jar:3.2.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  | | \- (org.springframework:spring-core:jar:3.2.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  | +- org.springframework:spring-expression:jar:3.2.1.RELEASE:compile 
[INFO] |  | | \- (org.springframework:spring-core:jar:3.2.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  | \- org.springframework:spring-core:jar:3.2.1.RELEASE:compile 
[INFO] |  +- dom4j:dom4j:jar:1.6.1-osgi:compile 
[INFO] |  \- jaxen:jaxen:jar:1.1.1:compile 
[INFO] |  +- (jaxen:jaxen:jar:1.1-beta-6:compile - omitted for cycle) 
[INFO] |  +- (dom4j:dom4j:jar:1.6.1:compile - omitted for conflict with 1.6.1-osgi) 
[INFO] |  +- (jaxen:jaxen:jar:1.0-FCS:compile - omitted for cycle) 
[INFO] |  \- jdom:jdom:jar:1.0:compile 
[INFO] \- com.jcraft:jsch:jar:0.1.50:compile 
[INFO] -------------------------------------------------------------------- 
[INFO] BUILD SUCCESS 
[INFO] -------------------------------------------------------------------- 
[INFO] Total time: 7.989 s 
[INFO] Finished at: 2017-08-14T18:02:29+05:30 
[INFO] Final Memory: 18M/356M 
[INFO] --------------------------------------------------------------------  ---- 

刪除所有其他JSCH庫後,以下是我Maven和我沒有看到比0.1以外的任何其他JSCH庫0.50

我還在行

client.login(sftpUser錯誤,keyFilePath,NU二);

Actual Log:Exception in thread "main" java.lang.NoSuchFieldError: identities 
    at com.jcraft.jsch.UserAuthPublicKey.start(UserAuthPublicKey.java:39) 
    at com.jcraft.jsch.Session.connect(Session.java:463) 
    at com.jcraft.jsch.Session.connect(Session.java:183) 
    at org.mule.transport.sftp.SftpClient.login(SftpClient.java:178) 
    at karthickArchive.archiveMigration.sftpFileUtil.processFiles(sftpFileUtil.java:46) 
    at karthickArchive.archiveMigration.getFileUtility.main(getFileUtility.java:69) 
+0

'使用JSch 0.1.50可能是由仍然在使用另一JSch版本的應用程序的其他部分時引起NoSuchFieldError'。你確定你重新編譯了你的整個代碼嗎?即'通常,這個錯誤是由編譯器捕獲的;這個錯誤只能在運行時發生,如果一個類的定義發生了不兼容的變化。' 使用JSch 0.1.42時,哪一行正好拋出異常? (顯示整個堆棧跟蹤可能會有所幫助) –

+0

@PierreB謝謝您的評論。當我使用jsch 01.42時,我編輯了完整的堆棧strace,我發現在\t client.storeFile(inputPath.getName(),bis)行發生錯誤; 。非常感謝這個建議。 – Karthi

+0

@PierreB。我做了一個mvn依賴項:樹 - 在項目中使用jsch 0.1.50),我發現項目和我已經在原始文章中添加了所有日誌:特別是:+ - org.mule.transports:mule- transport-sftp:jar:3.4.0:compile [INFO] | + - (com.jcraft:jsch:jar:0.1.44-1:編譯 - 省略與0.1.42衝突) + - (com.jcraft:jsch:jar:0.1.42:編譯 - 省略衝突0.1.50) [INFO] \ - com.jcraft:jsch:jar:0.1.50:compile [INFO] ---------------------- -------------------------------------------------- [INFO] BUILD SUCCESS – Karthi

回答

2

看你的代碼的第二時間(我的咖啡之後,它的更好),java.io.IOException: Pipe closed與JSch 0.1.42有效地通過一個邏輯問題引起的如你所說:

你finally塊您for循環。作爲一個finally塊總是被稱爲異常是否發生,或者不是你的客戶端是由始終斷開終於在第一個iteraton結束塊:

for(...){ 
    try{ 
     ... 
    }catch(...){ 
     ... 
    }finally{ 
     # this finally block is inside your for loop 
     # finally block is always called whether an exception occur or not 
     # on the first iteration, this is called and close your client 
     try{ 
      if(client!=null){ 
       # nope, it will close the client for next iteration! 
       client.disconnect(); 
      }if(fsdisPath!=null){ 
       # good to close this however 
       fsdisPath.close(); 
      } 
     }catch(Exceptionex){ 
      ex.printStackTrace(); 
     } 
    } 
} 

相反,你應該有類似:

try { 
    for(...){ 
     try{ 
      ... 
     }catch(...){ 
      ... 
     }finally{ 
      try{ 
       if(fsdisPath!=null){ 
        fsdisPath.close(); 
       } 
      }catch(Exceptionex){ 
       ex.printStackTrace(); 
      } 
     } 
    } 
} finally { 
    if(client!=null){ 
     client.disconnect(); 
    } 
} 

也可能有你的for循環代碼lisibility功能是個好主意;)

java.lang.NoSuchFieldError: identities通過使用不同的JSch版本的應用程序的另一個標準桿引起的,你把證據每Maven的依賴性TRE即

做了MVN依賴性:樹-Dverbose項目(使用jsch 0.1.50),我發現這個項目,我添加了所有記錄在原崗位:特別是:+ - org.mule .transports:mule-transport-sftp:jar:3.4.0:compile [INFO] | + - (com。jcraft:jsch:jar:0.1.44-1:compile - 與0.1.42衝突時省略)+ - (com.jcraft:jsch:jar:0.1.42:compile - 與0.1.50衝突時忽略)[INFO] - com.jcraft:jsch:罐子:0.1.50:編譯[INFO]

0

看起來像一個服務器的問題。你確定你連接的用戶有寫入權限嗎?您的SFTP服務器是否可以訪問?看看這篇文章:com.jcraft.jsch.JSchException: java.io.IOException: Pipe closed

還檢查您的SSH服務器日誌,你可能有一些有用的東西。

+0

當我使用jsch 0.1.42傳遞一個小文件列表..在服務器端沒有問題。第一個文件被傳送到其他機器。問題從第二個文件開始。這是否意味着代碼中的任何邏輯問題,連接在處理之前突然關閉? – Karthi

+0

你是對的,再看看你的代碼,這似乎是一個邏輯問題。我發佈了一個合適的答案。 –