图片.png一、讲师管理模块配置

图片.png

1、在service下面service-edu模块中创建配置文件
图片.png


resources目录下创建文件 application.properties

  1. # 服务端口
  2. server.port=8001
  3. # 服务名
  4. spring.application.name=service-edu
  5. # 环境设置:devtestprod
  6. spring.profiles.active=dev
  7. # mysql数据库连接
  8. spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
  9. spring.datasource.url=jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8
  10. spring.datasource.username=root
  11. spring.datasource.password=root
  12. #mybatis日志
  13. mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

或者在resources目录下创建文件 application.yml

  1. #### application.yml
  2. spring:
  3. application:
  4. name: service-edu
  5. profiles:
  6. active: dev
  7. #### application-dev.yml
  8. server:
  9. port: 8001
  10. mybatis-plus:
  11. configuration:
  12. log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  13. mapper-locations: classpath:com/atguigu/service/*/mapper/*.xml
  14. global-config:
  15. db-config:
  16. logic-delete-value: 1
  17. logic-not-delete-value: 0
  18. spring:
  19. datasource:
  20. type: com.zaxxer.hikari.HikariDataSource
  21. driver-class-name: com.mysql.cj.jdbc.Driver
  22. url: jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8
  23. username: root
  24. password: root
  25. hikari:
  26. connection-test-query: SELECT 1
  27. connection-timeout: 60000
  28. idle-timeout: 500000
  29. max-lifetime: 540000
  30. maximum-pool-size: 12
  31. minimum-idle: 10
  32. pool-name: GuliHikariPool
  33. jackson:
  34. date-format: yyyy-MM-dd HH:mm:ss
  35. time-zone: GMT+8

2、创建MP代码生成器

在test/java目录下创建包com.atguigu.eduservice,创建代码生成器:CodeGenerator.java

  1. public class getCode {
  2. @Test
  3. public void main1() {
  4. // 1、创建代码生成器
  5. AutoGenerator mpg = new AutoGenerator();
  6. // 2、全局配置
  7. GlobalConfig gc = new GlobalConfig();
  8. String projectPath = System.getProperty("user.dir");
  9. System.out.println(projectPath);
  10. gc.setOutputDir(projectPath + "/src/main/java");
  11. gc.setAuthor("atguigu");
  12. gc.setOpen(false); //生成后是否打开资源管理器
  13. gc.setFileOverride(false); //重新生成时文件是否覆盖
  14. /*
  15. * mp生成service层代码,默认接口名称第一个字母有 I
  16. * UcenterService
  17. * */
  18. gc.setServiceName("%sService"); //去掉Service接口的首字母I
  19. gc.setIdType(IdType.ID_WORKER); //主键策略
  20. gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
  21. gc.setSwagger2(true);//开启Swagger2模式
  22. mpg.setGlobalConfig(gc);
  23. // 3、数据源配置
  24. DataSourceConfig dsc = new DataSourceConfig();
  25. dsc.setUrl("jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8");
  26. dsc.setDriverName("com.mysql.cj.jdbc.Driver");
  27. dsc.setUsername("root");
  28. dsc.setPassword("root");
  29. dsc.setDbType(DbType.MYSQL);
  30. mpg.setDataSource(dsc);
  31. // 4、包配置
  32. PackageConfig pc = new PackageConfig();
  33. pc.setParent("com.atguigu");
  34. pc.setModuleName("serviceedu"); //包名为:com.atguigu.serviceedu
  35. pc.setController("controller"); //包名为:com.atguigu.controller
  36. pc.setEntity("entity");
  37. pc.setService("service");
  38. pc.setMapper("mapper");
  39. mpg.setPackageInfo(pc);
  40. // 5、策略配置
  41. StrategyConfig strategy = new StrategyConfig();
  42. strategy.setInclude("edu_teacher"); //数据库表名
  43. strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
  44. strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀
  45. strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
  46. strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作
  47. strategy.setRestControllerStyle(true); //restful api风格控制器
  48. strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符
  49. mpg.setStrategy(strategy);
  50. // 6、执行
  51. mpg.execute();
  52. }
  53. }

二、编写后台管理api接口

图片.png

