如何使用Spring Boot,Spring Data和H2 DB实现REST API

2024-04-30 13:08

本文主要是介绍如何使用Spring Boot,Spring Data和H2 DB实现REST API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在本文中,我们将讨论Kotlin。我在Kotlin中使用Spring Boot,Spring Data和H2内存数据库开发了一个非常简单的REST API。

Kotlin和Spring Boot很好地协同工作。

您将在代码演练部分中注意到项目中没有控制器和NO服务类。这是Spring的魔力,  @RepositoryRestResource下面将进一步解释。

我没有Kotlin的经验,但我在GitHub项目中阅读和看到的Kotlin代码绝对值得探索。

您可能会问的一个重要问题是:为什么Kotlin?

为何选择Kotlin? 

  • Kotlin编译为字节码,因此它可以像Java一样运行。
  • Kotlin比Java更简洁。
  • Kotlin的类比  Data Java的value 类更简洁  。
  • 默认情况下,类是final,对应于Effective Java Item 17 - 如果要使类可继承,则需要显式  打开 
  • 默认情况下,抽象类是打开的。
  • Kotlin的一个关键特性是null-safety,它在编译时干净地处理空值,而不是NullPointerException 在运行时碰到着名  的。 
  • 主构造函数与辅助构造函数 - 如果您需要多个构造函数,那么只有您可以使用辅助构造函数。否则,大多数Kotlin类都会有一个主构造函数。
  • Kotlin也可以用作脚本语言。
  • Kotlin和Java是可互操作的,所以很容易在代码库的一小部分上试用Kotlin。
  • Kotlin使用积极类型推断来确定未声明类型的值和表达式的类型。这减少了相对于Java的语言冗长度。
  • Google完全支持Kotlin与他们的Android操作系统一起使用。

以下两点参考维基百科:

  • “根据JetBrains的博客,Kotlin被亚马逊网络服务,Pinterest,Coursera,Netflix,Uber和其他公​​司使用.Corda是由知名银行财团(如高盛,富国银行,摩根大通)开发的分布式账本,德意志银行,瑞士银行,汇丰银行,法国巴黎银行,法国兴业银行(SociétéGénérale),其代码库中有超过90%的Kotlin。“
  • 根据谷歌的说法,Kotlin已被几家主要开发商采用 - 例如Expedia,Flipboard,Pinterest,Square等 - 用于他们的Android制作应用程序。

代码演练

这个例子的项目代码可以在我的Kotlin Github Repo上找到,演示了一个使用Kotlin和Spring Boot的简单REST API 

克隆  - https://github.com/BeTheCodeWithYou/SpringBoot-Kotlin.git

  • 科特林
  • 春季启动
  • 春季数据
  • H2内存数据库
  • 摇篮

了解build.gradle

 

 org.jetbrains.kotlin:kotlin-gradle-plugin  编译Kotlin源和模块。

 org.jetbrains.kotlin:kotlin-allopen -这是他有趣的部分。在Kotlin中,默认情况下,所有课程都是  最终的。 
现在,为了使类可继承,您必须使用open关键字进行批注。而且,问题在于许多其他库,如Spring,测试库(Mockito等),这需要类和方法成为非最终的。在Spring中,这些类主要包括  @Configuration 类和  @Bean 方法。

这里的规则很简单; 你需要注释  @Configuration 和  @Bean 方法来标记它们是开放的,但这种方法很乏味且容易出错,因此Kotlin提出了编译器插件,通过这种依赖使用和自动化这个过程。 org.jetbrains.kotlin:kotlin-noarg    
 apply plugin: 'kotlin-jpa'

为了能够使用Kotlin不可变类,我们需要启用Kotlin JPA插件。它将为任何使用@Entity注释的类生成no-arg构造函数,  apply plugin: 'kotlin'.

要定位JVM,需要应用Kotlin插件:  apply plugin: 'kotlin-spring'。这是Spring Kotlin集成所必需的

编译器选项

Spring可空性注释为整个Spring API提供了对Kotlin开发人员的null安全性,具有在编译时处理与null相关的问题的优势。可以通过 -Xjsr305 使用strict选项添加编译器标志来启用此功能  。并且,它还配置Kotlin编译器以生成Java 8字节码。

compileKotlin {
kotlinOptions {
freeCompilerArgs  = [ “ -  Xjsr305 = strict” ]
jvmTarget  =  “1.8”
}
}

 

compile("org.jetbrains.kotlin:kotlin-stdlib-jdk8") 我是Kotlin标准库的Java 8变体。

compile('com.fasterxml.jackson.module:jackson-module-kotlin') 一个用于科特林和数据类的序列化/反序列化DDS支持。

compile("org.jetbrains.kotlin:kotlin-reflect") 我是Kotlin反射库。

Spring Boot Gradle插件自动使用Kotlin Gradle插件上声明的Kotlin版本,因此未在依赖项部分明确定义该版本。

所有剩余的条目都是不言自明的。

Kotlin代码

Spring Boot应用程序

