この記事では主に 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) で直接設定できるメソッドも用意されています。