Spring Boot で Neo4j からデータ取得して画面表示させてみました。
Neo4j への接続には、組込みNeo4jドライバーを使用しています。本記事では、サンプルコードとその解説を記載します。
Neo4J 接続方式
Neo4J には、HTTP接続と組込みドライバでの接続があります。さらに、Spring Data Neo4jというフレームワークを使用して接続することも出来ます。
今回は、Spring Bootで組込みドライバを使用してNeo4jに接続します。
| Spring Boot | Spring Data Neo4j | |
| HTTP接続 | – | – |
| 組込みドライバ接続 | 当記事で実施 | – |
pom.xmlの設定
Neo4j組み込みドライバーを使用するにあたり、必須なライブラリは次のとおりです。
<dependency> <groupId>org.neo4j.driver</groupId> <artifactId>neo4j-java-driver-spring-boot-starter</artifactId> <version>4.0.1.1</version> </dependency>
全体は次のとおりです。今回のサンプルではブラウザからアクセスするためのライブラリや、ソースコードを修正したら自動でコンパイルしてくれるライブラリが入っています。これらは必須ではありません、作業効率を上げるためのものなので無くてもいいです。
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.7.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<groupId>com.demo</groupId>
<artifactId>app</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>Neo4jSample</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<maven-jar-plugin.version>3.1.1</maven-jar-plugin.version>
</properties>
<dependencies>
<dependency>
<groupId>org.neo4j.driver</groupId>
<artifactId>neo4j-java-driver-spring-boot-starter</artifactId>
<version>4.0.1.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
application.propertiesの設定
設定ファイル application.properties で記述が必要なのは次の3つです。
org.neo4j.driver.uri=bolt://localhost:7687 org.neo4j.driver.authentication.username=neo4j org.neo4j.driver.authentication.password=secret
username と password に設定する値は、Neo4jに設定しているものを使用します。
ソースコード
ソースコードのファイルは1つのみです。ブラウザからのアクセスを受け付けて、JSON形式で返却します。公式サイトのサンプルでは、データに依存した記載になっていてデータを修正するのが面倒だったので一部改修しました。
今回のサンプルではNeo4jにある全データを取得してブラウザに表示するようにしています。これならデータに依存することなく処理することが出来ます。
package com.demo.app;
import java.util.List;
import org.neo4j.driver.Driver;
import org.neo4j.driver.Session;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Neo4jSampleController {
private final Driver driver;
public Neo4jSampleController(Driver driver) {
this.driver = driver;
}
@GetMapping(path = "/", produces = MediaType.APPLICATION_JSON_VALUE)
public List<String> getMovieTitles() {
try (Session session = driver.session()) {
return session.run("MATCH (n) RETURN n ORDER BY n.name ASC")
.list(r -> r.get("n").asNode().get("name").asString());
}
}
}
以上、Spring Boot で Neo4j へのアクセス、データ取得(組み込みNeo4jドライバーを使用)でした。