次の方法で共有


JavaScript Azure Functions で開発プロキシを使用する

JavaScript を使用して Azure Functions を構築し、開発プロキシを使用する場合は、Node.js アプリケーションで開発プロキシを するための一般的なガイダンスに従ってください

Von Bedeutung

起動時に Azure Functions が失敗しないようにするには、--as-system-proxy false オプションを使用するか、asSystemProxy ファイルにfalseするようにdevproxyrc.jsonを構成して、システム プロキシとして登録せずに開発プロキシを起動します。 開発プロキシをシステム プロキシとして登録すると、起動時に Azure Functions が失敗し、次のようなエラー メッセージが表示されます。

Grpc.Core.RpcException: 'Status(StatusCode="Internal", Detail="Error starting gRPC call. HttpRequestException: Requesting HTTP version 2.0 with version policy RequestVersionOrHigher while unable to establish HTTP/2 connection.", DebugException="System.Net.Http.HttpRequestException: Requesting HTTP version 2.0 with version policy RequestVersionOrHigher while unable to establish HTTP/2 connection.")'

開発時の開発プロキシの使用と運用環境での使用を簡単に切り替えるには、環境変数を使用して Azure Functions アプリでプロキシを最適に構成できます。 local.settings.json環境変数を含むようにHTTPS_PROXY ファイルを変更します。 さらに、証明書の検証を無効にして、Azure Functions アプリが開発プロキシで使用される自己署名証明書を信頼できるようにします。

{
  "IsEncrypted": false,
  "Values": {
    "FUNCTIONS_WORKER_RUNTIME": "node",
    "AzureWebJobsFeatureFlags": "EnableWorkerIndexing",
    "AzureWebJobsStorage": "UseDevelopmentStorage=true",
    "HTTPS_PROXY": "http://127.0.0.1:8000",
    "NODE_TLS_REJECT_UNAUTHORIZED": "0"
  }
}

Azure Functions アプリで、 process.env オブジェクトを使用して環境変数を読み取り、HTTP 要求のプロキシを構成します。

import { app, HttpRequest, HttpResponseInit, InvocationContext } from "@azure/functions";
import fetch from 'node-fetch';
import { HttpsProxyAgent } from 'https-proxy-agent';

export async function MyFnHttpTrigger(request: HttpRequest, context: InvocationContext): Promise<HttpResponseInit> {
    const options = process.env.HTTPS_PROXY ? { agent: new HttpsProxyAgent(process.env.HTTPS_PROXY) } : {};
    const resp = await fetch('https://jsonplaceholder.typicode.com/posts', options);
    const data = await resp.json();
    return {
      status: 200,
      jsonBody: data
    };
};

app.http('MyFnHttpTrigger', {
    methods: ['GET', 'POST'],
    authLevel: 'anonymous',
    handler: MyFnHttpTrigger
});