作者swallowcc ()
看板java
標題[問題] jar 檔裡面的 sqlite
時間Sun Apr 12 13:28:01 2020
因為最近有個需求要寫個 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://webptt.com/m.aspx?n=bbs/java/M.1586669283.A.B27.html
1F:→ ssccg: 如果只是純讀取就算了,有寫入的話通常一定會copy出來用 04/12 16:15
2F:→ ssccg: 不會直接對資源檔寫入吧 04/12 16:16
原來如此 @@ 以前沒這麼做過,還以為直接寫就好,感謝~
3F:→ qrtt1: jar 就只是一個 zip 檔,應該沒有人想要反覆地解壓縮,壓縮 04/12 22:30
4F:→ qrtt1: 那個地方,本來就不是設計給你寫入的地方。你就在使用者的 04/12 22:31
5F:→ qrtt1: $HOME 下,生個資料夾來放它吧。 04/12 22:31
給 user 使用時還是盡量希望把 db 藏起來啦...
雖然會被改的機率不高,但還是想至少做一點基本防護這樣。
然後還要考慮 OS 跟多人使用問題 @@ 總之還是謝謝回應了~ 再思考看看。
※ 編輯: swallowcc (49.216.102.98 臺灣), 04/12/2020 22:47:05
6F:→ dennisxkimo: 你也可以光明正大把db放著 只是內容都是加密的 04/13 12:55