[問題] jar 檔裡面的 sqlite
因為最近有個需求要寫個 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 ,只會拿到使用者不知道的固定位置擺著呢?
感恩~ <(_ _)>
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 49.216.102.98 (臺灣)
※ 文章網址: https://www.ptt.cc/bbs/java/M.1586669283.A.B27.html
→
04/12 16:15,
4年前
, 1F
04/12 16:15, 1F
→
04/12 16:16,
4年前
, 2F
04/12 16:16, 2F
原來如此 @@ 以前沒這麼做過,還以為直接寫就好,感謝~
→
04/12 22:30,
4年前
, 3F
04/12 22:30, 3F
→
04/12 22:31,
4年前
, 4F
04/12 22:31, 4F
→
04/12 22:31,
4年前
, 5F
04/12 22:31, 5F
給 user 使用時還是盡量希望把 db 藏起來啦...
雖然會被改的機率不高,但還是想至少做一點基本防護這樣。
然後還要考慮 OS 跟多人使用問題 @@ 總之還是謝謝回應了~ 再思考看看。
※ 編輯: swallowcc (49.216.102.98 臺灣), 04/12/2020 22:47:05
→
04/13 12:55,
4年前
, 6F
04/13 12:55, 6F
java 近期熱門文章
PTT數位生活區 即時熱門文章