検索

SpringBootの実践スキル共有

Oct 15, 2018 pm 01:35 PM
javaspringboot

この記事の内容は、SpringBoot に関する実用的なヒントを共有することです。必要な友人が参考になれば幸いです。

序文

一部のソース コードとフレームワーク設計は、最近共有されたものです。考えてみると、ほとんどの人がコードを書くことに真剣に取り組んでいるはずであることがわかりました。それは、SpringBoot を使用するためのヒントです。

これは派手なものではありませんが、非常に便利です。

外部依存関係のシールド

最初は、外部依存関係をブロックすることです。これは何を意味しますか?

たとえば、日々の開発中に次のような問題を抱えていませんか:

プロジェクトは SpringCloud や dubbo などの分散サービスに基づいており、多くの基本サービスに依存する必要があります。

例: 注文番号の生成、ユーザー情報の取得など。

サービスの分割により、これらの機能は他のアプリケーションのインターフェイスの形式で提供されますが、幸いなことに、Mock を使用して単一のテスト用にブロックすることもできます。

しかし、アプリケーションを起動し、同時に独自の関連コードを実行したい場合はどうすればよいでしょうか?

通常、いくつかのアプローチがあります。

  • すべてのサービスをローカルで開始します。

  • 登録センターを開発環境に変更し、開発環境のサービスを利用します。

  • 自己テストのためにコードを開発環境に直接プッシュします。

私も以前はこの 3 つをすべて行うことができたようです。しかし、まだ小さな問題がいくつかあります。

  • ローカル スタートアップには多くのサービスがある可能性があり、そのサービスに問題がある場合、コンピュータがそれらをすべてサポートできるかどうかは不明です。それは続かないでしょう。

  • 開発環境に依存する前提は、ネットワークがオープンであることです。もう 1 つの問題は、開発環境のコードが非常に不安定で、テストに影響を与える可能性があることです。

  • 開発環境にプッシュする方がより信頼性の高い解決策となりますが、デバッグする場合はログを使用する方法しかなく、ローカル デバッグほど効率的ではありません。

それでは、どうすれば問題を解決できるでしょうか?他のサービスを起動せずにローカルでデバッグできます。

実際、単一のテスト メソッドを使用して、他の外部依存関係 Mock を削除することもできます。

大まかなプロセスは次のステップに分かれています。

  • SpringBoot が開始したら、Spring でシールドする必要がある API の Bean を見つけます (通常、このインターフェイスはSpring によって管理されます)。

  • Bean コンテナから Bean を手動で削除します。

  • この API のオブジェクトを再作成しますが、これは Mock から出たばかりです。

  • 次に、手動で Bean コンテナに登録します。

次のコードを例として取り上げます。

    @Override
    public BaseResponse<ordernoresvo> getUserByHystrix(@RequestBody UserReqVO userReqVO) {

        OrderNoReqVO vo = new OrderNoReqVO();
        vo.setAppId(123L);
        vo.setReqNo(userReqVO.getReqNo());
        BaseResponse<ordernoresvo> orderNo = orderServiceClient.getOrderNo(vo);
        return orderNo;
    }</ordernoresvo></ordernoresvo>
これは Spring Cloud アプリケーションです。

orderServiceClient に依存して注文番号を取得します。

orderServiceClient は外部 API であり、Spring によって管理されます。

元の Bean を置き換える

次のステップは、元の Bean を置き換えることです。

@Component
public class OrderMockServiceConfig implements CommandLineRunner {

    private final static Logger logger = LoggerFactory.getLogger(OrderMockServiceConfig.class);

    @Autowired
    private ApplicationContext applicationContext;

    @Value("${excute.env}")
    private String env;

    @Override
    public void run(String... strings) throws Exception {

        // 非本地环境不做处理
        if ("dev".equals(env) || "test".equals(env) || "pro".equals(env)) {
            return;
        }

        DefaultListableBeanFactory defaultListableBeanFactory = (DefaultListableBeanFactory) applicationContext.getAutowireCapableBeanFactory();

        OrderServiceClient orderServiceClient = defaultListableBeanFactory.getBean(OrderServiceClient.class);
        logger.info("======orderServiceClient {}=====", orderServiceClient.getClass());

        defaultListableBeanFactory.removeBeanDefinition(OrderServiceClient.class.getCanonicalName());

        OrderServiceClient mockOrderApi = PowerMockito.mock(OrderServiceClient.class,
                invocationOnMock -> BaseResponse.createSuccess(DateUtil.getLongTime() + "", "mock orderNo success"));

        defaultListableBeanFactory.registerSingleton(OrderServiceClient.class.getCanonicalName(), mockOrderApi);

        logger.info("======mockOrderApi {}=====", mockOrderApi.getClass());
    }
}

