[問題] jar 檔裡面的 sqlite

看板java作者時間4年前 (2020/04/12 13:28), 4年前編輯推噓0(006)
留言6則, 3人參與, 4年前最新討論串1/1
因為最近有個需求要寫個 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
如果只是純讀取就算了,有寫入的話通常一定會copy出來用
04/12 16:15, 1F

04/12 16:16, 4年前 , 2F
不會直接對資源檔寫入吧
04/12 16:16, 2F
原來如此 @@ 以前沒這麼做過,還以為直接寫就好,感謝~

04/12 22:30, 4年前 , 3F
jar 就只是一個 zip 檔,應該沒有人想要反覆地解壓縮,壓縮
04/12 22:30, 3F

04/12 22:31, 4年前 , 4F
那個地方,本來就不是設計給你寫入的地方。你就在使用者的
04/12 22:31, 4F

04/12 22:31, 4年前 , 5F
$HOME 下,生個資料夾來放它吧。
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
你也可以光明正大把db放著 只是內容都是加密的
04/13 12:55, 6F
文章代碼(AID): #1UagRZid (java)
文章代碼(AID): #1UagRZid (java)