将开发代理与 JavaScript Azure Functions配合使用

如果使用 JavaScript 生成Azure Functions并且想要使用开发代理,请遵循将开发代理与 Node.js 应用程序配合使用的一般指南。

为了能够在开发中使用开发代理和不在生产环境中轻松切换,可以使用环境变量在 Azure Functions 应用中配置代理。 更改 local.settings.json 文件以包含 HTTPS_PROXY 环境变量。 此外,禁用证书验证以允许Azure Functions应用信任开发代理使用的自签名证书。

{
  "IsEncrypted": false,
  "Values": {
    "FUNCTIONS_WORKER_RUNTIME": "node",
    "AzureWebJobsFeatureFlags": "EnableWorkerIndexing",
    "AzureWebJobsStorage": "UseDevelopmentStorage=true",
    "HTTP_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.HTTP_PROXY ? { agent: new HttpsProxyAgent(process.env.HTTP_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
});