Java SpringBoot开发小技巧详解
一、SpringBoot开发小技巧
1.1 Lombok
作用:在程序编译的时候,自动帮我们生成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(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=哈哈哈
控制台输出也没问题。
1.2 dev-tools
作用:以前开发页面啥的,老要重启一下主程序或者重启一下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端口号就不行了。开发网页啥的时候也是一样,改完代码,直接编译,然后回去网站刷新一下即可。
1.3 Spring Initializr
作用:初始化我们的SpringBoot工程。
在IDEA中,我们新建我们的项目,可以选择Spring Initializr,然后配置我们的工程名、路径等等信息,大致如下:
完成后,他就会自动帮我们导入我们的依赖
并且帮我们设计好我们的项目结构:
主程序类也帮我们写好了默认的语句。
如此,开发者基本上就只需要写自己的那些dao、service、controller和bean一系列的业务逻辑的东西就可以了。
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341