gpt4 book ai didi

java - 使用 Java NIO 监视服务监视 http 资源

转载 作者:行者123 更新时间:2023-11-30 08:18:46 26 4
gpt4 key购买 nike

我需要监控 Amazon S3 上的一个目录,以检查是否有任何新文件添加到该目录。我尝试使用 Java NIO Watch Service,但它无法正常工作。如果我将以下语法与提供的 S3 路径一起使用:

String pathToMonitor="file://https://abc/dir";  //Line1
Path path=Paths.get(new URL(pathToMonitor).toURI()); //Line2
Boolean isFolder=(Boolean) Files.getAttribute(file, "basic:isDirectory", LinkOption.NOFOLLOW_LINKS); //Line3

然后我得到以下错误:

java.nio.file.FileSystemException: \\https\abc\dir: The network path was not found.

at sun.nio.fs.WindowsException.translateToIOException(WindowsException.java:86)
at sun.nio.fs.WindowsException.rethrowAsIOException(WindowsException.java:97)
at sun.nio.fs.WindowsException.rethrowAsIOException(WindowsException.java:102)
at sun.nio.fs.WindowsFileAttributeViews$Basic.readAttributes(WindowsFileAttributeViews.java:53)
at sun.nio.fs.WindowsFileAttributeViews$Basic.readAttributes(WindowsFileAttributeViews.java:38)
at sun.nio.fs.AbstractBasicFileAttributeView.readAttributes(AbstractBasicFileAttributeView.java:168)
at sun.nio.fs.AbstractFileSystemProvider.readAttributes(AbstractFileSystemProvider.java:92)
at java.nio.file.Files.readAttributes(Files.java:1961)
at java.nio.file.Files.getAttribute(Files.java:1866)

如果我从路径中删除 file:// 前缀,则会生成以下错误:

Exception in thread "main" java.nio.file.FileSystemNotFoundException: Provider "https" not installed
at java.nio.file.Paths.get(Paths.java:147)

如果我将“Line2”修改为 Path path=Paths.get("https://abc/dir");,则会生成以下跟踪:

Exception in thread "main" java.nio.file.InvalidPathException: Illegal char <:> at index 5: https://abc/dir
at sun.nio.fs.WindowsPathParser.normalize(WindowsPathParser.java:182)
at sun.nio.fs.WindowsPathParser.parse(WindowsPathParser.java:153)
at sun.nio.fs.WindowsPathParser.parse(WindowsPathParser.java:77)
at sun.nio.fs.WindowsPath.parse(WindowsPath.java:94)
at sun.nio.fs.WindowsFileSystem.getPath(WindowsFileSystem.java:255)
at java.nio.file.Paths.get(Paths.java:84)

请让我知道我在这里做错了什么,以及是否可以使用 Java 监视服务或是否有任何其他框架/api 来监视此类 Web 资源。

谢谢

最佳答案

您给它混合了 file 协议(protocol)和 http 协议(protocol),这实际上没有意义。

基本上,如果您访问资源的唯一方式是通过 HTTP,则您无法做您想做的事。当 HTTP 资源发生变化时,没有通用的机制来获得通知,因为没有通用的机制从 HTTP 资源获得推送通知,而且它在操作系统的控制之外,所以它无法在发生变化时拦截它们。对于本地文件,您的操作系统可以在发生变化时检测到变化,因为它最终负责处理对本地磁盘的写入,但这不适用于您的情况。

您需要一些可以轮询更改的东西,除非 S3 有一些定制的东西来推送更改通知(但这是您必须单独调查的东西)。你不能用 Java NIO 做到这一点。

关于java - 使用 Java NIO 监视服务监视 http 资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27226592/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com