使用Kotlin和Spring Boot构建一个最简单的Web API

简而言之

    • Kotlin + SpringBootを扱ってみましたので、環境構築メモです。

 

    Spring Data JPAでテーブルアクセスし、JSON形式でブラウザに返却するところまでを書いております。

创建Spring项目

Spring Initializrを使います。
設定は下記のようにしました。

image.png

下载 IntelliJ IDEA

IntelliJ IDEAをダウンロードします。
Community版(無料)で大丈夫です。

导入已创建的项目

    IntelliJ IDEAより [File] -> [Open…] を選択し、作成したプロジェクトを取り込みます。
image.png

将JPA注释掉

dependencies {
//  implementation("org.springframework.boot:spring-boot-starter-data-jpa")
    implementation("org.springframework.boot:spring-boot-starter-web")
    implementation("com.fasterxml.jackson.module:jackson-module-kotlin")
    implementation("org.jetbrains.kotlin:kotlin-reflect")
    implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
    compileOnly("org.projectlombok:lombok")
    annotationProcessor("org.projectlombok:lombok")
    testImplementation("org.springframework.boot:spring-boot-starter-test")
}

写一个控制器

    • Controllerクラスを書きます。

 

    事前にcontrollerパッケージを作成しておきます。
package com.example.demo.controller

import org.springframework.http.MediaType
import org.springframework.http.ResponseEntity
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RestController

@RestController
@RequestMapping("/demo")
class DemoController {

    @GetMapping("/getAll")
    fun getAll(): ResponseEntity<String> {
        return ResponseEntity.ok("Demo")
    }

}

启动项目

    [View] -> [Tool Windows] -> [Gradle] -> [Tasks] -> [application] -> [bootRun] を選択してプロジェクトを実行します。
image.png
    下記のようなログが出ればOKです。
18:32:18: Executing task 'bootRun'...

> Task :compileKotlin
> Task :compileJava NO-SOURCE
> Task :processResources UP-TO-DATE
> Task :classes UP-TO-DATE
> Task :bootRunMainClassName

> Task :bootRun

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::                (v2.4.3)

2021-03-13 18:32:21.905  INFO 8184 --- [           main] com.example.demo.DemoApplicationKt       : Starting DemoApplicationKt using Java 1.8.0_241 on DESKTOP-I88K5MF with PID 8184 
2021-03-13 18:32:21.905  INFO 8184 --- [           main] com.example.demo.DemoApplicationKt       : No active profile set, falling back to default profiles: default
2021-03-13 18:32:23.034  INFO 8184 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2021-03-13 18:32:23.050  INFO 8184 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2021-03-13 18:32:23.050  INFO 8184 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.43]
2021-03-13 18:32:23.128  INFO 8184 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2021-03-13 18:32:23.128  INFO 8184 --- [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1155 ms
2021-03-13 18:32:23.425  INFO 8184 --- [           main] o.s.s.concurrent.ThreadPoolTaskExecutor  : Initializing ExecutorService 'applicationTaskExecutor'
2021-03-13 18:32:23.662  INFO 8184 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2021-03-13 18:32:23.677  INFO 8184 --- [           main] com.example.demo.DemoApplicationKt       : Started DemoApplicationKt in 2.308 seconds (JVM running for 2.822)
2021-03-13 18:32:26.108  INFO 8184 --- [nio-8080-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2021-03-13 18:32:26.108  INFO 8184 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2021-03-13 18:32:26.116  INFO 8184 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 8 ms

    ブラウザでhttp://localhost:8080/demo/getAllを表示する → Demoが表示されます。

为了使用JPA进行数据访问,需要准备Mysql数据库。

    テーブルを作っておきます。
create database demo;
use demo;
create table demo (
    id int auto_increment,
    name varchar(256),
    PRIMARY KEY (id)
);
insert into demo (name) values ("test");

在application.properties中添加配置。

spring.datasource.url=jdbc:mysql://localhost:3306/demo?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.jpa.database=MYSQL
spring.jpa.hibernate.ddl-auto=update

参考:
尝试使用Java连接数据库(MySQL)时出现错误的解决方案
使用SpringBoot + Spring JPA与数据库进行连接

取消JPA的注释,并添加驱动程序。


dependencies {
+   implementation("org.springframework.boot:spring-boot-starter-data-jpa")
    implementation("org.springframework.boot:spring-boot-starter-web")
    implementation("com.fasterxml.jackson.module:jackson-module-kotlin")
    implementation("org.jetbrains.kotlin:kotlin-reflect")
    implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
+   implementation("mysql:mysql-connector-java:8.0.20")
    compileOnly("org.projectlombok:lombok")
    annotationProcessor("org.projectlombok:lombok")
    testImplementation("org.springframework.boot:spring-boot-starter-test")
}

创建实体

    • 事前にentityパッケージを作成しておきます。

 

    Demo.ktを書きます。
package com.example.demo.entity

import javax.persistence.Entity
import javax.persistence.GeneratedValue
import javax.persistence.Id

@Entity
class Demo (
        var name: String? = null,
        @Id
        @GeneratedValue
        var id: Long? = null)

创建代码库

    • 事前にrepositoryパッケージを作成しておきます。

 

    DemoRepository.ktを作成します。
package com.example.demo.repository

import com.example.demo.entity.Demo
import org.springframework.data.repository.CrudRepository

interface DemoRepository : CrudRepository<Demo, Long> {
    fun findAllByOrderById(): Iterable<Demo>
}

修改控制器


package com.example.demo.controller

import com.example.demo.entity.Demo
import com.example.demo.repository.DemoRepository
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.http.MediaType
import org.springframework.http.ResponseEntity
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RestController

@RestController
@RequestMapping("/demo")
class DemoController @Autowired constructor(  //修正
        val demoRepository: DemoRepository)   //修正
{                                             //修正   

    @GetMapping("/getAll")
    fun getAll(): ResponseEntity<Iterable<Demo>> {             //修正
        val demos = demoRepository.findAllByOrderById()        //修正  
        return ResponseEntity.ok(demos)                        //修正 
    }

}

用浏览器进行显示

    • ブラウザでhttp://localhost:8080/demo/getAllを表示します

 

    下記のようにDBに登録されたデータが返却されていることを確認します。
image.png

总结

    kotlin + Spring BootでJSONをGetするところまでやりました。何かの参考になれば幸いです。

参考文献:
使用Spring Data JPA入门
使用Kotlin和Spring Boot 2.0实现简单的Rest API

广告
将在 10 秒后关闭
bannerAds