共计 27 个字符,预计需要花费 1 分钟才能阅读完成。
TEST
Handmade Javasript GitHub
正文完
发表至: javascript
2019-10-12
共计 2455 个字符,预计需要花费 7 分钟才能阅读完成。
在前面一篇已经写了 elasticsearch 的环境的搭建,那么这一篇就写下 springboot 与 elasticsearch 环境的整合。如果没有搭建环境,请参考:es 环境搭建
我们利用 es 做一个简单的用户添加获取的功能。
@Document(indexName = "user", type = "student")
public class UserInfo implements Serializable{
private String id;
private String username;
private int age;
public String getId() {return id;}
public void setId(String id) {this.id = id;}
public String getUsername() {return username;}
public void setUsername(String username) {this.username = username;}
public int getAge() {return age;}
public void setAge(int age) {this.age = age;}
@Override
public String toString() {
return "UserInfo{" +
"id='" + id + '\'' +
", username='" + username + '\'' +
", age=" + age +
'}';
}
}
这是一个简单的用户类,并且生成了 getter,setter 方法。
这里我们采用 jpa 的方式整合 es,使用接口,继承 ElasticsearchRepository,如下
@Repository
public interface UserRepository extends ElasticsearchRepository<UserInfo,String> {
}
@Service
public class Uservice {
@Autowired
UserRepository userRepository;
public UserInfo getById(String id){return userRepository.findOne(id);
}
public void save(UserInfo userInfo){userRepository.save(userInfo);
}
}
这里直接使用 rest 风格的接口
@RestController
public class UserController {Logger logger = LoggerFactory.getLogger(this.getClass());
@Autowired
UserInfoService userInfoService;
@GetMapping("/user/{id}")
public UserInfo get(@PathVariable String id){UserInfo userInfo = userInfoService.getById(id);
logger.info("---${user}:{}",userInfo.toString());
return userInfo;
}
@PostMapping("/user/create/{id}")
public UserInfo create(@PathVariable String id,@RequestBody UserInfo userInfo){userInfo.setId(id);
userInfoService.save(userInfo);
return userInfo;
}
}
这里只简单的编写了一个添加和一个获取的方法,接下来我们运行项目
抛出了一个异常,如下
java.lang.ClassNotFoundException: com.sun.jna.Native
at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[na:1.8.0_111]
at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[na:1.8.0_111]
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) ~[na:1.8.0_111]
at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[na:1.8.0_111]
at java.lang.Class.forName0(Native Method) ~[na:1.8.0_111]
at java.lang.Class.forName(Class.java:264) ~[na:1.8.0_111]
这是是 jna 包的原因,我们将此 jar 添加到 pom.xml
<dependency>
<groupId>net.java.dev.jna</groupId>
<artifactId>jna</artifactId>
<version>4.4.0</version>
</dependency>
我们先利用 postman 做一个接口测试,如下图
测试成功,已经将数据添加到 es 中。
至此,es 的添加和获取已经完成,后期 es 的更深入的东西后期请持续关注。
共计 3120 个字符,预计需要花费 8 分钟才能阅读完成。
(图一)
(图二)