Freigeben über


Verwenden von Dev Proxy mit JavaScript-Azure-Funktionen

Wenn Sie Azure-Funktionen mit JavaScript erstellen und Dev Proxy verwenden möchten, befolgen Sie die allgemeinen Anleitungen für die Verwendung von Dev Proxy mit Node.js-Anwendungen.

Von Bedeutung

Um zu verhindern, dass Azure Functions beim Start fehlschlägt, starten Sie Dev Proxy, ohne ihn als Systemproxy zu registrieren, entweder mithilfe der --as-system-proxy false Option oder durch Konfigurieren asSystemProxyfalse in der devproxyrc.json Datei. Wenn Sie Dev Proxy als Systemproxy registrieren, schlägt Azure Functions beim Start mit einer Fehlermeldung wie folgende fehl:

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.")'

Um zwischen der Verwendung von Dev Proxy in der Entwicklung und nicht in der Produktion zu wechseln, können Sie den Proxy in Ihrer Azure Functions-App am besten mithilfe von Umgebungsvariablen konfigurieren. Ändern Sie die local.settings.json Datei so, dass sie die Umgebungsvariable HTTPS_PROXY enthält. Deaktivieren Sie außerdem die Zertifikatüberprüfung, damit die Azure Functions-App dem selbstsignierten Zertifikat vertraut, das von Dev Proxy verwendet wird.

{
  "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"
  }
}

Verwenden Sie in Ihrer Azure Functions-App das process.env Objekt, um die Umgebungsvariablen zu lesen und den Proxy für Ihre HTTP-Anforderungen zu konfigurieren.

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
});