内容简介:这篇文章,介绍SpringBoot常用的配置和请求处理。大致分成三个部分介绍:常用的请求方式、Jpa配置、MySql配置。如下是常用的几种请求方式:get请求:一般用于查询数据,获取一些非重要性的信息。
这篇文章,介绍SpringBoot常用的配置和请求处理。大致分成三个部分介绍:常用的请求方式、Jpa配置、 MySql 配置。
常用的请求方式
如下是常用的几种请求方式:
get请求:一般用于查询数据,获取一些非重要性的信息。
post请求:一般用于插入数据。
put请求:一般用于数据更新。
delete请求:一般用于数据删除。
那么,在SpringBoot中,怎么对这些请求方式进行处理。(这里以最常用的get、post请求为例,其他的类似)
get请求:
//get请求,获取url路径上的参数 @PathVariable //注:localhost:8080/test/11/hans @RequestMapping(value = "/test/{id}/{name}", method = RequestMethod.GET) public String sayHello(@PathVariable("id") Integer id, @PathVariable("name") String name) { return "id:" + id + " name:" + name; } //get请求,获取url请求参数的值 @RequestParam //localhost:8080/test?id=99 @RequestMapping(value = "/test", method = RequestMethod.GET) public String sayHello(@RequestParam Integer id) { return "id:" + id; } //get请求,获取url请求参数的值,增加参数映射,默认值 @RequestParam //required=false 表示url中可以无id参数,此时就使用默认参数 @RequestMapping(value = "/test2", method = RequestMethod.GET) public String sayHello2(@RequestParam(value = "id", required = false, defaultValue = "1") Integer id) { return "id:" + id; }
post请求:
//post请求 //表单参数 @RequestMapping(value= "/getMessage", method = RequestMethod.POST) public String getMessage(int code, String message) { return "success"; } //post请求 //json raw参数 @PostMapping(value= "/getMessageBody") public String getMessagePost(@RequestBody HolidayEntity bean) { return "success"; } //匹配参数 //password如果匹配对,@RequestParam不写都ok public void login(@RequestParam("account") String name, @RequestParam String password) { System.out.println(name + ":" + password); } //@RequestHeader注解用来将请求头的内容绑定到方法参数上。 @PostMapping(value = "login") public void login2(@RequestHeader("access_token") String accessToken,@RequestParam String name) { System.out.println("accessToken:" + accessToken); }
补充:
组合注解(RequestMapping的变形) @GetMapping = @RequestMapping(method = RequestMethod.GET) @PostMapping = @RequestMapping(method = RequestMethod.POST) @PutMapping = @RequestMapping(method = RequestMethod.PUT) @DeleteMapping = @RequestMapping(method = RequestMethod.DELETE)
Jpa配置
1.pom文件加入Jpa配置
<!--jpa--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
2.Application入口类增加@EnableJpaRepositories注解
@EnableJpaRepositories public class Application extends SpringBootServletInitializer {
3.dao接口
@Repository public interface HolidayRepository extends JpaRepository<HolidayEntity, Long> { @Query(value = "SELECT p FROM HolidayEntity p") List<HolidayEntity> queryHoliday(); }
4.entity类
@Entity @Table(name = "holiday_scheme") @EntityListeners(AuditingEntityListener.class) public class HolidayEntity extends AbstractPersistable<Long> { @Column(name = "date") public String date; @Column(name = "hour") public String hour; @Column(name = "holiday") public String holiday; @Column(name = "holiday_explain") public String holiday_explain; @Column(name = "type") public String type;//SUB假期,ADD调休 public String getDate() { return date; } public void setDate(String date) { this.date = date; } public String getHour() { return hour; } public void setHour(String hour) { this.hour = hour; } public String getHoliday() { return holiday; } public void setHoliday(String holiday) { this.holiday = holiday; } public String getHoliday_explain() { return holiday_explain; } public void setHoliday_explain(String holiday_explain) { this.holiday_explain = holiday_explain; } public String getType() { return type; } public void setType(String type) { this.type = type; } @Override public String toString() { return "HolidayEntity{" + "date='" + date + '\'' + ", hour='" + hour + '\'' + ", holiday='" + holiday + '\'' + ", holiday_explain='" + holiday_explain + '\'' + ", type='" + type + '\'' + '}'; } }
5.执行,获取数据
@Autowired private HolidayRepository holidayRepository; @RequestMapping("/test") @ResponseBody public List<HolidayEntity> test() { return holidayRepository.findAll(); }
MySql配置
1.pom文件加入MySql配置
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.46</version> </dependency>
2.application.properties文件配置MySql相关
# tomcat配置 server.port=8090 # 数据库配置 #Mysql属性配置文件,Spring-boot系统配置 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://*.*.*.*:3306/db?autoReconnect=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai spring.datasource.username=*** spring.datasource.password=*** #配置自动建表:updata:没有表新建,有表更新操作,控制台显示建表语句 #spring.jpa.hibernate.ddl-auto=update spring.jpa.show-sql=true spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect #如下的配置会导致报错 Unable to build Hibernate SessionFactory #spring.jpa.properties.hibernate.hbm2ddl.auto=validate
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 常用设计模式/容器/依赖注入/静态代理/请求对象
- 详解nginx的请求限制(连接限制和请求限制)
- angular请求防抖,以及处理第一次请求失效
- RxHttp 一条链发送请求,新一代Http请求神器(一)
- RxHttp 一条链发送请求,新一代Http请求神器(一)
- 利用Jsonp跨域请求数据(原生和Jquery的ajax请求),简单易懂!
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Ruby原理剖析
[美] Patrick Shaughnessy / 张汉东、秦凡鹏 / 华中科技大学出版社 / 2016-12-1 / 78.80元
《Ruby原理剖析》解开Ruby编程语言的魔法面纱。全书图文并茂、深入浅出地剖析了Ruby编程语言的核心工作原理。作者本着科学实证的精神,设计了一系列实验,帮助读者轻松了解这门编程语言的工作奥秘,包括Ruby如何用虚拟机执行代码,Ruby的垃圾回收算法,以及类和模块在Ruby内部的关系等。一起来看看 《Ruby原理剖析》 这本书的介绍吧!