如何将JCIFS与apache VFS一起使用以访问SMB URL - 第2部分



>我遇到了同样的问题:如何将JCIFS与apache VFS一起使用来访问SMB URL?

。在类路径中包含commons-vfs-sandbox-2.1-SNAPSHOT.jar之后,我现在得到这个异常:

Exception in thread "main" org.apache.commons.vfs2.FileSystemException: Could not determine the type of file "smb://10.10.18.210/CIFS/123/asd".
    at org.apache.commons.vfs2.provider.AbstractFileObject.attach(AbstractFileObject.java:1522)
    at org.apache.commons.vfs2.provider.AbstractFileObject.getType(AbstractFileObject.java:489)
    at org.apache.commons.vfs2.provider.AbstractFileObject.exists(AbstractFileObject.java:477)
    at VFSTest.main(VFSTest.java:19)
Caused by: jcifs.smb.SmbAuthException: Logon failure: account currently disabled.
    at jcifs.smb.SmbTransport.checkStatus(SmbTransport.java:549)
    at jcifs.smb.SmbTransport.send(SmbTransport.java:667)
    at jcifs.smb.SmbSession.sessionSetup(SmbSession.java:390)
    at jcifs.smb.SmbSession.send(SmbSession.java:218)
    at jcifs.smb.SmbTree.treeConnect(SmbTree.java:176)
    at jcifs.smb.SmbFile.doConnect(SmbFile.java:911)
    at jcifs.smb.SmbFile.connect(SmbFile.java:954)
    at jcifs.smb.SmbFile.connect0(SmbFile.java:880)
    at jcifs.smb.SmbFile.queryPath(SmbFile.java:1335)
    at jcifs.smb.SmbFile.exists(SmbFile.java:1417)
    at jcifs.smb.SmbFile.isDirectory(SmbFile.java:1490)
    at org.apache.commons.vfs2.provider.smb.SmbFileObject.createSmbFile(SmbFileObject.java:118)
    at org.apache.commons.vfs2.provider.smb.SmbFileObject.doAttach(SmbFileObject.java:70)
    at org.apache.commons.vfs2.provider.AbstractFileObject.attach(AbstractFileObject.java:1505)
    ... 3 more

请指教。

我想

我知道你的问题是什么,沙盒提供程序不会在 2.0 中自动注册。此外,您还需要在解析调用中实际使用配置的身份验证属性(请参阅下面的修改源)。

我通常不使用默认的文件系统管理器,而是动态注册我的提供程序,但是如果要使用自动检测,则需要将 vfs-providers.xml 添加到沙箱 JAR 中。

以下是使用 2.0 构建完整工作 JAR 的方式:

> git clone https://github.com/apache/commons-vfs.git -b commons-vfs2-project-2.0 vfs2.0
> cd vfs2.0
> notepad sandboxpom.xml
> notepad sandboxsrctestjavaorgapachecommonsvfs2providersmbtestStandaloneMain.java
> mvn -Pinclude-sandbox -DskipTests=true clean package dependency:tree

编辑沙盒/pom.xml时,您需要确保从<版本>和<父><版本>标签中删除 -SANDBOX。然后,您需要添加:

  <resource>
    <directory>src/main/resources</directory>
  </resource>

到已经存在的<资源>标签(紧跟在第一个许可证+通知之后,包括第 88 行)

这是使用的测试代码:

package org.apache.commons.vfs2.provider.smb.test;
import org.apache.commons.vfs2.FileObject;
import org.apache.commons.vfs2.FileSystemException;
import org.apache.commons.vfs2.FileSystemManager;
import org.apache.commons.vfs2.FileSystemOptions;
import org.apache.commons.vfs2.VFS;
import org.apache.commons.vfs2.auth.StaticUserAuthenticator;
import org.apache.commons.vfs2.impl.DefaultFileSystemConfigBuilder;

public class StandaloneMain
{
    public static void main(String[] args) throws FileSystemException {
        //jcifs.Config.registerSmbURLHandler();
        StaticUserAuthenticator auth = new StaticUserAuthenticator("DOMAIN", "eckenfel", "SECRET");
        FileSystemOptions opts = new FileSystemOptions();
        DefaultFileSystemConfigBuilder.getInstance().setUserAuthenticator(opts, auth);
        FileSystemManager fs = VFS.getManager();
        if (!fs.hasProvider("smb")) throw new RuntimeException("Provide missing");
        System.out.println("Connecting " + args[0] + " with " + opts);
        FileObject smbFile = fs.resolveFile(args[0], opts); // added opts!
        System.out.println(smbFile.exists() + " " + smbFile.getContent().getLastModifiedTime());
    }
}

这是执行:

> set REP=C:UsersUSERNAME.m2repository
> java -cp sandboxtargetcommons-vfs2-sandbox-2.0.jar;^
           coretargetcommons-vfs2-2.0.jar;^
           %REP%commons-loggingcommons-logging1.1.1commons-logging-1.1.1.jar;^
           %REP%jcifsjcifs.8.3jcifs-0.8.3.jar;^
           sandboxtargettest-classes
       org.apache.commons.vfs2.provider.smb.test.StandaloneMain smb://HOST/Users
Jan 05, 2015 2:40:19 PM org.apache.commons.vfs2.VfsLog info
INFORMATION: Using "C:UsersUSERNAMEAppDataLocalTempvfs_cache" as temporary files store.
Connecting smb://eckenfels02/Users with org.apache.commons.vfs2.FileSystemOptions@27dd2ec5
true 0

最新更新