首页 > 其他分享 >SpringBoot的Controller,Service,Repository层的使用

SpringBoot的Controller,Service,Repository层的使用

时间:2024-01-05 21:11:27浏览次数:27  
标签:return SpringBoot repository public Controller Repository Todo id RequestMapping

找回熟悉的Controller,Service

Controller哪儿去了?

对于很多习惯了Spring开发的同学来讲,ControllerServiceDAO 这些套路突然间都没了会有不适感。其实呢,这些东西还在,只不过对于较简单的情景下,这些都变成了系统背后帮你做的事情。这一小节我们就先来看看如何将Controller再召唤回来。召唤回来的好处有哪些呢?首先我们可以自定义API URL的路径,其次可以对参数和返回的json结构做一定的处理。

如果要让 TodoController 可以和 TodoRepository 配合工作的话,我们当然需要在 TodoController 中需要引用 TodoRepository

 
  public class TodoController {   @Autowired   private TodoRepository repository;   //省略其它部分   }
 
 

@Autowired 这个修饰符是用于做依赖性注入的,上面的用法叫做 field injection,直接做类成员的注入。但Spring现在鼓励用构造函数来做注入,所以,我们来看看构造函数的注入方法:

 
  public class TodoController {       private TodoRepository repository;       @Autowired   public TodoController(TodoRepository repository){   this.repository = repository;   }   //省略其它部分   }
 
 

当然我们为了可以让Spring知道这是一个支持REST API的 Controller ,还是需要标记其为 @RestController。由于默认的路径映射会在资源根用复数形式,由于todo是辅音后的o结尾,按英语习惯,会映射成 todoes。但这里用 todostodoes 更舒服一些,所以我们再使用另一个 @RequestMapping("/todos") 来自定义路径。这个 Controller 中的其它方法比较简单,就是利用repository中的方法去增删改查即可。

 
  package dev.local.todo;       import org.bson.types.ObjectId;   import org.springframework.beans.factory.annotation.Autowired;   import org.springframework.web.bind.annotation.*;       import java.util.List;       @RestController   @RequestMapping("/todos")   public class TodoController {       private TodoRepository repository;       @Autowired   public TodoController(TodoRepository repository){   this.repository = repository;   }       @RequestMapping(method = RequestMethod.GET)   public List<Todo> getAllTodos(@RequestHeader(value = "userId") String userId) {   return repository.findByUserId(new ObjectId(userId));   }       @RequestMapping(method = RequestMethod.POST)   Todo addTodo(@RequestBody Todo addedTodo) {   return repository.insert(addedTodo);   }       @RequestMapping(value = "/{id}", method = RequestMethod.GET)   public Todo getTodo(@PathVariable String id) {   return repository.findOne(id);   }       @RequestMapping(value = "/{id}", method = RequestMethod.PUT)   Todo updateTodo(@PathVariable String id, @RequestBody Todo updatedTodo) {   updatedTodo.setId(id);   return repository.save(updatedTodo);   }       @RequestMapping(value = "/{id}", method = RequestMethod.DELETE)   Todo removeTodo(@PathVariable String id) {   Todo deletedTodo = repository.findOne(id);   repository.delete(id);   return deletedTodo;   }   }    
 
 

上面的代码中需要再说明几个要点:

  1. 为什么在类上标记 @RequestMapping("/todos") 后在每个方法上还需要添加 @RequestMapping?类上面定义的 @RequestMapping 的参数会默认应用于所有方法,但如果我们发现某个方法需要有自己的特殊值时,就需要定义这个方法的映射参数。比如上面例子中 addTodo,路径也是 todos,但要求 Request的方法是 POST,所以我们给出了 @RequestMapping(method = RequestMethod.POST)。但 getTodo 方法的路径应该是 todos/:id,这时我们要给出 @RequestMapping(value = "/{id}", method = RequestMethod.GET)
  2. 这些方法接受的参数也使用了各种修饰符,@PathVariable 表示参数是从路径中得来的,而 @RequestBody 表示参数应该从 Http Request的body 中解析,类似的 @RequestHeader 表示参数是 Http Request的Header中定义的。

在可以测试之前,我们还需要使用 @Repository 来标记 TodoRepository,以便于Spring可以在依赖注入时可以找到这个类。

 
  package dev.local.todo;       import org.bson.types.ObjectId;   import org.springframework.data.mongodb.repository.MongoRepository;   import org.springframework.stereotype.Repository;       import java.util.List;           /**   * Created by wangpeng on 2017/1/26.   */   @Repository   public interface TodoRepository extends MongoRepository<Todo, String>{   List<Todo> findByUserId(ObjectId userId);   }    
 
 

接下来就可以用PostMan做一下测试:

测试一下Controller

测试一下Controller

Service呢?在哪里?

熟悉Spring的童鞋肯定会问,我们刚才的做法等于直接是Controller访问Data了,隔离不够啊。其实我觉得有很多时候,这种简单设计是挺好的,因为业务还没有到达那步,过于复杂的设计其实没啥太大意义。但这里我们还是一步步来实践一下,找回大家熟悉的感觉。

回到原来的熟悉模式再简单不过的,新建一个 TodoService 接口,定义一下目前的增删改查几个操作:

 
  public interface TodoService {   Todo addTodo(Todo todo);   Todo deleteTodo(String id);   List<Todo> findAll(String userId);   Todo findById(String id);   Todo update(Todo todo);   }
 
 

为预防我们以后使用 MySQL 等潜在的 “可扩展性”,我们给这个接口的实现命名为 MongoTodoServiceImpl,然后把 Controller 中的大部分代码拿过来改改就行了。当然为了系统可以找到这个依赖并注入需要的类中,我们标记它为 @Service

 
  @Service   public class MongoTodoServiceImpl implements TodoService{   private final TodoRepository repository;       @Autowired   MongoTodoServiceImpl(TodoRepository repository) {   this.repository = repository;   }       @Override   public Todo addTodo(Todo todo) {   return repository.insert(todo);   }       @Override   public Todo deleteTodo(String id) {   Todo deletedTodo = repository.findOne(id);   repository.delete(id);   return deletedTodo;   }       @Override   public List<Todo> findAll(String userId) {   return repository.findByUserId(new ObjectId(userId));   }       @Override   public Todo findById(String id) {   return repository.findOne(id);   }       @Override   public Todo update(Todo todo) {   repository.save(todo);   return todo;   }   }
 
 

最后把Controller中的所有方法改为使用Service的简单调用就大功告成了。

 
  public class TodoController {       private TodoService service;       @Autowired   public TodoController(TodoService service){   this.service = service;   }       @RequestMapping(method = RequestMethod.GET)   public List<Todo> getAllTodos(@RequestHeader(value = "userId") String userId) {   return service.findAll(userId);   }       @RequestMapping(method = RequestMethod.POST)   Todo addTodo(@RequestBody Todo addedTodo) {   return service.addTodo(addedTodo);   }       @RequestMapping(value = "/{id}", method = RequestMethod.GET)   public Todo getTodo(@PathVariable String id) {   return service.findById(id);   }       @RequestMapping(value = "/{id}", method = RequestMethod.PUT)   Todo updateTodo(@PathVariable String id, @RequestBody Todo updatedTodo) {   updatedTodo.setId(id);   return service.update(updatedTodo);   }       @RequestMapping(value = "/{id}", method = RequestMethod.DELETE)   Todo removeTodo(@PathVariable String id) {   return service.deleteTodo(id);   }   }
 
 

说实话如果每个简单类都这么写,我深深地赶脚背离了Spring Boot的意图,虽然你能举出1000个理由这么做有好处。类似的,DAO或DTO要写起来也很简单,但我还是建议在业务没有复杂之前还是享受Spring Boot带给我们的便利吧。



 

 

标签:return,SpringBoot,repository,public,Controller,Repository,Todo,id,RequestMapping
From: https://www.cnblogs.com/lidabo/p/17948112

相关文章

  • springMVC的常见注解,以及注解的作用。@Controller,@RestController,@RequestMapping,@
    目录注:使用注解,必须要开启注解包扫描1.@Controller2.@RequestMapping3.@PathVariable4.@RequestParam5.@RequestHeader6.@CookieValue7.@RequestBody该注解的作用8.@ResponseBody9.@RestController注:使用注解,必须要开启注解包扫描在MVC核心配置中开启注解包扫描<!--  配置包......
  • springboot 打包本地jar包或外部依赖打不进去问题
    分为两种情况一、打war包的情况引入依赖<dependency><groupId>com.xxxx</groupId><artifactId>xxxxx</artifactId><version>1.0</version><scope>system</scope><systemPath>${basedir}/lib/xxxxx.jar&l......
  • Springboot 2.7 open api:swagger | knife4j | spring doc
    *[集成SpringDoc接口文档和knife4j|SpringBoot2.7.2实战基础-掘金](https://juejin.cn/post/7201195677128687674)*[Springboot2.7集成Swagger增强版接口框架Knife4j4.3+springdocOpenApi3.0\_knife4jspringboot2.7-CSDN博客](https://blog.csdn.net/Mrqi......
  • 记录Springboot中向企业微信指定人员发送含链接的消息
    背景:从海康智能门禁获取到了进入教室的人脸信息,由此得到一批用户List,等会儿就要实时向这批用户发送消息“***,您已进入**教室,请填写使用情况表<ahref="****">”。  过程:读了微信的开发者文档,摸索着写了测试代码。在debug时,发现微信传来的是{"errcode":60020,"errmsg":"not......
  • 用 SpringBoot+Redis 解决海量重复提交问题
    1前言在实际的开发项目中,一个对外暴露的接口往往会面临很多次请求,我们来解释一下幂等的概念:任意多次执行所产生的影响均与一次执行的影响相同。按照这个含义,最终的含义就是对数据库的影响只能是一次性的,不能重复处理。如何保证其幂等性,通常有以下手段:数据库建立唯一性索引,可以保......
  • 基于SpringBoot+Vue的线上课程管理系统设计实现(源码+lw+部署文档+讲解等)
    (文章目录)前言:heartpulse:博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌:heartpulse:......
  • springboot057洗衣店订单管理系统-计算机毕业设计源码+LW文档
    论文选题理由衣服是人们必不可少的重要物品,它让人们显得好看,变得舒适。一些人也会花费很昂贵的价格去购买自己心意的衣服,当我们刚刚购买时衣服非常的整洁非常的漂亮,但是当我们穿了一段时间后烦恼就来了。衣服变脏了、粘上油渍了,或者是放了一段时间后发黄了。这样的问题很多,而且很......
  • springboot058美发门店管理系统-计算机毕业设计源码+LW文档
    美发门店管理系统摘要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了美发门店管理系统的开发全过程。通过分析美发门店管理系统管理的不足,创建了一个计算机管理美发门店管理系统的方案。文章介绍了美发门店管理系统的系统分析部分......
  • springboot059课程答疑系统-计算机毕业设计源码+LW文档
    摘要随着信息互联网信息的飞速发展,无纸化作业变成了一种趋势,针对这个问题开发一个专门适应师生交流形式的网站。本文介绍了课程答疑系统的开发全过程。通过分析企业对于课程答疑系统的需求,创建了一个计算机管理课程答疑系统的方案。文章介绍了课程答疑系统的系统分析部分,包括可行......
  • springboot060师生共评的作业管理系统-计算机毕业设计源码+LW文档
    师生共评的作业管理系统设计与实现摘要随着信息互联网信息的飞速发展,无纸化作业变成了一种趋势,针对这个问题开发一个专门适应师生作业交流形式的网站。本文介绍了师生共评的作业管理系统的开发全过程。通过分析企业对于师生共评的作业管理系统的需求,创建了一个计算机管理师生共评......