时间:2023-02-21 13:44:39 | 栏目:JAVA代码 | 点击:次
作用:在程序编译的时候,自动帮我们生成setter和getter方法以及我们的toString方法和我们的全参和无参构造器等等。
那么,怎么用呢?很简单,用下边这四个注解就行了:
1、@Data:自动生成setter和getter方法。
2、@ToString:自动生成toString方法。
3、@AllArgsConstructor:自动生成全参构造器
4、@NoArgsConstructor:自动生成无参构造器
5、@EqualsAndHashCode:自动生成EqualsAndHashCode方法
6、@Slf4j:开启我们的日志记录器
使用Lombok,首先当然要引入他的依赖,这个在SpringBoot也装配好了,所以我们不用写他的版本号。
<!--lombok依赖--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency>
然后在IDEA的settings中下载Lombok的插件。(下载完记得重启一下IDEA,让他生效)
使用这个插件后,我们以后开发的时候的那些Bean,我们只需要在上面添加如下注解就可以生成对应的方法了:
package com.example.bean; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import lombok.ToString; @Data //setter和getter方法 @ToString //toString方法 @AllArgsConstructor //有参构造器 @NoArgsConstructor //无参构造器 @EqualsAndHashCode //EqualsAndHashCode方法 public class User { private Integer id; private String username; private String password; }
然后我们给控制器也写一个@Slf4j注释
package com.example.controller; import lombok.extern.slf4j.Slf4j; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource; //@RestController可以理解成是Controller加ResponseBody @RestController @Slf4j public class HelloController { @RequestMapping("/hello") public String toHello(@RequestParam("name") String name){ log.info("/hello被人访问啦!"); return "Hello,World!"+name; } }
在主程序中写上:
package com.example.boot; import com.example.bean.User; import com.example.config.MyConfig; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.context.ConfigurableApplicationContext; /** * 主程序类 * @SpringBootApplication 告诉 SpringBoot这是一个SpringBoot应用 */ @SpringBootApplication(scanBasePackages = "com.example") public class MainApplication { public static void main(String[] args) { //固定写法 ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args); MyConfig myConfig = run.getBean(MyConfig.class); //通过myConfig的方法获取Bean User user = myConfig.user(); // User user1 = myConfig.user(); //通过run获取Bean User user2 = run.getBean("user",User.class); System.out.println(user); System.out.println(user2); } }
运行我们的主程序,我们来测试一下,首先Bean的创建没问题,而且他的toString方法也没问题。
登录http://localhost:8888/hello?name=哈哈哈
控制台输出也没问题。
作用:以前开发页面啥的,老要重启一下主程序或者重启一下Tomcat服务器,有了他就方便多啦。我们只需要按Ctrl+F9(编译一下),就可以让他实时生效。(第一次使用记得在成功导入依赖后,先重启一次主程序)
先添加依赖:
<!--dev-tools依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency>
然后我们来试一下,我们把之前设置端口号为8888的那一段删掉,让他变回默认的8080。按Ctrl+F9,很快就编译完成了,然后我们此时登录8080端口号成功。登录8888端口号就不行了。开发网页啥的时候也是一样,改完代码,直接编译,然后回去网站刷新一下即可。
作用:初始化我们的SpringBoot工程。
在IDEA中,我们新建我们的项目,可以选择Spring Initializr,然后配置我们的工程名、路径等等信息,大致如下:
完成后,他就会自动帮我们导入我们的依赖
并且帮我们设计好我们的项目结构:
主程序类也帮我们写好了默认的语句。
如此,开发者基本上就只需要写自己的那些dao、service、controller和bean一系列的业务逻辑的东西就可以了。