検索
ホームページJava&#&チュートリアルSpring Cloud Netflix Zuul プロキシ ゲートウェイを使用してバックエンド REST サービスにアクセスする実装 (コード)

この記事の内容は、Spring Cloud Netflix Zuul プロキシ ゲートウェイを使用してバックエンド REST サービスにアクセスする実装 (コード) に関するものです。必要な方は参考にしていただければ幸いです。 。

1. 概要

この記事では、互いに別々にデプロイされたフロントエンド アプリケーションとバックエンド REST API サービスの間で通信する方法について説明します。その目的は、ブラウザーのクロスドメイン リソース アクセスと同一オリジン ポリシーの制限を解決し、同じサーバーにない場合でもページ UI がバックグラウンド API を呼び出せるようにすることです。

ここでは、UI アプリケーションと単純な REST API という 2 つの別個のアプリケーションを作成しました。UI アプリケーションで Zuul プロキシを使用して、REST API への呼び出しをプロキシします。 Zuul は、Netflix の JVM ベースのルーターおよびサーバー側のロード バランサーです。 Spring Cloud は、組み込み Zuul プロキシと優れた統合を備えています。

2.REST アプリケーション

私たちの REST API アプリケーションは、シンプルな Spring Boot アプリケーションです。この記事では、サーバーにデプロイされた API はポート 8081 で実行されます。

設定ファイル

server.contextPath=/spring-zuul-foos-resourceserver.port=80
81

まず、使用するリソースの基本的な DTO を定義します:

public class Foo {
    private long id;    
    private String name;    
    // standard getters and setters
    }

単純なコントローラーを定義します:

@Controllerpublic class FooController {

    @RequestMapping(method = RequestMethod.GET, value = "/foos/{id}")    
    @ResponseBody
    public Foo findById(
      @PathVariable long id, HttpServletRequest req, HttpServletResponse res) {        
      return new Foo(Long.parseLong(randomNumeric(2)), randomAlphabetic(4));
    }
}

3. フロントエンド アプリケーション

私たちの UI アプリケーションも単純な Spring Boot アプリケーションです。この記事では、アプリケーションはポート 8080 で実行されています。

まず、Spring Cloud 経由で zuul サポートの依存関係を UI アプリケーションの pom に追加する必要があります。これを yml で行います:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-zuul</artifactId></dependency>

注:

    リソースサーバー Foos をプロキシします。
  • UI からの「/foos/」で始まるすべてのリクエストは、次の Foos リソース サーバーにルーティングされます: http://loclahost:8081/spring-zuul-foos-resource/foos/
  • その後、次のように書きますメインページのindex.html — ここでいくつかのAngularJSを使用しています:
zuul:
  routes:
    foos:
      path: /foos/**
      url: http://localhost:8081/spring-zuul-foos-resource/foos

ここで最も重要な点は、相対URLを使用してAPIにアクセスする方法です。

API アプリケーションは UI アプリケーションと同じサーバーにデプロイされていないため、相対 URL は機能せず、プロキシなしでは機能しないことに注意してください。

ただし、プロキシを通じて、Zuul プロキシを介して Foo リソースにアクセスします。Zuul プロキシは、これらのリクエストを API が実際にデプロイされている場所にルーティングするように構成されています。

最後に、ブート対応アプリケーション:

<html>
<body ng-app="myApp" ng-controller="mainCtrl">
<script src="angular.min.js"></script>
<script src="angular-resource.min.js"></script>
<script>
var app = angular.module(&#39;myApp&#39;, ["ngResource"]);

app.controller(&#39;mainCtrl&#39;, function($scope,$resource,$http) {
    $scope.foo = {id:0 , name:"sample foo"};
    $scope.foos = $resource("/foos/:fooId",{fooId:&#39;@id&#39;});

    $scope.getFoo = function(){
        $scope.foo = $scope.foos.get({fooId:$scope.foo.id});
    }  
});</script><p>
    <h1 id="Foo-nbsp-Details">Foo Details</h1>
    <span>{{foo.id}}</span>
    <span>{{foo.name}}</span>
    <a href="#" ng-click="getFoo()">New Foo</a>
    </p>
    </body>
    </html>

これは @EnableZuulProxy アノテーションを使用して Zuul プロキシを開始します。これは非常にクリーンで簡潔です。

4. テストを実行します

2 つのアプリケーション システムをそれぞれ起動し、ブラウザに http://localhost:8080/index を入力します

[New Foo] ボタンをクリックするたびにバックグラウンド REST API にアクセスします。



Spring Cloud Netflix Zuul プロキシ ゲートウェイを使用してバックエンド REST サービスにアクセスする実装 (コード) 5. カスタム Zuul フィルター

複数の Zuul フィルターが利用可能です。独自のカスタム フィルターを作成することもできます:

@EnableZuulProxy@SpringBootApplicationpublic class UiApplication extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(UiApplication.class, args);
    }
}

この単純なフィルターは、「Test」というヘッダーをリクエストの属性に追加するだけです - もちろん、必要に応じてリクエストを増やすことができます。

6. カスタム Zuul フィルターをテストします

最後に、テストしてカスタム フィルターが機能していることを確認しましょう - まず、Foos リソース サーバー上の FooController を変更します:

@Componentpublic class CustomZuulFilter extends ZuulFilter {

    @Override
    public Object run() {
        RequestContext ctx = RequestContext.getCurrentContext();
        ctx.addZuulRequestHeader("Test", "TestSample");        
        return null;
    }    @Override
    public boolean shouldFilter() {       
    return true;
    }    // ...}

さて、テストしてみましょう。

@Controllerpublic class FooController {

    @GetMapping("/foos/{id}")    @ResponseBody
    public Foo findById(
      @PathVariable long id, HttpServletRequest req, HttpServletResponse res) {        
      if (req.getHeader("Test") != null) {
            res.addHeader("Test", req.getHeader("Test"));
        }        return new Foo(Long.parseLong(randomNumeric(2)), randomAlphabetic(4));
    }
}

7. 結論

この投稿では、Zuul を使用して UI アプリケーションから REST API にリクエストをルーティングすることに焦点を当てました。 CORS と同一生成元ポリシーを解決し、転送中の HTTP リクエストのカスタマイズと拡張にも成功しました。

関連する推奨事項:

Spring Cloud Feign は HTTP を使用してリモート サービスをリクエストします


spring-cloud-sleuth+zipkin 追跡サービスの実装 (2)

以上がSpring Cloud Netflix Zuul プロキシ ゲートウェイを使用してバックエンド REST サービスにアクセスする実装 (コード)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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ヘンタイを無料で生成します。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境