Spring Boot + Hibernate Search示例

在这里,我们将使用Hibernate Search + Thymeleaf模板引擎创建一个Spring Boot Web应用程序示例,并将其作为WAR部署到Wildfly 10.1。

使用的技术:

  1. Spring Boot 1.5.6。发布
  2. Java 8
  3. Hibernate Search 5.6.1。最终版
  4. 嵌入式Tomcat,Wildfly 8.1 Final和10.1 Final

1.项目结构

标准的Maven项目结构

1.项目依赖

pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
	http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.mkyong</groupId>
    <artifactId>spring-boot-web-wildfly-search</artifactId>
    <version>0.0.1</version>
    <packaging>war</packaging>
    <name>mkyong-wildfly-spring-boot</name>
    <description>Spring Boot Web Hibernate Search Example</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <logback.version>1.1.9</logback.version>
    </properties>

    <dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <!--
            Comment out if deploy as WAR file
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
            -->
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-search-engine -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-search-engine</artifactId>
            <version>5.6.1.Final</version>
            <exclusions>
                <exclusion>
                    <groupId>org.jboss.logging</groupId>
                    <artifactId>jboss-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-search-orm -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-search-orm</artifactId>
            <version>5.6.1.Final</version>
            <exclusions>
                <exclusion>
                    <groupId>org.jboss.logging</groupId>
                    <artifactId>jboss-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <dependency>
            <groupId>org.hsqldb</groupId>
            <artifactId>hsqldb</ar
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这里提供一个基于 Spring Boot 和 Vue3 的示例项目,可以作为参考: 后端 Spring Boot 部分: 1. 创建一个 Spring Boot 项目,添加以下依赖: ``` <dependencies> <!-- Spring Boot Web --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- Spring Boot Data JPA --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <!-- H2 Database --> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <scope>runtime</scope> </dependency> <!-- Spring Boot Test --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> ``` 2. 在 `application.properties` 文件中配置数据库连接: ``` spring.datasource.url=jdbc:h2:mem:testdb spring.datasource.driverClassName=org.h2.Driver spring.datasource.username=sa spring.datasource.password= spring.jpa.database-platform=org.hibernate.dialect.H2Dialect spring.jpa.hibernate.ddl-auto=update ``` 3. 创建一个实体类 `User`: ``` @Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(nullable = false, unique = true) private String username; @Column(nullable = false) private String password; // getters and setters omitted for brevity } ``` 4. 创建一个 `UserRepository` 接口: ``` public interface UserRepository extends JpaRepository<User, Long> { User findByUsername(String username); } ``` 5. 创建一个 `UserController` 类,处理用户相关的请求: ``` @RestController @RequestMapping("/api/users") public class UserController { @Autowired private UserRepository userRepository; @GetMapping("/{username}") public User getUserByUsername(@PathVariable String username) { return userRepository.findByUsername(username); } @PostMapping("/") public User createUser(@RequestBody User user) { return userRepository.save(user); } } ``` 前端 Vue3 部分: 1. 安装 Vue CLI: ``` npm install -g @vue/cli ``` 2. 创建一个 Vue3 项目: ``` vue create my-project ``` 3. 安装 axios: ``` npm install axios ``` 4. 在 `src/main.js` 文件中添加以下代码: ``` import { createApp } from 'vue' import App from './App.vue' import axios from 'axios' axios.defaults.baseURL = 'http://localhost:8080/api' const app = createApp(App) app.config.globalProperties.$http = axios app.mount('#app') ``` 5. 创建一个 `Users.vue` 组件,显示用户列表: ``` <template> <div> <h1>Users</h1> <ul> <li v-for="user in users" :key="user.id"> {{ user.username }} </li> </ul> </div> </template> <script> export default { data() { return { users: [] } }, mounted() { this.$http.get('/users').then(response => { this.users = response.data }) } } </script> ``` 6. 在 `App.vue` 中添加一个路由: ``` <template> <div> <router-view /> </div> </template> <script> import { createRouter, createWebHashHistory } from 'vue-router' import Users from './Users.vue' const routes = [ { path: '/', component: Users } ] const router = createRouter({ history: createWebHashHistory(), routes }) export default { router } </script> ``` 这样,我们就完成了一个基于 Spring Boot 和 Vue3 的示例项目,可以通过 `npm run serve` 命令启动前端应用,通过 `mvn spring-boot:run` 命令启动后端应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值