Java 从Servlet创建目录并将文件保存在网络位置

Java 从Servlet创建目录并将文件保存在网络位置,java,file,tomcat,servlets,filesystemexception,Java,File,Tomcat,Servlets,Filesystemexception,我在Tomcat服务器(v8)中部署了一个Web应用程序,它在Windows 2008 R2PC中运行服务。在此Web应用程序中,用户使用表单上载文件(照片)。我想要的是将这些照片存储在我网络中的NAS磁盘中(服务器和NAS磁盘都在同一网络下) 我读了这篇相关的文章,并遵循了它。我首先尝试将照片保存到我服务器的本地磁盘C:,结果成功了 public void saveFiles(List<Part> fileParts,String targetId) { Stri

我在
Tomcat服务器
(v8)中部署了一个Web应用程序,它在
Windows 2008 R2
PC中运行服务。在此Web应用程序中,用户使用表单上载文件(照片)。我想要的是将这些照片存储在我网络中的
NAS
磁盘中(服务器和NAS磁盘都在同一网络下)

我读了这篇相关的文章,并遵循了它。我首先尝试将照片保存到我服务器的本地磁盘
C:
,结果成功了

public void saveFiles(List<Part> fileParts,String targetId) { 
        String pathRoot = "C:\\Share\\photos\\;
        String date = new SimpleDateFormat("yyyyMMddHHmmss").format(Calendar.getInstance().getTime());

        try {
            int counter = 1;
            for (Part filePart : fileParts) {

                String destPath = pathRoot + "\\" + targetId;    
                Boolean flag = new File(destPath).mkdirs();                   
                System.err.println("mkdirs flag = " + flag);

                File file = new File(destPath, targetId + " " + date + "-" + counter + ".jpg");

                try (InputStream input = filePart.getInputStream()) {
                    Files.copy(input, file.toPath());
                }

                counter++;
            }
        } catch (IOException ex) {
            ex.printStackTrace();
        }
    }
然后我得到以下错误:

java.nio.file.FileSystemException: \\192.168.0.7\Share\photos\machines\4 20180704110827-1.jpg: Logon failure: unknown user name or bad password.
    at sun.nio.fs.WindowsException.translateToIOException(Unknown Source)
    at sun.nio.fs.WindowsException.rethrowAsIOException(Unknown Source)
    at sun.nio.fs.WindowsException.rethrowAsIOException(Unknown Source)
    at sun.nio.fs.WindowsFileSystemProvider.newByteChannel(Unknown Source)
    at java.nio.file.spi.FileSystemProvider.newOutputStream(Unknown Source)
    at java.nio.file.Files.newOutputStream(Unknown Source)
    at java.nio.file.Files.copy(Unknown Source)
    at com.yaylitizis.production.Actions.saveFiles(Actions.java:1797)
    at com.yaylitizis.production.Actions.processRequest(Actions.java:510)
    at com.yaylitizis.production.Actions.doPost(Actions.java:1893)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:291)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at com.yaylitizis.production.FilterUTF8.doFilter(FilterUTF8.java:27)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:142)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:673)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1526)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1482)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Unknown Source)
为了避免上述错误,如何添加网络磁盘的凭据

编辑1


我从Windows映射了网络磁盘,并且可以访问该文件夹。但是,错误仍然存在。

您可以通过两种方式实现:

1) 由于网络驱动器中的“登录”是由windows完成的,请转到您的服务器(安装并运行tomcat的服务器),访问共享文件夹
\\192.168.0.7\Share\photos
,当它要求提供凭据时,将其放入并使用复选框“在windows上记住凭据”保存。然后,您可以在“控制面板”上编辑或从“管理网络密码”中删除密码。寻找更多信息

2) 您必须为Java使用外部库。有一个有用的答案


希望它能帮助您执行
net use\\192.168.0.7\Share\photos您的密码/user:your domain\your user name/persistent:yes/savecred
。在Web应用程序初始化期间只需执行一次。

它不起作用。。现在我得到一个错误
java.nio.file.NoSuchFileException
,那么,错误在哪里抛出?你走对路了吗<代码>无此文件与身份验证相关错误不同。。。
java.nio.file.FileSystemException: \\192.168.0.7\Share\photos\machines\4 20180704110827-1.jpg: Logon failure: unknown user name or bad password.
    at sun.nio.fs.WindowsException.translateToIOException(Unknown Source)
    at sun.nio.fs.WindowsException.rethrowAsIOException(Unknown Source)
    at sun.nio.fs.WindowsException.rethrowAsIOException(Unknown Source)
    at sun.nio.fs.WindowsFileSystemProvider.newByteChannel(Unknown Source)
    at java.nio.file.spi.FileSystemProvider.newOutputStream(Unknown Source)
    at java.nio.file.Files.newOutputStream(Unknown Source)
    at java.nio.file.Files.copy(Unknown Source)
    at com.yaylitizis.production.Actions.saveFiles(Actions.java:1797)
    at com.yaylitizis.production.Actions.processRequest(Actions.java:510)
    at com.yaylitizis.production.Actions.doPost(Actions.java:1893)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:291)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at com.yaylitizis.production.FilterUTF8.doFilter(FilterUTF8.java:27)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:142)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:673)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1526)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1482)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Unknown Source)