/src/main/kotlin/com.xp.springboot.kotlin.SpringBootKotlinRestApiApplication.kt 

注意上面缺少的分号。只有拥有@ Bean时才需要打开和关闭类的大括号。否则,需要一个类  name 。 Runapplication 是一个顶级的功能。

创建数据类

然后,我们通过使用科特林数据类,其目的是为了保存数据,并自动提供创建我们的模型equals()hashCode()toString(),  componentN() 功能,和copy()

此外,您可以在同一数据类中定义多个实体。  Var 类似于一般变量,在Kotlin中被称为可变变量,可以多次分配。

还有另一种类型:  val 类似于常量变量,在Kotlin中被称为不可变的,只能初始化一次。此外,它  val 是只读的,您不能显式写入  val

创建存储库

是的,只有一个单行程序来定义Spring Data curd存储库的存储库接口。这里有趣的Spring注释是  RepositoryRestResource。这是通过添加  spring-boot-starter-data-rest 依赖项来实现的。

如果你注意到,  没有控制器,也没有服务。 此项目在启用HATEOAS的情况下公开以下REST端点。

 GET -  http:// localhost:8080 / parkrun / runners

 POST - http:// localhost:8080 / parkrun / runners

 GET - http:// localhost:8080 / parkrun / runners / 2

 DELETE - http:// localhost:8080 / parkrun / runners / 1

这是神奇的@RepositoryRestResource

应用于collectionResourceRel 定义自定义资源标签,否则,注释将根据模型类名称(/parkRunners)使用默认值。

在运行时,Spring Data REST  将自动创建此接口的实现。然后,它将使用  @RepositoryRestResource 注释来指导Spring MVC并在其中创建RESTful端点   /parkRunners

运行应用程序

在Gradle clean build之后准备好jar后,使用以下命令运行应用程序:   java -jar SpringBootKotlinRestAPI-0.0.1-SNAPSHOT.jar 并点击GET上的URL 。以下是对响应的看法: http://localhost:8080/parkrun  
 

{
    “_links”:{
        “跑步者”:{
            “href”“http:// localhost:8080 / parkrun / runners”
        },
        “个人资料”:{
            “href”“http:// localhost:8080 / parkrun / profile”
        }
    }
 
}

 

http://localhost:8080/parkrun/runners  在GET上点击URL   。

这是你的回答:

{  
   “_embedded”:{  
      “跑步者”:[  
         {  
            “firstName”“NEERAJ”
            “lastName”“SIDHAYE”
            “性别”“M”
            “runningClub”“RUNWAY”
            “totalRuns”“170”
            “_links”:{  
               “自我”:{  
                  “href”“http:// localhost:8080 / parkrun / runners / 1”
               },
               “parkRunner”:{  
                  “href”“http:// localhost:8080 / parkrun / runners / 1”
               }
            }
         }
      ]
   },
   “_links”:{  
      “自我”:{  
         “href”“http:// localhost:8080 / parkrun / runners”
      },
      “个人资料”:{  
         “href”“http:// localhost:8080 / parkrun / profile / runners”
      }
   }
}

 

接下来,选择配置文件URL并查看您使用的内容  http://localhost:8080/parkrun/profile/runners

{
   “阿尔卑斯山”:{
      “版本”“1.0”
      “描述符”:[
         {
            “id”“parkRunner-representation”
            “href”“http:// localhost:8080 / parkrun / profile / runners”
            “描述符”:[
               {
                  “name”“firstName”
                  “type”“SEMANTIC”
               },
               {
                  “name”“lastName”
                  “type”“SEMANTIC”
               },
               {
                  “名字”“性别”
                  “type”“SEMANTIC”
               },
               {
                  “名字”“runningClub”
                  “type”“SEMANTIC”
               },
               {
                  “名字”“totalRuns”
                  “type”“SEMANTIC”
               }
            ]
         },
         {
            “id”“get-runners”
            “名字”“跑步者”
            “类型”“安全”
            “rt”“#parkRunner-representation”
         },
         {
            “id”“创造跑步者”
            “名字”“跑步者”
            “type”“UNSAFE”
            “rt”“#parkRunner-representation”
         },
         {
            “id”“patch-parkRunner”
            “名字”“parkRunner”
            “type”“UNSAFE”
            “rt”“#parkRunner-representation”
         },
         {
            “id”“get-parkRunner”
            “名字”“parkRunner”
            “类型”“安全”
            “rt”“#parkRunner-representation”
         },
         {
            “id”“delete-parkRunner”
            “名字”“parkRunner”
            “type”“IDEMPOTENT”
            “rt”“#parkRunner-representation”
         },
         {
            “id”“update-parkRunner”
            “名字”“parkRunner”
            “type”“IDEMPOTENT”
            “rt”“#parkRunner-representation”
         }
      ]
   }
}

 

希望这有助于您更好地理解Kotlin中REST API的快速开发。快乐的编码!

这篇关于如何使用Spring Boot,Spring Data和H2 DB实现REST API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/948951

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据