ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
@Configuration の基本
Spring の Bean 定義は元々 XML(applicationContext.xml)で書いていましたが、Java コードで書く方が型安全・IDE 補完が効くため @Configuration + @Bean が標準になりました。
@Configuration
public class AppConfig {
@Bean
public DataSource dataSource() {
HikariConfig config = new HikariConfig();
config.setJdbcUrl("jdbc:postgresql://localhost:5432/mydb");
config.setUsername("user");
config.setPassword("secret");
return new HikariDataSource(config);
}
@Bean
public JdbcTemplate jdbcTemplate(DataSource dataSource) { // 上で定義した Bean を注入
return new JdbcTemplate(dataSource);
}
@Bean
public RestTemplate restTemplate() {
RestTemplate rt = new RestTemplate();
rt.setRequestFactory(new HttpComponentsClientHttpRequestFactory());
return rt;
}
}
@Bean メソッドの特性
シングルトン保証(proxyBeanMethods = true)
デフォルトでは @Configuration クラスは CGLib プロキシ化され、@Bean メソッド呼び出しが常に同じインスタンスを返すようになります:
@Configuration
public class AppConfig {
@Bean
public FooBean foo() {
return new FooBean();
}
@Bean
public BarBean bar() {
return new BarBean(foo()); // ← foo() を呼ぶ
}
@Bean
public BazBean baz() {
return new BazBean(foo()); // ← もう一度 foo() を呼ぶ
}
}
// → bar.foo == baz.foo(同じインスタンス、シングルトン保証)
proxyBeanMethods = false(パフォーマンス重視)
@Configuration(proxyBeanMethods = false)
public class LightConfig {
@Bean
public FooBean foo() {
return new FooBean();
}
@Bean
public BarBean bar() {
return new BarBean(foo()); // ← 直接呼び出し(新インスタンス)
}
}
// → 引数で受け取る方が安全
@Bean
public BarBean bar(FooBean foo) { // ← DI で注入
return new BarBean(foo);
}
@Bean メソッドの属性
@Configuration
public class AppConfig {
// 名前指定
@Bean(name = "myDataSource")
public DataSource dataSource() { ... }
// 複数名(エイリアス)
@Bean({"ds", "dataSource"})
public DataSource dataSource() { ... }
// 初期化と破棄
@Bean(initMethod = "init", destroyMethod = "close")
public ConnectionPool connectionPool() {
return new ConnectionPool();
}
// 自動破棄をオフ
@Bean(destroyMethod = "")
public AutoCloseable customResource() { ... }
}
関連アノテーションの組み合わせ
@ComponentScan
@Configuration
@ComponentScan(basePackages = {"com.example.service", "com.example.controller"})
public class AppConfig { ... }
@PropertySource(外部プロパティ読み込み)
@Configuration
@PropertySource("classpath:app.properties")
public class AppConfig {
@Value("${app.host}")
private String host;
@Bean
public Environment env() { ... }
}
@Import(複数 Configuration を組み合わせ)
@Configuration
@Import({DatabaseConfig.class, SecurityConfig.class, MailConfig.class})
public class AppConfig { ... }
// またはモジュール化
@Configuration
public class DatabaseConfig {
@Bean public DataSource dataSource() { ... }
@Bean public JdbcTemplate jdbcTemplate(DataSource ds) { ... }
}
@Configuration
public class SecurityConfig {
@Bean public PasswordEncoder passwordEncoder() { ... }
}
プロファイル別の Configuration
@Configuration
@Profile("prod")
public class ProdConfig {
@Bean
public DataSource dataSource() {
// 本番用 DB 接続
}
}
@Configuration
@Profile({"dev", "test"})
public class DevConfig {
@Bean
public DataSource dataSource() {
// 開発用 H2 等
}
}
# 起動時にプロファイル指定
java -jar app.jar --spring.profiles.active=prod
条件付き Configuration
@Configuration
@ConditionalOnProperty(name = "feature.mail.enabled", havingValue = "true")
public class MailConfig {
@Bean
public MailSender mailSender() { ... }
}
@Configuration
@ConditionalOnClass(name = "redis.clients.jedis.Jedis") // クラスパスに Jedis があれば
public class RedisConfig {
@Bean
public RedisTemplate redisTemplate() { ... }
}
@Configuration
@ConditionalOnMissingBean(DataSource.class) // DataSource Bean がなければ
public class DefaultDataSourceConfig {
@Bean
public DataSource dataSource() {
return new EmbeddedDatabaseBuilder().build();
}
}
@Configuration と @Component の違い
| 項目 | @Configuration | @Component |
|---|---|---|
| クラス自体 | Bean 登録 | Bean 登録 |
| 内部の @Bean | シングルトン保証 | 呼ぶたびに新インスタンス |
| CGLib プロキシ | あり(デフォルト) | なし |
| 用途 | サードパーティ Bean / 設定中心 | ビジネスロジッククラス |
Spring Boot での自動構成
Spring Boot は @SpringBootApplication 内部で @EnableAutoConfiguration を有効にし、starter 依存に応じて自動的に @Configuration クラスを読み込みます:
@SpringBootApplication
// 内部で以下を行う:
// @Configuration
// @EnableAutoConfiguration
// @ComponentScan
public class MyApp {
public static void main(String[] args) {
SpringApplication.run(MyApp.class, args);
}
}
# 起動時に有効な自動構成を見る
java -jar app.jar --debug
# 自動構成を除外
@SpringBootApplication(exclude = {
DataSourceAutoConfiguration.class,
SecurityAutoConfiguration.class
})
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?