Java Application Bundled for Mac无法启动

时间:2013-02-28 17:37:38

标签: java macos bundle

我正在使用jarbundler 2.2.0,因为应用程序应该由Apple在JRE 1.6上运行。

该捆绑似乎是正确的,显示了相应的图标,但点击它不会做任何事情。如果我进入它的内容并尝试双击指定的主文件的jar工作正常。

有没有办法看看发生了什么?我可以看到某种错误或日志?

修改 请求的Info.plist。由于代码是私有的,我用Application替换了一些东西:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<plist version="1.0">
  <dict>
    <key>CFBundleName</key>
    <string>Application</string>
    <key>CFBundleShortVersionString</key>
    <string>2.2.0</string>
    <key>CFBundleGetInfoString</key>
    <string>Application version</string>
    <key>CFBundleAllowMixedLocalizations</key>
    <string>false</string>
    <key>CFBundleInfoDictionaryVersion</key>
    <string>6.0</string>
    <key>CFBundleExecutable</key>
    <string>JavaApplicationStub</string>
    <key>CFBundleDevelopmentRegion</key>
    <string>English</string>
    <key>CFBundlePackageType</key>
    <string>APPL</string>
    <key>CFBundleSignature</key>
    <string>????</string>
    <key>CFBundleVersion</key>
    <string>beta</string>
    <key>CFBundleIconFile</key>
    <string>SynamicD.icns</string>
    <key>CFBundleIdentifier</key>
    <string>net.sourceforge.javydreamercsw</string>
    <key>Java</key>
    <dict>
      <key>MainClass</key>
      <string>net.sourceforge.javydreamercsw.Main</string>
      <key>JVMVersion</key>
      <string>1.6.*</string>
      <key>ClassPath</key>
      <array>
        <string>$JAVAROOT/Application.jar</string>
        <string>$JAVAROOT/lib\lib1.jar</string>
        <string>$JAVAROOT/lib\lib2.jar</string>
      </array>
      <key>Properties</key>
      <dict>
        <key>apple.awt.textantialiasing</key>
        <string>true</string>
        <key>apple.awt.brushMetal</key>
        <string>true</string>
        <key>apple.laf.useScreenMenuBar</key>
        <string>true</string>
        <key>apple.awt.showGrowBox</key>
        <string>true</string>
      </dict>
    </dict>
  </dict>
</plist>

PkgInfo的内容:

APPL????

在Application.app/Contents/MacOS上我有来自Mac机器的JavaApplicationStub。

产生的文件结构:

Application.app
|
---Contents
      |
      ---Info.plist
      ---PkgInfo
      ---MacOS
            |
      |      ---JavaApplicationStub
      ---Resources
            |
             ---Java
                  |
                   ----lib
                        |
                         ---lib1.jar
                        |
                         ---lib2.jar
                  |
                   ---Application.jar
            |
             ---Application.icns

请求输出到命令:

~ $ java -version
java version "1.7.0_17"
Java(TM) SE Runtime Environment (build 1.7.0_17-b02)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01, mixed mode)
~ $ sw_vers -productVersion
10.8.2
~ $ /usr/libexec/java_home -V
Matching Java Virtual Machines (4):
    1.7.0_17, x86_64:   "Java SE 7" /Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home
    1.7.0_15, x86_64:   "Java SE 7" /Library/Java/JavaVirtualMachines/jdk1.7.0_15.jdk/Contents/Home
    1.6.0_43-b01-447, x86_64:   "Java SE 6" /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home
    1.6.0_43-b01-447, i386: "Java SE 6" /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home

/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home
~ $ /usr/libexec/java_home
/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home
~ $ echo $JAVA_HOME

~ $ echo $JAVA_ARCH

~ $ /Library/Internet\ Plug-Ins/JavaAppletPlugin.plugin/Contents/Home/bin/java -version
java version "1.7.0_17"
Java(TM) SE Runtime Environment (build 1.7.0_17-b02)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01, mixed mode)
~ $ ls /Library/Java/JavaVirtualMachines
jdk1.7.0_15.jdk jdk1.7.0_17.jdk
~ $ /System/Library/Frameworks/JavaVM.framework/Commands/java -version
java version "1.6.0_43"
Java(TM) SE Runtime Environment (build 1.6.0_43-b01-447-11M4203)
Java HotSpot(TM) 64-Bit Server VM (build 20.14-b01-447, mixed mode)
~ $ 

2 个答案:

答案 0 :(得分:3)

那些反斜杠肯定是错误的,因为Mac OS是Unix。应该是:

  <array>
    <string>$JAVAROOT/Application.jar</string>
    <string>$JAVAROOT/lib/lib1.jar</string>
    <string>$JAVAROOT/lib/lib2.jar</string>
  </array>

既然你说你在Windows上这样做了,我要检查的另一件事是文件权限。特别是这些文件:

  • MacOS / JavaApplicationStub(rwxrwxr-x)
  • Resources / Java / Application.jar(-rw-rw-r--)
  • Resources / Java / lib / lib1.jar(-rw-rw-r - )
  • Resources / Java / lib / lib2.jar(-rw-rw-r - )

最后,1.6 *的JVMVersion是not recommended。请尝试使用1.5+或1.6+,因为它可能更兼容。

排除以上所有问题,问题必须在于JavaApplicationStub。请注意,来自JarBundler页面:

  

在Windows或Linux下使用JarBundler ANT任务时,开发人员必须提供JavaApplicationStub的副本。这不能从源构建,但必须从Mac OS X系统获得。

Java启动存根的已知问题

  

2006年初,Apple升级到Quicktime(7.0.4)导致更老   “JavaApplicationStub”的版本无法启动。这些旧的   副本来自首次创建应用程序包的开发人员   作为目录,然后通过替换JAR创建新的应用程序   bundle中的文件,而不是用。替换“JavaApplicationStub”   更新的副本。

答案 1 :(得分:1)

您是否尝试使用open

通过终端启动应用程序
open Application.app

这可以为您提供有关应用程序无法执行jar的原因的更多信息。

更新: 通过open收益:

  

LSOpenURLsWithRole()失败,文件错误为-10810 /Users/MacBookPro/NetBeansProjects/SynamicD/dist/SynamicD.app

引用https://developer.apple.com/library/mac/documentation/Carbon/Reference/LaunchServicesReference/LaunchServicesReference.pdf(第69页)显示错误说明为:

  

kLSUnknownErr -10810发生了未知错误。适用于OS X v10.0及更高版本。