CommandLineRunner インターフェイスが実装されており、Spring コンテナの初期化が完了した後に run() メソッドを呼び出すことができます。

コードは非常に単純です。簡単に言うと、まずローカル環境を除いて、残りは実際にリモート サービスを呼び出す必要があります。

次のステップは、Bean を取得して手動で削除することです。

重要なステップ:

OrderServiceClient mockOrderApi = PowerMockito.mock(OrderServiceClient.class,
                invocationOnMock -> BaseResponse.createSuccess(DateUtil.getLongTime() + "", "mock orderNo success"));

defaultListableBeanFactory.registerSingleton(OrderServiceClient.class.getCanonicalName(), mockOrderApi);

新しい OrderServiceClient オブジェクトを作成し、それを Spring コンテナーに手動で登録します。

コードの最初の部分では、PowerMockito.mock の API を使用します。これにより、OrderServiceClient を呼び出すすべてのメソッドがデフォルトで返されるようにプロキシ オブジェクトを作成できます。

BaseResponse.createSuccess(DateUtil.getLongTime() + "", "mock orderNo success"))

今、置換せずにインターフェイスを呼び出し、ローカルが開始されていない場合にテストしてください。 OrderService:

SpringBootの実践スキル共有

##フォールバックが構成されていないため、サービスが見つからないことを示すエラーが報告されます。

Bean を置き換える場合:

SpringBootの実践スキル共有

再度リクエストしてもエラーは報告されず、デフォルトの戻り値が得られました。

SpringBootの実践スキル共有

ログから、

OrderServiceClient が最終的に Mock によってプロキシされたことがわかります。実際のメソッドを呼び出しません。

暗号化の構成

次のステップは暗号化を構成することです。これは基本機能であると考えられます。

たとえば、構成ファイル内の一部のアカウントとパスワードは暗号テキストで保存する必要があります。

そこで、今回は暗号化と復号化の実装にオープン ソース コンポーネントが使用されます。これは

SpringBoot に非常に適しており、完了するのに必要なコードはわずか数個だけです。

  • 首先根据加密密码将需要加密的配置加密为密文。

  • 替换原本明文保存的配置。

  • 再使用时进行解密。

使用该包也只需要引入一个依赖即可:

<dependency>
    <groupid>com.github.ulisesbocchio</groupid>
    <artifactid>jasypt-spring-boot-starter</artifactid>
    <version>1.14</version>
</dependency>

同时写一个单测根据密码生成密文,密码也可保存在配置文件中:

jasypt.encryptor.password=123456

接着在单测中生成密文。

    @Autowired
    private StringEncryptor encryptor;

    @Test
    public void getPass() {
        String name = encryptor.encrypt("userName");
        String password = encryptor.encrypt("password");
        System.out.println(name + "----------------");
        System.out.println(password + "----------------");

    }

之后只需要使用密文就行。

由于我这里是对数据库用户名和密码加密,所以还得有一个解密的过程。

利用 Spring Bean 的一个增强接口即可实现:

@Component
public class DataSourceProcess implements BeanPostProcessor {


    @Autowired
    private StringEncryptor encryptor;

    @Override
    public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
        return bean;
    }

    @Override
    public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {

        if (bean instanceof DataSourceProperties){
            DataSourceProperties dataSourceProperties = (DataSourceProperties) bean;
            dataSourceProperties.setUsername(encryptor.decrypt(dataSourceProperties.getUsername())) ;
            dataSourceProperties.setPassword(encryptor.decrypt(dataSourceProperties.getPassword()));
            return dataSourceProperties ;
        }

        return bean;
    }
}

这样就可以在真正使用时还原为明文。

同时也可以在启动命令中配置刚才的密码:

java -Djasypt.encryptor.password=password -jar target/jasypt-spring-boot-demo-0.0.1-SNAPSHOT.jar

以上がSpringBootの実践スキル共有の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はsegmentfault思否で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか?高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか?Mar 17, 2025 pm 05:46 PM

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

適切なバージョン化と依存関係管理を備えたカスタムJavaライブラリ(JARファイル)を作成および使用するにはどうすればよいですか?適切なバージョン化と依存関係管理を備えたカスタムJavaライブラリ(JARファイル)を作成および使用するにはどうすればよいですか?Mar 17, 2025 pm 05:45 PM

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

カフェインやグアバキャッシュなどのライブラリを使用して、Javaアプリケーションにマルチレベルキャッシュを実装するにはどうすればよいですか?カフェインやグアバキャッシュなどのライブラリを使用して、Javaアプリケーションにマルチレベルキャッシュを実装するにはどうすればよいですか?Mar 17, 2025 pm 05:44 PM

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか?キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか?Mar 17, 2025 pm 05:43 PM

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか?Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか?Mar 17, 2025 pm 05:35 PM

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。