ホームページ >Java >&#&チュートリアル >Javaでの静的リソースのロード例の詳細な説明
この記事では主に Spring Boot での静的リソースの読み込み処理方法を紹介します。必要な方は参考にしてください
1. Spring Boot のデフォルトのリソース処理
Spring Boot はデフォルトで静的リソース処理を提供します。 WebMvcAutoConfiguration でさまざまなプロパティを構成します。
Spring Boot がファイルをロードするためのデフォルトのパスは次のとおりです:
/META-INF/resources/
/resources/
/static/
/public/
これらのディレクトリの下では、もちろん Spring からも参照できます。ブート ソース コード Java コード:
private static final String[] CLASSPATH_RESOURCE_LOCATIONS = { "classpath:/META-INF/resources/", "classpath:/resources/", "classpath:/static/", "classpath:/public/" };
上記は、静的リソースのマッピング パスです。優先順位は次のとおりです: META-INF/resources > static > すべてのローカル静的リソースは以下で構成されます。 Web アプリの下ではなく、クラスパスです。
Spring Boot によって提供される Sping MVC が要件を満たしていない場合は、構成クラス (@Configuration アノテーションが付けられたクラス) と @EnableWebMvc アノテーションを使用して、完全に制御された MVC 構成を実現できます。 もちろん、通常、Spring Boot の自動構成はほとんどのニーズを満たします。 Spring Boot によって提供される利便性を維持し、独自の追加構成を追加する必要がある場合は、@EnableWebMvc アノテーションを使用せずに構成クラスを定義し、WebMvcConfigurerAdapter を継承できます。
@EnableWebMvc を使用すると、公式の /static、/public、META-INF/resources、/resources および静的リソースを保存するその他のディレクトリが自動的にカバーされます。
2. カスタム リソース マッピング
ここでは、このクラスのメソッドをオーバーライドすることで、一般的に使用される構成をいくつか紹介します。
カスタマイズされたリソース マッピング addResourceHandlers@Configuration public class SimpleWebAppConfigurer extends WebMvcConfigurerAdapter { @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/myresource/**").addResourceLocations("classpath:/myresource/"); super.addResourceHandlers(registry); } }
/myresource/* をデフォルトと同じ /* に変更すると、addResourceLocations を複数回使用してディレクトリを追加できます。最初に追加した優先順位は、後で追加したものよりも高くなります。
3. 外部リソースを使用する
絶対パスフォルダー (H:/images/ など) を指定したい場合は、addResourceLocations を使用するだけで指定できます。 // 可以直接使用addResourceLocations 指定磁盘绝对路径,同样可以配置多个位置,注意路径写法需要加上file:
registry.addResourceHandler("/myimgs/**").addResourceLocations("file:H:/myimgs/");
は、
を介して設定されます。実際、Spring Boot には、application.properties (または .yml) で直接設定できるメソッドも用意されています。
設定方法は次のとおりです: # 默认值为 /**
spring.mvc.static-path-pattern=classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/
spring.resources.static-locations=这里设置要指向的路径,多个使用英文逗号隔开
spring.resources.static-locations を使用してパターンが指すパスを再定義し、classpath: と file: をサポートします (上で説明済み)
spring.mvc.static- に注意してくださいpath - 定義できるパターンは 1 つだけであり、カンマで区切られた複数のメソッドは現在サポートされていません。
【関連する推奨事項】
1.
無料の Java ビデオチュートリアル以上がJavaでの静的リソースのロード例の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。