我最近决定使用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上运行,并且安装程序的设置方式会使事情变得更复杂。
非常感谢任何帮助。
答案 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)