前言
所谓的服务组件(service component)— 就是用于处理系统业务逻辑的类,如果按照系统分层设计理论来划分,服务组件是位于业务层当中的类。在spring boot中,服务组件是一个被**@service**注解进行注释的类,这些类用于编写系统的业务代码。在本章节中,将讲解如何创建并使用服务组件。
在开始正文之前,先来看两段示例代码。使用服务组件之前,我们需要定义服务组件接口类,用于索引服务组件提供的服务,代码如下所示:
1
2
3
|
public interface userservice{ // todo ... } |
然后,需要使用**@service**注解对服务组件接口实现类进行注释,演示代码如下:
1
2
3
4
|
@service (value= "userservice" ) public class userserviceimpl implements userservice{ //todo ... } |
最后,使用**@autowired**注解来自动引用服务组件,代码如下:
1
2
3
4
5
6
|
@controller public class democontroller{ @autowired userservice userservice; //todo ... } |
在本次讲解中,我们依然以对用户的增、删、改、查为案例,将控制器中的业务方法迁移到服务组件中。
1. 创建服务接口
创建一个包含添加用户、更新用户、删除用户和查询用户的服务接口类 — 用户服务组件接口类。详细代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
package com.ramostear.application.service; import com.ramostear.application.model.user; import java.util.collection; /** * created by ramostear on 2019/3/11 0011. */ public interface userservice { /** * create user * @param user */ void create(user user); /** * update user info by id * @param id * @param user */ void update( long id,user user); /** * delete user by id * @param id */ void delete( long id); /** * query all user * @return */ collection<user> findall(); } |
2. 实现服务接口
创建一个接口实现类,用于实现其中的增、删、改、查四个业务方法,并用**@service**注解进行标注,具体代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
package com.ramostear.application.service.impl; import com.ramostear.application.model.user; import com.ramostear.application.service.userservice; import org.springframework.stereotype.service; import javax.annotation.postconstruct; import java.util.collection; import java.util.hashmap; import java.util.map; /** * @author ramostear * @create-time 2019/3/11 0011-4:29 * @modify by : * @since: */ @service (value= "userservice" ) public class userserviceimpl implements userservice { private static map< long ,user> userrepo = new hashmap<>(); @postconstruct public void inituserrepo(){ user admin = new user(); admin.setid( 1 ).setname( "admin" ); userrepo.put(admin.getid(),admin); user editor = new user(); editor.setid( 2 ).setname( "editor" ); userrepo.put(editor.getid(),editor); } @override public void create(user user) { userrepo.put(user.getid(),user); } @override public void update( long id, user user) { userrepo.remove(id); user.setid(id); userrepo.put(id,user); } @override public void delete( long id) { userrepo.remove(id); } @override public collection<user> findall() { return userrepo.values(); } } |
3. 使用服务组件
接下来,定义一个用户控制器,使用**@autowired**注解来应用用户服务组件,实现对用户的增、删、改、查功能:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
package com.ramostear.application.controller; import com.ramostear.application.model.user; import com.ramostear.application.service.userservice; import org.springframework.beans.factory.annotation.autowired; import org.springframework.http.httpstatus; import org.springframework.http.responseentity; import org.springframework.web.bind.annotation.*; /** * @author ramostear * @create-time 2019/3/11 0011-4:42 * @modify by : * @since: */ @restcontroller public class usercontroller { @autowired userservice userservice; @getmapping ( "/users" ) public responseentity<object> users(){ return new responseentity<>(userservice.findall(), httpstatus.ok); } @postmapping ( "/users" ) public responseentity<object> create( @requestbody user user){ userservice.create(user); return new responseentity<>( "user is created successfully." ,httpstatus.created); } @putmapping ( "/users/{id}" ) public responseentity<object> update( @pathvariable (name= "id" ) long id, @requestbody user user){ userservice.update(id,user); return new responseentity<>( "user is updated successfully." ,httpstatus.ok); } @deletemapping ( "/users/{id}" ) public responseentity<object> delete( @pathvariable (name = "id" ) long id){ userservice.delete(id); return new responseentity<>( "user is deleted successfully." ,httpstatus.ok); } } |
4. 数据模型
用户对象的代码沿用以往章节的user.java代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
package com.ramostear.application.model; import lombok.getter; import lombok.noargsconstructor; import lombok.setter; /** * @author ramostear * @create-time 2019/3/6 0006-3:12 * @modify by : * @since: */ @getter @setter @noargsconstructor public class user { private long id; private string name; public user setid( long id){ this .id = id; return this ; } public user setname(string name){ this .name = name; return this ; } } |
注:应用程序主类和maven build文件与之前章节的代码形同,不再列举。
5. 运行测试
启动spring boot应用程序,然后打开postman测试应用程序,分别进行如下的测试。
get 请求:获取所有的用户信息。
url地址:http://localhost:8080/users
获取用户信息
post 请求:新增一位用户信息
url地址:http://localhost:8080/users
请求参数:{“id”:3,"name":"reader"}
新增用户
put请求:修改用户信息
url地址:http://localhost:8080/users/3
请求参数:{“id”:3,"name":"ramostear"}
修改用户
delete请求:删除用户信息
url地址:http://localhost:8080/users/3
删除用户
6. 附件
本章节用于演示的项目源码已经上传到github代码仓库,你可以通过下面的地址链接免费获取本章节的全部源码信息:
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。
原文链接:https://juejin.im/post/5caddc715188251ad646b634