1、编写controller代码

  1. package com.atguigu.eduservice.controller;
  2. @Api(description="讲师管理")
  3. @RestController
  4. @RequestMapping("/eduservice/teacher")
  5. //@CrossOrigin
  6. public class EduTeacherController {
  7. //访问地址: http://localhost:8001/eduservice/teacher/findAll
  8. //把service注入
  9. @Autowired
  10. private EduTeacherService teacherService;
  11. //1 查询讲师表所有数据
  12. //rest风格
  13. @ApiOperation(value = "所有讲师列表")
  14. @GetMapping("findAll")
  15. public List<Teacher> list(){
  16. return teacherService.list(null);
  17. }
  18. }

2、创建SpringBoot配置类

在edu包下创建config包,创建MyBatisPlusConfig.java

  1. package com.guli.edu.config;
  2. @Configuration
  3. @EnableTransactionManagement
  4. @MapperScan("com.atguigu.eduservice.mapper") //扫描mapper
  5. public class MyBatisPlusConfig {
  6. }

3、配置SQL执行性能分析插件

  1. /**
  2. * SQL 执行性能分析插件
  3. * 开发环境使用,线上不推荐。 maxTime 指的是 sql 最大执行时长
  4. */
  5. @Bean
  6. @Profile({"dev","test"})// 设置 dev test 环境开启
  7. public PerformanceInterceptor performanceInterceptor() {
  8. PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
  9. performanceInterceptor.setMaxTime(1000);//ms,超过此处设置的ms则sql不执行
  10. performanceInterceptor.setFormat(true);
  11. return performanceInterceptor;
  12. }

4、创建SpringBoot启动类

创建启动类 EduApplication.java,注意启动类的创建位置

  1. @SpringBootApplication
  2. public class EduApplication {
  3. public static void main(String[] args) {
  4. SpringApplication.run(EduApplication.class, args);
  5. }
  6. }

5、运行启动类

访问http://localhost:8001/eduservice/teacher
得到json数据

6、统一返回的json时间格式

默认情况下json时间格式带有时区,并且是世界标准时间,和我们的时间差了八个小时
在application.properties中设置

  1. #返回json的全局时间格式
  2. spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
  3. spring.jackson.time-zone=GMT+8

三、讲师逻辑删除功能

图片.png

1、配置逻辑删除插件

EduConfig中配置

  1. package com.atguigu.eduservice.config;
  2. @EnableTransactionManagement
  3. @Configuration
  4. @MapperScan("com.atguigu.eduservice.mapper")
  5. public class EduConfig {
  6. /**
  7. * 逻辑删除插件
  8. */
  9. @Bean
  10. public ISqlInjector sqlInjector() {
  11. return new LogicSqlInjector();
  12. }
  13. }

2、逻辑删除属性上面添加注解

EduTeacher中配置

  1. package com.atguigu.eduservice.entity;
  2. @Data
  3. @ApiModel(value="EduTeacher对象", description="讲师")
  4. public class EduTeacher implements Serializable {
  5. private static final long serialVersionUID = 1L;
  6. @ApiModelProperty(value = "讲师ID")
  7. @TableId(value = "id", type = IdType.ID_WORKER_STR)
  8. private String id;
  9. ************
  10. @ApiModelProperty(value = "逻辑删除 1(true)已删除, 0(false)未删除")
  11. @TableLogic
  12. private Boolean isDeleted;
  13. @ApiModelProperty(value = "创建时间")
  14. @TableField(fill = FieldFill.INSERT)
  15. private Date gmtCreate;
  16. @ApiModelProperty(value = "更新时间")
  17. @TableField(fill = FieldFill.INSERT_UPDATE)
  18. private Date gmtModified;
  19. }

2、EduTeacherController添加删除方法

  1. package com.atguigu.eduservice.controller;
  2. @Api(description="讲师管理")
  3. @RestController
  4. @RequestMapping("/eduservice/teacher")
  5. //@CrossOrigin
  6. public class EduTeacherController {
  7. //访问地址: http://localhost:8001/eduservice/teacher/findAll
  8. //把service注入
  9. @Autowired
  10. private EduTeacherService teacherService;
  11. //2 逻辑删除讲师的方法
  12. @DeleteMapping("{id}")
  13. public boolean removeById(@PathVariable String id){
  14. return teacherService.removeById(id);
  15. }
  16. }

3、使用postman测试删除


测试结果:数据库中的is_deleted字段被修改为1

四、跨域配置

1、什么是跨域

浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域 。前后端分离开发中,需要考虑ajax跨域的问题。

这里我们可以从服务端解决这个问题

2、配置

在Controller类上添加注解

  1. @CrossOrigin //跨域