[問題] jar 檔裡面的 sqlite

作者: swallowcc (guest)   2020-04-12 13:28:01
因為最近有個需求要寫個 client 的小程式
所以打算在 jar 裡面嵌一個 sqlite db 去記錄一些簡單的設定, 不過踩到了地雷。
目前 sqlite db 是放在 resource/sqlite 資料夾裡面
連線設定是這樣的 https://i.imgur.com/hy9Qv5P.jpg
不過測試中發現,用 ui 工具 (sqlite browser) 點開 db 後沒看到寫入的資料。
但用程式去讀取測試時,還是有看到那些資料列出。
這狀況不管是在 IDE 裡面跑,或者包成 jar 跑時都一樣。
然後包成 jar 執行還有一個特殊狀況...
先把同一個設定的 jar 分別命名成 a.jar 跟 b.jar。
執行完 a.jar 之後結束並砍掉 a.jar 程式,然後將 b.jar 更名成 a.jar 後執行,
居然發現更名完的 b.jar 可以讀取到剛剛經由 a.jar 新增的資料。
猜測可能是因為 sqlite db 在寫入資料之前會產一些 cache 檔案,
但這些檔案並無法放進 jar, 所以便在 tmp 資料夾裡面放著。
而 b.jar 更名之後可以直接去讀那些 cache 檔案,
因而產生 b.jar 也可以讀到資料的狀況。
(這兩個 a b jar 解壓縮後點開 sqlite db 也一樣沒資料)
不過這段就純猜測而已,實際上不理解這個機制是怎樣處理的。
最後是把連線字串裡面 sqlite db 位置指成絕對路徑,結果就正常了。
(也就是圖片中標註起來那句)
...
所以想請問一下有沒有人知道這個地雷是怎麼回事?
以及想問,如果想在 jar 裡面放 sqlite 一般是怎麼做?
還是說通常不會塞進 jar ,只會拿到使用者不知道的固定位置擺著呢?
感恩~ <(_ _)>
作者: ssccg (23)   2020-04-12 16:15:00
如果只是純讀取就算了,有寫入的話通常一定會copy出來用不會直接對資源檔寫入吧
作者: qrtt1 (有些事,有時候。。。)   2020-04-12 22:30:00
jar 就只是一個 zip 檔,應該沒有人想要反覆地解壓縮,壓縮那個地方,本來就不是設計給你寫入的地方。你就在使用者的$HOME 下,生個資料夾來放它吧。
作者: dennisxkimo (Dennis(一上B就糟糕))   2020-04-13 12:55:00
你也可以光明正大把db放著 只是內容都是加密的

Links booklink

Contact Us: admin [ a t ] ucptt.com