Windows10上でeclipseを使用してjavaによりプログラムを作成しています。
javaのFileDialogクラスを使って、ダイアログ・ウィンドウを表示させてファイルを選択しようとしています。
eclipseで動作確認後、warファイルにエクスポートし、Windowsのtomcatのwebappsに配置して動作確認をしたときに、tomcatの起動方法により動作に違いがありました。
tomcatをTomcat9.exeで起動した場合は、思い通りに動作しファイル選択できますが、Tomcat9w.exeから起動した場合は、ダイアログ・ウィンドウが表示しません。
Tomcat9w.exe から起動した場合にダイアログ・ウィンドウを表示させるにはどうすればよいのでしょうか?
ちなみに、権限の問題かとも考えて、Tomcat9w.exe を起動してからのLogOnタブで、Local System accountを選択しているところをThis accountを選択してwindowsのログインアカウントにしても結果は同じでした。
また、catalinaログを確認しましたが、Tomcat Webアプリケーションマネージャから該当アプリケーションを配備解除したタイミングで、以下のメッセージ(抜粋)が出力されています。
情報 [http-nio-8080-exec-10] org.apache.catalina.core.StandardWrapper.unload サーブレット [dialog.Window] の [1] インスタンスが割り当て解除されるのを待機しています 警告 [http-nio-8080-exec-10] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesThreads Webアプリケーション[FileDialogTest]はまだ完了していないリクエストを処理しています。 これはメモリリークを引き起こす可能性が非常に高いです。 リクエストの終了時間は、StandardContext実装のunloadDelay属性を使用して制御できます。 java.base@14.0.2/java.lang.Object.wait(Native Method) java.base@14.0.2/java.lang.Object.wait(Object.java:321) java.desktop@14.0.2/java.awt.WaitDispatchSupport.enter(WaitDispatchSupport.java:264) java.desktop@14.0.2/java.awt.Dialog.show(Dialog.java:1070) java.desktop@14.0.2/java.awt.Component.show(Component.java:1717) java.desktop@14.0.2/java.awt.Component.setVisible(Component.java:1664) java.desktop@14.0.2/java.awt.Window.setVisible(Window.java:1023) java.desktop@14.0.2/java.awt.Dialog.setVisible(Dialog.java:1005) dialog.Window.selectFile(Window.java:54) dialog.Window.doPost(Window.java:33) javax.servlet.http.HttpServlet.service(HttpServlet.java:652)
ログの
java.desktop@14.0.2/java.awt.Dialog.setVisible(Dialog.java:1005)
dialog.Window.selectFile(Window.java:54)
の部分から、
dialog.setVisible(true);
で処理が止まっているような気がします。
どなたか、ご教授頂ければ幸いです。
環境は以下の通りです。
Windows 10
JDK 14.0.2
Apache Tomcat 9.0.37
javaとjspのソースは以下の通りです。
Window.java
java
1package dialog; 2 3import java.awt.FileDialog; 4import java.awt.Frame; 5import java.io.File; 6import java.io.IOException; 7import java.io.PrintWriter; 8 9import javax.servlet.RequestDispatcher; 10import javax.servlet.ServletException; 11import javax.servlet.annotation.WebServlet; 12import javax.servlet.http.HttpServlet; 13import javax.servlet.http.HttpServletRequest; 14import javax.servlet.http.HttpServletResponse; 15 16/** 17 * Servlet implementation class Window 18 */ 19@WebServlet("/Window") 20public class Window extends HttpServlet { 21 private static final long serialVersionUID = 1L; 22 23 /** 24 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 25 */ 26 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 27 // TODO Auto-generated method stub 28 // doGet(request, response); 29 response.setContentType("text/html; charset=UTF-8"); 30 PrintWriter out = response.getWriter(); 31 32 File[] files = selectFile(); 33 34 if (files.length == 0) { 35 RequestDispatcher rd = request.getRequestDispatcher("Start.jsp"); 36 rd.forward(request, response); 37 return; 38 } 39 40 for (File afile : files) { 41 String name = afile.getName(); 42 out.printf("FILE: %s<br>", name); 43 } 44 } 45 46 47 File[] selectFile() { 48 String dialogName = "ファイルを選択"; 49 FileDialog dialog = new FileDialog((Frame)null, 50 dialogName, 51 FileDialog.LOAD); 52 dialog.setMultipleMode(true); 53 dialog.setVisible(true); 54 File[] files = dialog.getFiles(); 55 dialog.dispose(); 56 return files; 57 } 58 59} 60
Start.jsp
jsp
1<%@ page language="java" contentType="text/html; charset=UTF-8" 2 pageEncoding="UTF-8"%> 3 4<!DOCTYPE html> 5<html> 6<head> 7 <meta charset="UTF-8"> 8 <title>TITLE</title> 9</head> 10 11<body> 12 13 <h2>ファイルを選択</h2> 14 15 <form action="Window" method="POST" > 16 <input type="submit" value="開始"><br> 17 </form> 18 19</body> 20</html>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/09/19 21:34
2020/09/20 05:16 編集
2020/09/20 20:48