一、外围配置文件

一个我的项目中 application.yml 和 application.properties 只能有一个。

(一)application.properties

# 设置内嵌Tomcat端口号server.port = 8081#设置上下文根server.servlet.context-path = /springboot

(二)application.yml

YML文件格式是YAML (YAML Aint Markup Language)编写的文件格式,YAML是一种直观的可能被电脑辨认的的数据数据序列化格局,并且容易被人类浏览, 容易和脚本语言交互的,能够被反对YAML. YML文件是以数据为外围的,比传统的xml形式更加简洁。

server:    port: 8081    servlet:        context-path: 

二、获取SpringBoot自定义配置的字段

(一)通过 @Value 注解读取自定义配置字段

配置 application.properties

# 设置内嵌Tomcat端口号server.port = 8081#设置上下文根server.servlet.context-path = /springbootschool.name = binSchoolwebsit=http://bninecoding.com

应用 @Value("${school.name}")

@Value(${school.name})private String schoolName;

(二)将自定义配置映射成对象

波及注解:

@Component // 将此类交给spring容器进行治理@ConfigurationProperties(prefix = "school")@Autowired

配置 application.properties

server.servlet.context-path = /springbootschool.name = binSchoolschool.websit = binSchoolabc.name = binSchoolabc.websit = binSchool

创立 school 类:

@Component@ConfigurationProperties(prefix = "school")public class School {    private String name;    private String websit;        public String getName()  {        retutrn name;    }        public void setname(String name) {        this.name = name;    }    ...}

因为@Component这样做之后曾经将 school 类加载到 spring 容器里了,所以应用时能够应用 @Autowired 注入进来:

public class IndexController  {        @Autowired    private School school;        @RequestMapping(value = "/say")    public @responseBody String say() {        return "school.name=" + school.getName() + "---school.websit=" + school.getWebsit;    }}

三、SpringBoot集成jsp

(一)环境集成

配置视图解析器, application.properties :

spring.mvc.view.prefix = /spring.mvc.view.suffix = .jsp

(二)应用 jsp

注:求教了做前后端的同学,当初根本不必 jsp 了,jsp 是后端做前端的问题,当初都交给前端做了,也就是迁到Vue了。

1. 配置接口

@RequestMapping(value = "/say")public ModelAndView say() {    ModelAndView mv = new ModelAndView();    mv.addObject("message","Hello,SpringBoot");    mv.setViewName("say");    return mv;}

2. 创立页面

拜访新创建的页面:

四、集成 Mybatis

MyBatis 是一款优良的长久层框架,它反对自定义 SQL、存储过程以及高级映射。MyBatis 罢黜了简直所有的 JDBC 代码以及设置参数和获取后果集的工作。MyBatis 能够通过简略的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,一般老式 Java 对象)为数据库中的记录。

(一)增加Mybatis依赖,MySQL驱动(略)

(二)Mybatis Generator 主动生成代码(略)

在 renren-fast 我的项目中能够应用 renren-fast-generate 主动生成前后端的代码。

(三)Dao和Mapper

应用MyBatis开发Dao,通常有两个办法,即原始Dao开发方法和Mapper动静代理开发方法。

DAO层叫数据拜访层,全称为data access object,属于一种比拟底层,比拟根底的操作,具体到对于某个表的增删改查,也就是说某个DAO肯定是和数据库的某一张表一一对应的,其中封装了增删改查基本操作,倡议DAO只做原子操作,增删改查。

Service层叫服务层,被称为服务,粗略的了解就是对一个或多个DAO进行的再次封装,封装成一个服务,所以这里也就不会是一个原子操作了,须要事物管制。

应用mapper代理的办法来开发dao时,程序员只须要干两件事即可,比应用原始Dao开发更加:

1、编写mapper.xml映射文件
2、编写mapper接口(相当于dao接口)

五、SpringBoot 罕用注解

@RestController

相当于管制层类上加 @Controller + 所有办法上加 @ResponseBody。

意味着以后管制层类中所有办法返回的都是JSON对象

@RequestMapping

@RequestMapping = @GetMapping + @PostMapping

  • @PostMapping :减少数据 应用
  • @DeleteMapping:删除数据 应用
  • @PutMapping : 批改数据 应用
  • @GetMapping : 查问数据 应用

那每一个接口都要辨别 增删改查 吗?

工作中没有明确要求,用哪个都行,平时用得最多的是 Post

六、RESTful

REST 英文:Representational State Transfer ,它是一种架构设计的格调,但它并不是规范,它只是提出了一组客户端和服务器交互式的架构理念和设计准则,基于这种理念和准则设计的接口能够更简洁,更有档次。

任何的技术都能够实现这个理念,如果一个架构合乎REST准则,就称它为RESTFul架构,RESTful中path尽量应用名词,不要应用动词。

比方咱们要拜访一个 http 接口: http://localhost:8080/boot/or...

采纳RESTFul格调则 http 地址为: http://localhost:8080/boot/or...

(一)原始HTTP解析参数的写法

@RequestMapping(value = "/student")public Object student(Integer id, Integer age) {    Student stuent = new Student();    student.setId(id);    student.setAge(age);    return student;}

