我正在嘗試創建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中。我怎樣才能以安全的方式分發數據庫與應用程序? (安全意味着它不能被覆蓋,打開或輕鬆閱讀)。
當您將數據庫發送給消費者時,它不再安全。從jar中提取數據庫很簡單(一個jar只是一個zip),然後在一個sqllite管理器中打開它。任何具有正確權限的程序都可以輕鬆完成。 – Tschallacka
@Tschallacka我不需要全面和完整的安全。我只是想確保數據庫不容易訪問,不能輕易覆蓋。 – user3552551
它是一個靜態只讀數據庫嗎?如果是這樣,請在接口前應用校驗和測試,如果修改則執行嚴重異常。 – Tschallacka