SpringBoot入坑-請求參數傳遞

  前一篇我們探討了關於springboot的配置文件和Controller的使用,本篇我們來一起探討一下關於springboot如何傳遞參數的知識。

  參數傳遞我們最常見的就是在url後通過?/&兩個符號來將參數傳遞到後臺,當然springboot也是也一樣,我們可以通過這種方式將參數傳遞到後臺,那麼後臺如何接收這些參數呢?下面我們一起學習一下:

  這裏我們將用到@RequestParam註解,這個註解有三個參數分別是:value、required、defaultValue,具體的用法,下面一一爲大家介紹。

    @RequestMapping(value = "/par1", method = RequestMethod.GET)
    public String reqPar1(@RequestParam("name") String name){
        return name;
    }

  通過@RequestParam註解聲明接收用戶傳入的參數,這樣當我們在瀏覽器輸入http://localhost:8080/par1?name=123

    @RequestMapping(value = "/par2", method = RequestMethod.GET)
    public String reqPar2(@RequestParam(value = "name", required = false) String name){
        if(null != name){
            return name;
        }else{
            return "未傳入參數";
        }
    }

  我們看到第一個接口我們並沒有寫value和required,其實第一個接口是簡寫,等同於

@RequestParam(value = "name", required = true)

  required=true:該參數不能爲空;相反required=false:該參數能爲空

    @RequestMapping(value = "/par3", method = RequestMethod.GET)
    public String reqPar3(@RequestParam(value = "name", defaultValue = "null") String name){
        return name;
    }

  最後說一下defaultValue看字面意思,估計你已經想到它的作用了,是的當我們未穿入該參數時的默認值。

  下面我們先看一下博客園中博客地址的鏈接:http://www.cnblogs.com/AndroidJotting/p/8232686.html,請大家注意紅色位置,這樣的參數傳遞是不是很有趣,我們並不用設置參數的key,那麼這是怎麼實現的呢?請接着看。

    @RequestMapping(value = "/par4/{id}", method = RequestMethod.GET)
    public Integer reqPar4(@PathVariable("id") Integer id){
        return id;
    }

  這樣是不是和博客園的訪問很像,這樣我們便可以直接將傳遞參數加在url後面。最後再來活學活用一下:

    @RequestMapping(value = "/{id}/par5", method = RequestMethod.GET)
    public Integer reqPar5(@PathVariable("id") Integer id){
        return id;
    }

  OK到這裏關於參數傳遞的內容就和大家分享完畢,最後再給大家補充一個小知識:

  resources資源springboot默認只映射static、templates兩個文件夾下的文件,那麼如何進行拓展呢?很簡單,比如我們在resources下新建一個image資源,這是我們需要打開項目的主類:xxApplication

@SpringBootApplication
public class Springboot1Application extends WebMvcConfigurerAdapter {

    public static void main(String[] args) {
        SpringApplication.run(Springboot1Application.class, args);
    }

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        super.addResourceHandlers(registry);
        //這種方式會在默認的基礎上增加/image/**映射到classpath:/image/,不會影響默認的方式,可以同時使用。
        registry.addResourceHandler("/image/**")
                .addResourceLocations("classpath:/image/");
    }
}

  這樣簡單一配置,我們就完成了上面的需求。

  下一篇springboot持久化操作

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章