>我遇到了同样的问题:如何将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