Spring Bootトップページ設定解析(推奨)
7226 ワード
まず、Spring Bootトップページに設置されている3つの方法を説明します。
1.SpringBootデフォルトのトップページの設定
ファイルindex.を作成します。
data:image/s3,"s3://crabby-images/e834b/e834bf2252cec3b5972d19cefaa9d1a85c8dcf0e" alt="在这里插入图片描述"
http://localhost:8080/アクセス、成功表示
data:image/s3,"s3://crabby-images/a5e1c/a5e1cdb22d1551cb278f409f1ed4f66283733439" alt="在这里插入图片描述"
ソース分析
まず対応する自動配置類WebMvcAutoConfigrationの中の対応コードを探します。
data:image/s3,"s3://crabby-images/431cd/431cdab9c2871c8360090d2811e9c1c8945001d0" alt="在这里插入图片描述"
Static LocationsはWebProptisの内部静的な種類のResourceの属性であり、コンストラクタからその値が
/META-INF
/レスポンス/
/レスポンス/
/static/
//public/
前のコードに戻ります。Static Locationsを取得した後、巡回することによって、明らかに新しい方法が見られます。
ソースからは、別の静的リソースディレクトリの優先度の問題を見ることができます。getWelcome Pageは静的リソースディレクトリを遍歴しています。見つけたら戻りますので、優先度とstatic Locationsの中の順序が相対しています。確認してください。
まず各ディレクトリの下に対応するindx.ファイルを作成します。
data:image/s3,"s3://crabby-images/105b5/105b5b2dbae72f99288b47f83a4a76d6766ae2cd" alt="在这里插入图片描述"
http://localhost:8080/アクセス
data:image/s3,"s3://crabby-images/ebbde/ebbdee6f21579ed3c75bcf5a6d1738a63a44a27e" alt="在这里插入图片描述"
得られた結論と同じように、優先順位が一番高いのは/META-INF/resoures/で、/META-INF/resource/下のindex.ファイルを削除して再検証します。
data:image/s3,"s3://crabby-images/d2061/d2061e0f5e2817f621d3fb42df98c1e616638847" alt="在这里插入图片描述"
検証成功!
2.controllerに「/」のマップパスを追加
新規IndexController.java
data:image/s3,"s3://crabby-images/0635c/0635c48b8e7f5669b1b849c5d641e38a13d1f280" alt="在这里插入图片描述"
3.MVC拡張配置実現
新しいMyMvcConfigrationの配置類を作って、MVCの配置を拡張して、addView Controllerの方法を書き直します。
data:image/s3,"s3://crabby-images/e9d90/e9d900491f3596aa5b2893804d8f96c2ff3b2abc" alt="在这里插入图片描述"
拡張:優先順位の問題
以前の3つの方法は全部単独で設置しました。今は彼らを結合します。
data:image/s3,"s3://crabby-images/2ad3d/2ad3d3d7f306cf9f34c944b9ad0acc1057a4ac22" alt="在这里插入图片描述"
http://localhost:8080/アクセス
data:image/s3,"s3://crabby-images/2d5ad/2d5adc3cb5c5444d61ac2fa720634dd9468ddd51" alt="在这里插入图片描述"
優先度が一番高いのは第二の方法です。そしてindexControllerを削除して、再度検証します。
data:image/s3,"s3://crabby-images/801d4/801d41bb5a6d81f78b826138f3417630adf945d5" alt="在这里插入图片描述"
結論:Controller>MyMvcConfigration>デフォルト方法
ここで、SpringBootトップページの設定解析について詳しく紹介します。SprigBootトップページの設定内容は以前の文章を検索したり、下記の関連記事を見たりしてください。これからも応援してください。
1.SpringBootデフォルトのトップページの設定
ファイルindex.を作成します。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<h1> </h1>
</body>
</html>
index.ファイルをSpring Bootの任意の静的リソースディレクトリの下に置く。data:image/s3,"s3://crabby-images/e834b/e834bf2252cec3b5972d19cefaa9d1a85c8dcf0e" alt="在这里插入图片描述"
http://localhost:8080/アクセス、成功表示
data:image/s3,"s3://crabby-images/a5e1c/a5e1cdb22d1551cb278f409f1ed4f66283733439" alt="在这里插入图片描述"
ソース分析
まず対応する自動配置類WebMvcAutoConfigrationの中の対応コードを探します。
@Bean
public WelcomePageHandlerMapping welcomePageHandlerMapping(ApplicationContext applicationContext, FormattingConversionService mvcConversionService, ResourceUrlProvider mvcResourceUrlProvider) {
WelcomePageHandlerMapping welcomePageHandlerMapping =
new WelcomePageHandlerMapping(new TemplateAvailabilityProviders(applicationContext),
applicationContext, this.getWelcomePage(), this.mvcProperties.getStaticPathPattern());
welcomePageHandlerMapping.setInterceptors(this.getInterceptors(mvcConversionService, mvcResourceUrlProvider));
welcomePageHandlerMapping.setCorsConfigurations(this.getCorsConfigurations());
return welcomePageHandlerMapping;
}
SpringBootはWelcome PageHandlerMappingBenを登録してプロジェクトのデフォルトのトップページを処理します。コンストラクタの中のthis.get Welcome Pageはトップページの資源です。
private Resource getWelcomePage() {
String[] var1 = this.resourceProperties.getStaticLocations();
int var2 = var1.length;
for(int var3 = 0; var3 < var2; ++var3) {
String location = var1[var3];
Resource indexHtml = this.getIndexHtml(location);
if (indexHtml != null) {
return indexHtml;
}
}
ServletContext servletContext = this.getServletContext();
if (servletContext != null) {
return this.getIndexHtml((Resource)(new ServletContextResource(servletContext, "/")));
} else {
return null;
}
}
このコードを分析して、まずthis.resource PropertiesのStatic Locationsフィールドを獲得しました。名前の通り静的なパスです。まずStatic Locationsを追跡します。data:image/s3,"s3://crabby-images/431cd/431cdab9c2871c8360090d2811e9c1c8945001d0" alt="在这里插入图片描述"
Static LocationsはWebProptisの内部静的な種類のResourceの属性であり、コンストラクタからその値が
private static final String[] CLASSPATH_RESOURCE_LOCATIONS = new String[]{"classpath:/META-INF/resources/", "classpath:/resources/", "classpath:/static/", "classpath:/public/"};
明らかに、これはSpringBootの静的資源目録です。/META-INF
/レスポンス/
/レスポンス/
/static/
//public/
前のコードに戻ります。Static Locationsを取得した後、巡回することによって、明らかに新しい方法が見られます。
private Resource getIndexHtml(String location) {
return this.getIndexHtml(this.resourceLoader.getResource(location));
}
this.resource Loaderを使用して、locationに対応するResourceに戻り、別のget IndexHtml()関数を実行します。
private Resource getIndexHtml(Resource location) {
try {
Resource resource = location.createRelative("index.html");
if (resource.exists() && resource.getURL() != null) {
return resource;
}
} catch (Exception var3) {
}
return null;
}
明らかに、この方法は対応ディレクトリのindex.ファイルを取得することです。また振り返ってみます
for(int var3 = 0; var3 < var2; ++var3) {
String location = var1[var3];
Resource indexHtml = this.getIndexHtml(location);
if (indexHtml != null) {
return indexHtml;
}
}
対応するファイルが見つかったら、対応するリソースを返します。これはSpringBoot設定のトップページのデフォルト方式の原理です。ソースからは、別の静的リソースディレクトリの優先度の問題を見ることができます。getWelcome Pageは静的リソースディレクトリを遍歴しています。見つけたら戻りますので、優先度とstatic Locationsの中の順序が相対しています。確認してください。
まず各ディレクトリの下に対応するindx.ファイルを作成します。
data:image/s3,"s3://crabby-images/105b5/105b5b2dbae72f99288b47f83a4a76d6766ae2cd" alt="在这里插入图片描述"
http://localhost:8080/アクセス
data:image/s3,"s3://crabby-images/ebbde/ebbdee6f21579ed3c75bcf5a6d1738a63a44a27e" alt="在这里插入图片描述"
得られた結論と同じように、優先順位が一番高いのは/META-INF/resoures/で、/META-INF/resource/下のindex.ファイルを削除して再検証します。
data:image/s3,"s3://crabby-images/d2061/d2061e0f5e2817f621d3fb42df98c1e616638847" alt="在这里插入图片描述"
検証成功!
2.controllerに「/」のマップパスを追加
新規IndexController.java
package com.springboot04webapp.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class IndexController {
@RequestMapping("/")
public String index(){
return "indexController";
}
}
最初のページの資源indexController.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<h1>indexController </h1>
</body>
</html>
http://localhost:8080/アクセスdata:image/s3,"s3://crabby-images/0635c/0635c48b8e7f5669b1b849c5d641e38a13d1f280" alt="在这里插入图片描述"
3.MVC拡張配置実現
新しいMyMvcConfigrationの配置類を作って、MVCの配置を拡張して、addView Controllerの方法を書き直します。
package com.springboot04webapp.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class MyMvcConfiguration implements WebMvcConfigurer {
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/").setViewName("indexMVC");
}
}
トップページの資源indexMVC.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<h1>indexMVC </h1>
</body>
</html>
http://localhost:8080/アクセスdata:image/s3,"s3://crabby-images/e9d90/e9d900491f3596aa5b2893804d8f96c2ff3b2abc" alt="在这里插入图片描述"
拡張:優先順位の問題
以前の3つの方法は全部単独で設置しました。今は彼らを結合します。
data:image/s3,"s3://crabby-images/2ad3d/2ad3d3d7f306cf9f34c944b9ad0acc1057a4ac22" alt="在这里插入图片描述"
http://localhost:8080/アクセス
data:image/s3,"s3://crabby-images/2d5ad/2d5adc3cb5c5444d61ac2fa720634dd9468ddd51" alt="在这里插入图片描述"
優先度が一番高いのは第二の方法です。そしてindexControllerを削除して、再度検証します。
data:image/s3,"s3://crabby-images/801d4/801d41bb5a6d81f78b826138f3417630adf945d5" alt="在这里插入图片描述"
結論:Controller>MyMvcConfigration>デフォルト方法
ここで、SpringBootトップページの設定解析について詳しく紹介します。SprigBootトップページの設定内容は以前の文章を検索したり、下記の関連記事を見たりしてください。これからも応援してください。