如何使用SQLite

时间:2017-05-09 14:16:31

标签: java hibernate sqlite maven executable-jar

我正在尝试创建一个java应用程序的可运行jar。我正在使用Hibernate和Spring。我的项目是一个具有以下结构的maven项目:

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>

我正在使用hibernate与sqlite数据库通信以执行读取和写入操作。 hibernate的.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是一个嵌入式数据库。不过我在google上也发现只有当你把它放在.jar中时它才会被读取。如何以安全的方式使用应用程序分发数据库? (安全意味着它不能被覆盖,打开或轻松阅读)。

1 个答案:

答案 0 :(得分:0)

一旦交出你就迷失了(正如Tschallacka所说)。

你在这里几乎没有选择(但他们只会“减少伤害”):

  • 校验和(以验证数据库的一致性)
  • 将您的数据库创建查询嵌入到代码中,如果有人使用它,则重新创建它
  • 在内存解决方案中使用:

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

但你仍然需要保护你保存的状态(例如加密它)。