我创建了一个Java桌面应用程序(使用Swing),现在正在尝试使用JNLP从网络启动它。当我从终端启动它时,应用程序工作得很好,但是一旦我从JNLP启动它,它就不会关闭。每次我都得手动杀死这个过程。
我读到,如果我的JFrame使用DISPOSE_ON_CLOSE作为默认的关闭操作,可能会出现问题,但它没有,它使用DO_NOTHING_ON_CLOSE (隐式)。此外,在释放所有对象之后,我将显式调用System.exit(0):
f = new JFrame("Pacman");
f.addWindowListener(new WindowAdapter() {
@Override
public void windowClosing(WindowEvent e) {
// Terminate the Game-loop:
GameLoop.INSTANCE.stopLoop();
// Close the application:
System.exit(0);
}
});我猜当我关闭应用程序时可能会引发异常,但是我找不到一种方法来获得用JNLP启动的正在运行的应用程序的控制台输出(例如堆栈-跟踪)。以下是我尝试过的:
javaws并与jconsole连接(工作,但我找不到任何异常或控制台输出)。javaws,并将IntelliJ调试器附加到它(也可以工作,但不提供任何输出)那么,我如何使用JNLP启动应用程序并获得输出(写入默认的输出流和错误流),就像使用普通桌面应用程序一样?
发布于 2012-06-06 13:12:09
解决方案1-启用Java控制台,并查找异常。
您可以通过Java控制面板来完成它。切换到高级选项卡,并在Java控制台中确保选择Show。
然后,运行您的应用程序并监视控制台中是否有异常。修正异常。
解决方案2-调试正在运行的应用程序(正确)。
像这样启动应用程序(用于Java1.6及更高版本):
javaws -verbose -J-Xdebug -J-Xnoagent -J-Xrunjdwp:transport=dt_socket,server=n,suspend=y,address=8123 http://myserver.com/path/to/myapp.jnlp如果使用早期的java版本(1.4.2,1.5),请设置环境变量,如下所示:
set JAVAWS_VM_ARGS="-Xdebug -Xnoagent -Xrunjdwp:transport=dt_socket,server=n,suspend=y,address=8123"并通过以下方式运行该应用程序:
javaws http://myserver.com/path/to/myapp.jnlp当应用程序运行时:
javaws的参数端口(在本例中为8123)。windowClosing方法中设置一个断点。GameLoop.INSTANCE.stopLoop()方法,以查看挂起的位置/时间。不要期望在控制台中看到解决方案,只需使用调试器执行代码--如果应用程序挂起,它将显示您的位置。
发布于 2017-08-03 16:51:56
有时,即使控制台也不显示任何内容,例如,TLS/SSL握手(即close_notify或handshake_failure)出现问题时。在这些情况下,您需要执行以下操作:

SET命令)。
设置JAVA_TOOL_OPTIONS=-Djavax.net.deb=所有javaws -wait jnlp.jnlp
2.b.在Java > Java > View中为JVM添加参数(即-Djavax.net.debug=all) (在此特定情况下这不是必需的),并从浏览器启动JNLP文件:
log目录中的Java部署主页目录中:
a. Windows XP:%HOME%\Application Data\Sun\Java\Deployment
b. Windows 7/Vista:%APPDATA%\..\LocalLow\Sun\Java\Deployment
c. Linux/Solaris:%HOME%/.java/deployment发布于 2020-02-07 11:34:24
此答案是npe回答的另一种选择,以启用远程调试(Windows)。

在此之后,将编辑器配置为远程调试到已配置的端口(本例中为localhost:8123)。
https://stackoverflow.com/questions/10899675
复制相似问题