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

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

springboot中怎么實現(xiàn)前后端傳參

springboot中怎么實現(xiàn)前后端傳參,針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序制作、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了元氏免費建站歡迎大家使用!

獲取傳參

@PathVariable注解主要用來獲取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"; }

對于多個參數(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 請求,接收前端表單提交的參數(shù)

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

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

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

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

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

上面的是表單實體提交。當(dāng)JSON格式提交時,需要用@RequestBody。@RequestBody 注解用于接收前端傳來的實體。接收參數(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"; }

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

Restful格式

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

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

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

@GetMapping,處理 Get 請求  @PostMapping,處理 Post 請求  @PutMapping,用于更新資源  @DeleteMapping,處理刪除請求  @PatchMapping,用于更新部分資源

@RestController注解可將返回的數(shù)據(jù)結(jié)果轉(zhuǎn)換成json格式,在sprinboot中默認(rèn)使用的JSON解析技術(shù)框架是Jackson?;臼纠?/p>

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

對null的處理

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

@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;   } }

就會自動把null值轉(zhuǎn)換為空值""

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

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

public class JsonResult {    private T data;   private String code;   private String msg;    /**  * 若沒有數(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); }

訪問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è)置配置類來保存配置

配置信息如下:

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

新建一個配置類,來保存配置

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

@Component 注解是把該類作為組件放在spring容器中,使用時直接注入即可。@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(); }

關(guān)于springboot中怎么實現(xiàn)前后端傳參問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。


文章標(biāo)題:springboot中怎么實現(xiàn)前后端傳參
文章分享:http://weahome.cn/article/jjjjoj.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部