已签名的JNLP小程序在加载时卡住

3

我有一个小程序,一个月前还很好用,但现在在启动时卡住了。这会锁定任何浏览器,所以必须停止该进程。只有这个小程序出现问题。

控制台日志显示jnlp文件正在加载和重新加载。不确定这是否是问题。没有抛出异常。我从未到达安全检查点。最后出现以下内容:

 basic: Relaunch because: [currently running JRE doesn't satisfy (version/args)]

这是控制台日志的底部部分。
network: Created version ID: 1.7.0.21
network: Created version ID: 1.7
network: Created version ID: 2.2.21
network: Cache entry found [url: http://WS001LT9138PRD/web4/lib/configurator.jnlp, version: null] prevalidated=false/0
cache: Adding MemoryCache entry: http://WS001LT9138PRD/web4/lib/configurator.jnlp
temp: new XMLParser with source:
temp: <?xml version="1.0" encoding="utf-8"?>
<jnlp spec="6.0+" href="configurator.jnlp">

   <security>
      <all-permissions />
   </security>
   <resources>
      <java version="1.6+" max-heap-size="512m" java-vm-args="-Xss=256K"/>
      <jar href="configurator.jar" />
   </resources>
   <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet"
      width="1152" height="864">
   </applet-desc>
</jnlp>

temp: 

returning ROOT as follows:

<jnlp spec="6.0+" href="configurator.jnlp">

  <security>
    <all-permissions/>
  </security>
  <resources>
    <java version="1.6+" max-heap-size="512m" java-vm-args="-Xss=256K"/>
    <jar href="configurator.jar"/>
  </resources>
  <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet" width="1152" height="864"/>
</jnlp>
network: Created version ID: 1.6+
network: Created version ID: 1.9
temp: returning LaunchDesc from XMLFormat.parse():

<jnlp spec="6.0+" codebase="http://WS001LT9138PRD/web4/lib/" href="http://WS001LT9138PRD/web4/lib/configurator.jnlp">

  <security>
    <all-permissions/>
  </security>
  <update check="timeout" policy="always"/>
  <resources>
    <java max-heap-size="536870912" java-vm-args="-Xss=256K" version="1.6+"/>
    <jar href="http://WS001LT9138PRD/web4/lib/configurator.jar" download="eager" main="false"/>
  </resources>
  <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet" documentbase="http://ws001lt9138prd/cseg/web/ajax/cfg/config_applet2.jsp?ui=applet&cmd=CFG&username=admin&product_id=TTT" width="1152" height="864"/>
</jnlp>
cache: Resource http://WS001LT9138PRD/web4/lib/configurator.jnlp has expired.
network: Connecting http://WS001LT9138PRD/web4/lib/configurator.jnlp with proxy=DIRECT
network: Connecting http://WS001LT9138PRD:80/ with proxy=DIRECT
network: Connecting http://WS001LT9138PRD/web4/lib/configurator.jnlp with cookie "uuid=1a852b20-5ad7-411e-bb1a-837770f71c73; uuidinstance=1"
network: ResponseCode for http://WS001LT9138PRD/web4/lib/configurator.jnlp : 304
network: Encoding for http://WS001LT9138PRD/web4/lib/configurator.jnlp : null
network: Disconnect connection to http://WS001LT9138PRD/web4/lib/configurator.jnlp
temp: new XMLParser with source:
temp: <?xml version="1.0" encoding="utf-8"?>
<jnlp spec="6.0+" href="configurator.jnlp">

   <security>
      <all-permissions />
   </security>
   <resources>
      <java version="1.6+" max-heap-size="512m" java-vm-args="-Xss=256K"/>
      <jar href="configurator.jar" />
   </resources>
   <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet"
      width="1152" height="864">
   </applet-desc>
</jnlp>

temp: 

returning ROOT as follows:

<jnlp spec="6.0+" href="configurator.jnlp">

  <security>
    <all-permissions/>
  </security>
  <resources>
    <java version="1.6+" max-heap-size="512m" java-vm-args="-Xss=256K"/>
    <jar href="configurator.jar"/>
  </resources>
  <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet" width="1152" height="864"/>
</jnlp>
network: Created version ID: 1.6+
network: Created version ID: 1.9
temp: returning LaunchDesc from XMLFormat.parse():

<jnlp spec="6.0+" codebase="http://WS001LT9138PRD/web4/lib/" href="http://WS001LT9138PRD/web4/lib/configurator.jnlp">

  <security>
    <all-permissions/>
  </security>
  <update check="timeout" policy="always"/>
  <resources>
    <java max-heap-size="536870912" java-vm-args="-Xss=256K" version="1.6+"/>
    <jar href="http://WS001LT9138PRD/web4/lib/configurator.jar" download="eager" main="false"/>
  </resources>
  <applet-desc name="ConfigApplet" main-class="com.configsc.applet.ConfigApplet" documentbase="http://ws001lt9138prd/cseg/web/ajax/cfg/config_applet2.jsp?ui=applet&cmd=CFG&username=admin&product_id=TTT" width="1152" height="864"/>
</jnlp>    

cache: JNLPPreverifyClassLoader.initialize: FAILED: http://WS001LT9138PRD/web4/lib/configurator.jar
    basic: Plugin2ClassLoader.addURL2 called for http://WS001LT9138PRD/web4/lib/configurator.jar
    basic: Plugin2ClassLoader.drainPendingURLs addURL called for http://WS001LT9138PRD/web4/lib/configurator.jar
    network: LaunchDownload: concurrent downloads from LD: 4
    network: Total size to download: -1
    security: Security check for progress jars: allSigned=true
    security: Blacklist revocation check is enabled
    security: blacklist: created: NEED_LOAD, lastModified: 1367506003185
    security: blacklist: hasBeenModifiedSince 0 (we have 1367506003185)
    cache: Trying to update in place C:\Users\AppData\LocalLow\Sun\Java\Deployment\cache\6.0\3\149e9b83-2d476b62.idx
    cache: Upgrade writing to disk for C:\Users\AppData\LocalLow\Sun\Java\Deployment\cache\6.0\3\149e9b83-2d476b62
    security: blacklist: check contains 3COxySh3Q4+QRZlBYHxrjd5s0shhO2/5P3Oghwz5s0U=, state now NEED_LOAD
    security: blacklist: loadCache
    security: blacklist: not  found in cache
    security: Trusted libraries list check is enabled
    security: Trusted libraries list file not found
    cache: Create from verifier: JarSigningData{hasOnlySignedEntries=true, hasSingleCodeSource=true, hasMissingSignedEntries=false}
    cache: Upgrade of entry done
    cache: readIndexFile returning success
    network: Cache entry found [url: http://WS001LT9138PRD/web4/lib/configurator.jar, version: null] prevalidated=false/0
    cache: Adding MemoryCache entry: http://WS001LT9138PRD/web4/lib/configurator.jar
    cache: Resource http://WS001LT9138PRD/web4/lib/configurator.jar has expired.
    network: Connecting http://WS001LT9138PRD/web4/lib/configurator.jar with proxy=DIRECT
    network: Connecting http://WS001LT9138PRD/web4/lib/configurator.jar with cookie "uuid=1a852b20-5ad7-411e-bb1a-837770f71c73; uuidinstance=1"
    network: ResponseCode for http://WS001LT9138PRD/web4/lib/configurator.jar : 304
    network: Encoding for http://WS001LT9138PRD/web4/lib/configurator.jar : null
    network: Disconnect connection to http://WS001LT9138PRD/web4/lib/configurator.jar
    network: Download Progress: jarsDone: 1
        Match: beginTraversal
    network: Created version ID: 1.6+
    network: Created version ID: 1.7
    Match: digest selected JREDesc: JREDesc[version 1.6+, heap=-1-536870912, args=-Xss=256K, href=null, sel=false, null, null], JREInfo: JREInfo for index 0:
        platform is: 1.7
        product is: 1.7.0_21
        location is: http://java.sun.com/products/autodl/j2se
        path is: C:\Program Files\Java\jre7\bin\javaw.exe
        args is: 
        native platform is: Windows, amd64 [ x86_64, 64bit ]
        JavaFX runtime is: JavaFX 2.2.21 found at C:\Program Files\Java\jre7\
        enabled is: true
        registered is: true
        system is: true

        Match: selecting maxHeap: 536870912
        Match: ignoring InitHeap: -1
        Match: digesting vmargs: -Xss=256K
    security:  --- parseCommandLine converted : -Xss=256K
    into:
    [-Xss=256K]
        Match: digested vmargs: [JVMParameters: isSecure: true, args: -Xss=256K]
        Match: JVM args after accumulation: [JVMParameters: isSecure: true, args: -Xss=256K]
        Match: digest LaunchDesc: http://WS001LT9138PRD/web4/lib/configurator.jnlp
        Match: digest properties: []
        Match: JVM args: [JVMParameters: isSecure: true, args: -Xss=256K]
        Match: endTraversal ..
        Match: JVM args final: -Xmx512m -Xss=256K
    network: Created version ID: 1.7.0.21
    network: Created version ID: 1.7
    network: Created version ID: 2.2.21
        Match: Running JREInfo Version    match: 1.7.0.21 == 1.7.0.21
         Match: Running JVM args mismatch: have:<-Xmx512m -Xss256K> !satisfy want:<-Xmx512m -Xss=256K>
    basic: LaunchDesc location: http://WS001LT9138PRD/web4/lib/configurator.jnlp
    network: Created version ID: 6.0+
    network: Created version ID: 7.0
    basic: Relaunch because: [currently running JRE doesn't satisfy (version/args)] 
    basic: Saving session state to C:\Users\JONATH~1.BRI\AppData\Local\Temp\session7801545931076966323
    basic: Remote relaunch: LaunchJVMAppletMessage{appletID=1, conversationID=1, javaHome=C:\Program Files\Java\jre7, launchTime=15798419052, sendKill=false, [sun.plugin2.main.client.PluginMain, write_pipe_name=jpi2_pid8472_pipe5,read_pipe_name=jpi2_pid8472_pipe4]}
    security:  --- parseCommandLine converted : 
    into:
    []
    security:  --- parseCommandLine converted : -Xmx512m -Xss=256K
    into:
    [-Xmx512m, -Xss=256K]
    network: Created version ID: 2.0+
    network: Created version ID: 1.6.0.10
    basic: RemoteJVMLauncher.start(), pipe=Pipe{transport=WindowsNamedPipe: server: false; readPipe: jpi2_pid8472_pipe2, readBufferSz: 4096; writePipe: jpi2_pid8472_pipe3, writeBufferSz: 4096, initiatingSide=false} message: LaunchJVMAppletMessage{appletID=1, conversationID=1, javaHome=C:\Program Files\Java\jre7, launchTime=15798419052, sendKill=false, [sun.plugin2.main.client.PluginMain, write_pipe_name=jpi2_pid8472_pipe5,read_pipe_name=jpi2_pid8472_pipe4]}
    basic: Thread[RemoteJVMLauncher-1,5,main] running...
    basic: RemoteJVMLauncher.afterStart(): initializing streamers
    handleLaunchJVM(): RemoteJVMLauncer.setCallBack for 1
    security: blacklist: hasBeenModifiedSince 1367517921973 (we have 1367506003185)
    network: CleanupThread used 36730 us
    handleLaunchJVM(): now unregisterApplet 1
    basic: PluginMain.unregisterApplet: 1 from mananger sun.plugin2.applet.JNLP2Manager@2e8d7a0

尝试按照Oracle的Java SE 7桌面技术故障排除指南操作,看看是否有助于诊断您的问题。从描述来看,可能是Java 7u21与您的应用程序不兼容,并且将Java系统更新到Java 7u21导致了您的问题。 - jewelsea
我相信这是真的。我们将在不久的将来更新到非自签名小程序。在开发中,我相信我们可以通过不调用JNLP来启动来解决这个问题。 - jebrick
你解决了这个问题吗? - jsosnowski
2个回答

1
截至Java 7_21版本,您不能再使用自签名的applet与JNLP一起使用。我们的解决方法是在开发时不使用JNLP来调用applet。

1
您不能再使用JNLP自签名小程序。我认为这是不正确的,并通过测试我自己的自签名应用程序进行确认 - 只要用户在出现可怕的对话框时单击“确定”按钮,它就可以正常工作。有关更多信息,请参见详细介绍Java 7 Update 21安全改进 - Andrew Thompson

0

在你的java-vm-args中,你指定了-Xss=256K,但是正确的应该是指定-Xss256K(没有等号)。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接