在程序文件夹中创建锁定文件会导致异常

时间:2013-01-21 04:16:57

标签: java locking file-permissions h2

我最近决定使用Java应用程序的官方安装程序。

应用程序将自己安装在“程序文件”下的相应文件夹中。

在我的应用程序的jar所在的bin文件夹中,我有一个h2.db文件,其中包含应用程序读取的一堆信息。

当我尝试在安装位置运行应用程序时,我得到一个例外:

org.h2.jdbc.JdbcSQLException: IO Exception: "java.io.FileNotFoundException: C:\Program Files (x86)\Aurora Game Hub\bin\AuroraDB.lock.db (Access is denied)"; "C:/Program Files (x86)/Aurora Game Hub/bin/AuroraDB.lock.db" [90031-167]
        at org.h2.message.DbException.getJdbcSQLException(DbException.java:329)
        at org.h2.message.DbException.get(DbException.java:158)
        at org.h2.message.DbException.convertIOException(DbException.java:315)
        at org.h2.store.fs.FilePathDisk.newOutputStream(FilePathDisk.java:265)
        at org.h2.store.fs.FileUtils.newOutputStream(FileUtils.java:223)
        at org.h2.store.FileLock.save(FileLock.java:197)
        at org.h2.store.FileLock.lockFile(FileLock.java:333)
        at org.h2.store.FileLock.lock(FileLock.java:128)
        at org.h2.engine.Database.open(Database.java:542)
        at org.h2.engine.Database.openDatabase(Database.java:222)
        at org.h2.engine.Database.<init>(Database.java:217)
        at org.h2.engine.Engine.openSession(Engine.java:56)
        at org.h2.engine.Engine.openSession(Engine.java:159)
        at org.h2.engine.Engine.createSessionAndValidate(Engine.java:138)
        at org.h2.engine.Engine.createSession(Engine.java:121)
        at org.h2.engine.Engine.createSession(Engine.java:28)
        at org.h2.engine.SessionRemote.connectEmbeddedOrServer(SessionRemote.java:305)
        at org.h2.jdbc.JdbcConnection.<init>(JdbcConnection.java:110)
        at org.h2.jdbc.JdbcConnection.<init>(JdbcConnection.java:94)
        at org.h2.Driver.connect(Driver.java:72)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at aurora.engine.V1.Logic.ASimpleDB.searchAprox(ASimpleDB.java:828)
        at aurora.V1.core.GameSearch.searchGame(GameSearch.java:249)
        at aurora.V1.core.GameSearch.run(GameSearch.java:346)
        at java.lang.Thread.run(Unknown Source)
Caused by: java.io.FileNotFoundException: C:\Program Files (x86)\Aurora Game Hub\bin\AuroraDB.lock.db (Access is denied)
        at java.io.FileOutputStream.open(Native Method)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at org.h2.store.fs.FilePathDisk.newOutputStream(FilePathDisk.java:257)
        ... 22 more

当它不在Program Files位置时工作正常,因为我在开发时会注意到这一点。

我认为它与权限有关,而且无法创建锁定文件或其他东西。有没有办法给出/要求显式创建锁文件的权限,还是我可以告诉H2不要创建锁文件?

我们考虑过将静态数据库放在除安装位置之外的某个位置,但由于必须在Mac和PC上运行,并且安装程序的设置方式会使事情变得更复杂。

非常感谢任何帮助。

3 个答案:

答案 0 :(得分:1)

似乎没有写入此目录的访问权限。您需要将数据库文件存储在您具有访问权限的目录中。

对于H2,如果使用数据库URL jdbc:h2:~/data/db,则相对于当前用户主目录存储数据库。另一种方法是使用绝对路径,例如jdbc:h2:c:/dir/to/db/file

答案 1 :(得分:0)

这是由Windows中安全性的提高引起的。只有在您拥有升高的特权时才可以写作。例如,如果您将程序作为“以管理员身份运行”启动,则它可以写入“程序文件”区域。然后这不是一个好主意 - 请参阅:Bypass Windows permission restrictions on program files folder

您应该使用'ProgramData'变量指向的文件夹。或者好的旧用户。

答案 2 :(得分:0)

在Mac OS X上,您可以使用引用hereuser.home已知子目录。

{p> Java Web Start可以选择合适的permissions,但我还没有尝试过。