SpringBoot如何返回頁面的實現(xiàn)方法
SpringBoot中使用Controller和頁面的結(jié)合能夠很好地實現(xiàn)用戶的功能及頁面數(shù)據(jù)的傳遞。但是在返回頁面的時候竟然會出現(xiàn)404或者500的錯誤,我總結(jié)了一下如何實現(xiàn)頁面的返回以及這里面所包含的坑。
SpringBoot中對Thymeleaf的集成已經(jīng)基本完善,但在特殊情況下,并不需要或者不能使用Thymeleaf,所以分成兩種情況對頁面的返回進行闡述。
首先說一下這兩種情況下都會發(fā)生的錯誤,也是新手們經(jīng)常會出現(xiàn)的錯誤。
直接上代碼:
@RestControllerpublic class TestController { @RequestMapping('/') public String index() {return 'index'; }}
這個代碼的初衷是返回index.html頁面,但是執(zhí)行的結(jié)果是在頁面中輸出index。
原因分析:@RestController注解相當(dāng)于@ResponseBody和@Controller合在一起的作用。在使用@RestController注解Controller時,Controller中的方法無法返回jsp頁面,或者html,配置的視圖解析器 InternalResourceViewResolver不起作用,返回的內(nèi)容就是Return 里的內(nèi)容。
包括在Mapping注解使用的同時使用@ResponseBody時也會出現(xiàn)同樣的問題。
解決辦法:①去除@ResponseBody或?qū)⒑蠷est的注解換成對應(yīng)的原始注解;
②不通過String返回,通過ModelAndView對象返回,上述例子可將return語句換成下面的句子:
return new ModelAndView('index');
在使用ModelAndView對象返回的時候,不需要考慮有沒有@ResponseBody類似的注解。
還有一個需要注意的點:@RequestMapping中的路徑一定不要和返回的頁面名稱完全相同,這樣會報500的錯誤!!!!
如下面這樣是不行的:
@Controllerpublic class TestController { @RequestMapping('/index') public String idx() {return 'index'; }}1、在不使用模板引擎的情況下:
在不使用模板引擎的情況下,訪問頁面的方法有兩種:
1)將所需要訪問的頁面放在resources/static/文件夾下,這樣就可以直接訪問這個頁面。如:
在未配置任何東西的情況下可以直接訪問:
而同樣在resources,但是在templates文件夾下的login.html卻無法訪問:
2)使用redirect實現(xiàn)頁面的跳轉(zhuǎn)
示例代碼(在頁面路徑和上面一致的情況下):
@Controllerpublic class TestController { @RequestMapping('/map1') public String index() {return 'redirect:index.html'; } @RequestMapping('/map2') public String map2() {return 'redirect:login.html'; }}
執(zhí)行結(jié)果:
這說明這種方法也需要將html文件放在static目錄下才能實現(xiàn)頁面的跳轉(zhuǎn)。
當(dāng)然還是有終極解決方案來解決這個存放路徑問題的,那就是使用springmvc的配置:
spring: mvc: view: suffix: .html static-path-pattern: /** resources: static-locations: classpath:/templates/,classpath:/static/
這樣配置后,map1和map2都可以訪問到頁面了。
2、使用Thymeleaf模板引擎:先將所需要的依賴添加至pom.xml
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-thymeleaf --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> <version>2.1.6.RELEASE</version></dependency>
同樣的頁面路徑下將controller代碼修改成下面的代碼:
@Controllerpublic class TestController { @RequestMapping('/map1') public String index() {return 'index'; } /** 下面的代碼可以實現(xiàn)和上面代碼一樣的功能 */ /*public ModelAndView index() {return new ModelAndView('index'); }*/ @RequestMapping('map2') public String map2() {return 'login'; }}
執(zhí)行結(jié)果:
這又說明一個問題,所需要的頁面必須放在templates文件夾下。當(dāng)然也可以修改,更改配置文件:
spring: thymeleaf: prefix: classpath:/static/ suffix: .html cache: false #關(guān)閉緩存
更改prefix對應(yīng)的值可以改變Thymeleaf所訪問的目錄。但好像只能有一個目錄。
綜上:模板引擎的使用與否都可以實現(xiàn)頁面的訪問。區(qū)別在于頁面所存放的位置以及訪問或返回的時候后綴名加不加的問題。
到此這篇關(guān)于SpringBoot如何返回頁面的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)SpringBoot返回頁面內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. JSP取得在WEB.XML中定義的參數(shù)2. 關(guān)于html嵌入xml數(shù)據(jù)島如何穿過樹形結(jié)構(gòu)關(guān)系的問題3. WMLScript的語法基礎(chǔ)4. el-input無法輸入的問題和表單驗證失敗問題解決5. XML 非法字符(轉(zhuǎn)義字符)6. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)7. 不要在HTML中濫用div8. vue實現(xiàn)復(fù)制文字復(fù)制圖片實例詳解9. XML入門的常見問題(三)10. 前端html+css實現(xiàn)動態(tài)生日快樂代碼
