真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用springboot怎么實(shí)現(xiàn)前后端傳參

今天就跟大家聊聊有關(guān)使用spring boot怎么實(shí)現(xiàn)前后端傳參,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)公司是一家專業(yè)提供永仁企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、網(wǎng)站制作、成都h5網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為永仁眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

獲取傳參

@PathVariable注解主要用來(lái)獲取URL參數(shù)。即這種風(fēng)格的 URL:http://localhost:8080/user/{id}

@GetMapping("/user/{id}") 
public String testPathVariable(@PathVariable Integer id) {  System.out.println("獲取到的id為:" + id); 
return "success"; }

對(duì)于多個(gè)參數(shù)的獲取

@GetMapping("/user/{idd}/{name}") 
public String testPathVariable(@PathVariable(value = "idd") Integer id, @PathVariable String name) {  System.out.println("獲取到的id為:" + id); System.out.println("獲取到的name為:" + name); return "success"; }

@RequestParam:是從 Request 里獲取參數(shù)值,即這種風(fēng)格的 URL:http://localhost:8080/user?id=1。除此之外,該注解還可以用于 POST 請(qǐng)求,接收前端表單提交的參數(shù)

@RequestMapping("/user") 
public String testRequestParam(@RequestParam(value = "idd", required = false) Integer id) { 
System.out.println("獲取到的id為:" + id); 
return "success"; }

當(dāng)參數(shù)較多時(shí),可以不用@RequestParam。而是通過(guò)封裝實(shí)體類來(lái)接收參數(shù)。

public class User { 
private String username;
private String password;
//添加setter和getter }

使用實(shí)體接收的話,我們不必在前面加 @RequestParam 注解,直接使用即可。

@PostMapping("/form2") 
public String testForm(User user) { 
System.out.println("獲取到的username為:" + user.getUsername()); 
System.out.println("獲取到的password為:" + user.getPassword()); 
return "success"; 
}

上面的是表單實(shí)體提交。當(dāng)JSON格式提交時(shí),需要用@RequestBody。
@RequestBody 注解用于接收前端傳來(lái)的實(shí)體。接收參數(shù)為JSON格式的傳遞。

public class User { 
private String username; 
private String password; 
// set get } 

@PostMapping("/user") 
public String testRequestBody(@RequestBody User user) { System.out.println("獲取到的username為:" + user.getUsername()); 
System.out.println("獲取到的password為:" + user.getPassword()); 
return "success"; }

傳輸時(shí)需要傳JSON格式的參數(shù)。

Restful格式

前后端傳參一般使用Restful規(guī)范

RESTful 架構(gòu)一個(gè)核心概念是“資源”(Resource)。從 RESTful 的角度看,網(wǎng)絡(luò)里的任何東西都是資源,可以是一段文本、一張圖片、一首歌曲、一種服務(wù)等,每個(gè)資源都對(duì)應(yīng)一個(gè)特定的 URI(統(tǒng)一資源定位符),并用它進(jìn)行標(biāo)示,訪問(wèn)這個(gè) URI 就可以獲得這個(gè)資源。

spring boot的注解很好的支持了restful格式

  • @GetMapping,處理 Get 請(qǐng)求

  • @PostMapping,處理 Post 請(qǐng)求

  • @PutMapping,用于更新資源

  • @DeleteMapping,處理刪除請(qǐng)求

  • @PatchMapping,用于更新部分資源

@RestController注解可將返回的數(shù)據(jù)結(jié)果轉(zhuǎn)換成json格式,在sprinboot中默認(rèn)使用的JSON解析技術(shù)框架是Jackson。
基本示例

@RestController 
@RequestMapping("/") 
public class Hello { 
  @GetMapping(value = "hello") 
  public String hello(){ 
    return "hello world"; 
  } 
}

對(duì)null的處理

在項(xiàng)目中,遇到null值時(shí),希望把null都轉(zhuǎn)成""。需要設(shè)置一個(gè)配置

@Configuration 
public class Jackson { 
  @Bean 
 @Primary @ConditionalOnMissingBean(ObjectMapper.class) 
  public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) { 
    ObjectMapper objectMapper = builder.createXmlMapper(false).build(); 
    objectMapper.getSerializerProvider().setNullValueSerializer(new JsonSerializer() { 
      @Override 
 public void serialize(Object o, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException { 
        jsonGenerator.writeString(""); 
      } 
    }); 
    return objectMapper; 
  } 
}

就會(huì)自動(dòng)把null值轉(zhuǎn)換為空值""

包裝統(tǒng)一的JSON返回結(jié)構(gòu)

在后臺(tái)返回的接口數(shù)據(jù)中,一般要求結(jié)構(gòu)是統(tǒng)一的,包括有狀態(tài)碼、返回信息。所以可以用泛型封裝一個(gè)統(tǒng)一的JSON返回結(jié)構(gòu)

public class JsonResult { 
 
  private T data; 
  private String code; 
  private String msg; 
 
  /** 
 * 若沒(méi)有數(shù)據(jù)返回,默認(rèn)狀態(tài)碼為0 
 */ public JsonResult(T data){ 
    this.data = data; 
    this.code = "10200"; 
    this.msg = "操作成功"; 
  }
  
  //省略getter和setter

修改controller中的代碼

@RequestMapping("/list") 
public JsonResult getStudentList(){ 
  List list = new ArrayList<>(); 
  Student stu1 = new Student(2,"22",null); 
  Student stu2 = new Student(3,"33",null); 
  list.add(stu1); 
  list.add(stu2); 
  return new JsonResult<>(list); 
}

訪問(wèn)url,返回的格式將是:

{"data":
  [{"id":2,"username":"22","password":""},     {"id":3,"username":"33","password":""}],
"code":"10200",
"msg":"操作成功"}

取配置文件中的值

1、取配置文件中的配置

author.name=zhangsan

可以使用@Value注解即可獲取配置文件中的配置信息

@Value("${author.name}") 
private String userName;

2、設(shè)置配置類來(lái)保存配置

配置信息如下:

url.orderUrl=http://localhost:8002 
url.userUrl=http://localhost:8003 
url.shoppingUrl=http://localhost:8004

新建一個(gè)配置類,來(lái)保存配置

@Component 
@ConfigurationProperties(prefix = "url") 
public class MicroServiceUrl { 
  private String orderUrl; 
  private String userUrl; 
  private String shoppingUrl; 
  // 省去 get 和 set 方法 
}

@Component 注解是把該類作為組件放在spring容器中,使用時(shí)直接注入即可。
@ConfigurationProperties注解就是指明該類中的屬性名就是配置中去掉前綴后的名字

使用ConfigurationProperties需要加依賴

 
  org.springframework.boot 
  spring-boot-configuration-processor 
  true 

使用Resource注解就可以將添加配置類MicroServiceUrl引入到controller中使用了

@Resource 
private MicroServiceUrl microServiceUrl; 
 
@GetMapping(value = "getResource") 
public String getR(){ 
  return microServiceUrl.getUserUrl(); 
}

看完上述內(nèi)容,你們對(duì)使用spring boot怎么實(shí)現(xiàn)前后端傳參有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


本文題目:使用springboot怎么實(shí)現(xiàn)前后端傳參
分享URL:http://weahome.cn/article/ggposo.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部