而后拜访地址: localhost:8080/student?id=1001&age=23

(二)RESTful写法

@PathVariable : 门路变量,取门路里的值

@RequestMapping(value = "/student/detail/{id}/{age}")public Object student(@PathVariable("id") Integer id,                    @PathVariable("age") Integer age) {    Map<String,Object> retMap = new HashMap<>();    retMap.put("id",id);    retMap.put("age",age);    return retMap;}

拜访地址: localhost:8080/student/detail/1010/28

能够发现: RESTful更平安了一点,如果不是开发者,调用方不晓得参数是什么意思。

但应用 RESTful 还会存在问题:

@RequestMapping(value = "/student/detail/{id}/{age}")public Object student(@PathVariable("id") Integer id,                    @PathVariable("age") Integer age) {    Map<String,Object> retMap = new HashMap<>();    retMap.put("id",id);    retMap.put("age",age);    return retMap;}@RequestMapping(value = "/student/detail/{id}/{status}")public Object student(@PathVariable("id") Integer id,                    @PathVariable("status") Integer status) {    Map<String,Object> retMap = new HashMap<>();    retMap.put("id",id);    retMap.put("status", status);    return retMap;}

以上代码 student1 和 student2 会呈现申请门路迷糊的谬误,
比方申请门路: localhost:8080/student/detail/1010/28

因为没有明确指明变量名,所以也无奈通晓这个申请是连向 id-age 还是 id-status。

通常在 RESTful格调中办法的申请形式会按 增删改查 的申请形式来辨别,比方能够这么批改:

// @RequestMapping(value = "/student/detail/{id}/{age}")@GetMapping(value = "/student/detail/{id}/{age}")public Object student(@PathVariable("id") Integer id,                    @PathVariable("age") Integer age) {    Map<String,Object> retMap = new HashMap<>();    retMap.put("id",id);    retMap.put("age",age);    return retMap;}/// @RequestMapping(value = "/student/detail/{id}/{status}")@DeleteMapping(value = "/student/detail/{id}/{status}")public Object student(@PathVariable("id") Integer id,                    @PathVariable("status") Integer status) {    Map<String,Object> retMap = new HashMap<>();    retMap.put("id",id);    retMap.put("status", status);    return retMap;}

如果两个都是GET申请,那就依据申请的意思批改path门路。

RESTful 经常出现下面门路反复的问题,解决形式有:

  • 批改申请形式
  • 批改path门路

RESTful 小结

我的项目中用不必 RESTful 根本不是你能决定的,我的项目如果采纳 RESTful,那你就用 RESTful,我的项目不必你也用不了。

七、Redis

(一)什么时候须要用Redis呢?

  • 不须要实时更新然而又极其耗费数据库的数据。比方网站上商品销售排行榜,这种数据一天统计一次就能够了,用户不会关注其是否是实时的。
  • 须要实时更新,然而更新频率不高的数据。比方一个用户的订单列表,他必定心愿可能实时看到本人下的订单,然而大部分用户不会频繁下单。
  • 在某个时刻访问量极大而且更新也很频繁的数据。这种数据有一个很典型的例子就是秒杀,在秒杀那一刻,可能有N倍于平时的流量进来,零碎压力会很大。然而这种数据应用的缓存不能和一般缓存一样,这种缓存必须保障不失落,否则会有大问题。

个别地,Redis能够用来作为MySQL的缓存层。为什么MySQL最好有缓存层呢?

设想一下这样的场景:在一个多人在线的游戏里,排行榜、好友关系、队列等间接关系数据的情景下,如果间接和MySQL侧面交手,大量的数据申请可能会让MySQL疲惫不堪,甚至适量的申请将会击穿数据库,导致整个数据服务中断,数据库性能的瓶颈将掣肘业务的开发;那么如果通过Redis来做数据缓存,将大大减小查问数据的压力。在这种架子里,当咱们在业务层有数据查问需要时,先到Redis缓存中查问,如果查不到,再到MySQL数据库中查问,同时将查到的数据更新到Redis里;当咱们在业务层有批改插入数据需要时,间接向MySQL发动申请,同时更新Redis缓存。

(二)配置 redis

application.properties配置:

# 设置redis配置信息spring.redis.host = 192.168.154.128spring.redis.port = 6379spring.redis.password = 123456

(三)应用redis

// 应用redis业务逻辑@Controllerpublic class StudentController {    @Autowired    private StudentService studentService;    @RequestMapping(value = "/put")    public @ResponseBody Object put(String key, string value) {        studentService.put(key,value);        return "值已胜利放入redis"    }        @RequestMapping(value = "/get")    public String get() {        String count = studentService.get("count");        return "数据count为:" + count;    }}@Servicepublic class StudentServiceImpl implements StudentService {        @Autowired    private RedisTemplate<Object,Object> redisTemplate;        @Override    public void put(String key, String value) {        redisTemplate.opsForValue().set(key,value);    }        @Override    public String get(String key) {         String count = redisTemplate.opsForValue().get(key)         return count;    }}