2017-05-09 20 views
0

我正在嘗試創建java應用程序的可運行jar。我正在使用Hibernate和Spring。我的項目是一個Maven項目結構如下:如何使用SQLite發佈java應用程序

src 
-----/main 
----------/java 
---------------/com 
--------------------/project 
-------------------------/main.java 
----------/resources 
---------------/database.db 
pom.xml 

這是我的一些POM文件的

<url>http://maven.apache.org</url> 

    <parent> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-parent</artifactId> 
     <version>1.4.1.RELEASE</version> 
     <relativePath/> 
    </parent> 

    <properties> 
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    <maven.compiler.source>1.8</maven.compiler.source> 
    <maven.compiler.target>1.8</maven.compiler.target> 
    </properties> 

    <dependencies> 
    <dependency> 
     <groupId>junit</groupId> 
     <artifactId>junit</artifactId> 
     <version>3.8.1</version> 
     <scope>test</scope> 
    </dependency> 

    <!-- Spring --> 
    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-context</artifactId> 
     <version>4.3.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-tx</artifactId> 
     <version>4.3.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>commons-dbcp</groupId> 
     <artifactId>commons-dbcp</artifactId> 
     <version>1.4</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-web</artifactId> 
     <version>1.4.1.RELEASE</version> 
    </dependency> 

    <!-- Hibernate --> 
    <dependency> 
     <groupId>org.hibernate</groupId> 
     <artifactId>hibernate-core</artifactId> 
     <version>4.3.5.Final</version> 
    </dependency> 

    <dependency> 
     <groupId>org.hibernate</groupId> 
     <artifactId>hibernate-entitymanager</artifactId> 
     <version>4.3.5.Final</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-orm</artifactId> 
     <version>4.3.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.xerial</groupId> 
     <artifactId>sqlite-jdbc</artifactId> 
     <version>3.15.1</version> 
    </dependency> 

    <dependency> 
     <groupId>mysql</groupId> 
     <artifactId>mysql-connector-java</artifactId> 
     <version>5.1.31</version> 
    </dependency> 

    <build> 
     <plugins> 
      <plugin> 
       <groupId>org.springframework.boot</groupId> 
       <artifactId>spring-boot-maven-plugin</artifactId> 
      </plugin> 
     </plugins> 
    </build> 

我使用休眠和SQLite數據庫進行通信以執行讀寫操作。休眠的.xml配置:

<beans:bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" 
     destroy-method="close"> 
     <beans:property name="driverClassName" value="org.sqlite.JDBC" /> 
     <beans:property name="url" 
      value="jdbc:sqlite:src/main/resources/database.db" /> 
</beans:bean> 

我希望能夠將應用程序與數據庫一起分發給用戶使用。我已經讀過,sqlite是一個嵌入式數據庫。不過,我也發現在谷歌提到,它只讀,當你把它放在.jar中。我怎樣才能以安全的方式分發數據庫與應用程序? (安全意味着它不能被覆蓋,打開或輕鬆閱讀)。

+1

當您將數據庫發送給消費者時,它不再安全。從jar中提取數據庫很簡單(一個jar只是一個zip),然後在一個sqllite管理器中打開它。任何具有正確權限的程序都可以輕鬆完成。 – Tschallacka

+0

@Tschallacka我不需要全面和完整的安全。我只是想確保數據庫不容易訪問,不能輕易覆蓋。 – user3552551

+0

它是一個靜態只讀數據庫嗎?如果是這樣,請在接口前應用校驗和測試,如果修改則執行嚴重異常。 – Tschallacka

回答

0

一旦你交出來,你就會迷失方向(正如Tschallacka所說)。

您有幾種選擇在這裏(但他們只會「減少損失」):

  • 校驗(驗證數據庫的一致性)
  • 嵌入內部代碼數據庫創建查詢和,萬一有人發揮它,重新創建它在存儲器溶液代替
  • 使用:

https://db.apache.org/derby/docs/10.11/devguide/cdevdvlpinmemdb.html https://sqlite.org/inmemorydb.html

但是你仍然必須保護你的保存狀態(例如,通過加密它)。

+0

除非使用加密和inmemorydb,但有一些限制(內存本身),否則採用sqlite工具將很容易讀取。 – AxelH

+0

是的,當然。這就是爲什麼我說過,在向最終用戶交付任何東西之後,你是無奈的。你唯一能做的就是限制損害。 – mko

+0

由於您按照「_您在這裏有幾個選項_」的說法進行了說明,因此尚不清楚 – AxelH