Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of de directory te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen de mappen te wijzigen.
Als u Azure Functions bouwt met Behulp van JavaScript en Dev Proxy wilt gebruiken, volgt u de algemene richtlijnen voor het gebruik van Dev Proxy met Node.js toepassingen.
Belangrijk
Als u wilt voorkomen dat Azure Functions fouten optreden tijdens het opstarten, start Dev Proxy zonder het te registreren als systeemproxy, hetzij door de --as-system-proxy false optie te gebruiken of door asSystemProxy naar false te configureren in het devproxyrc.json bestand. Als u Dev Proxy registreert als een systeemproxy, mislukt Azure Functions bij het opstarten met een foutbericht dat vergelijkbaar is met:
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.")'
Als u eenvoudig wilt kunnen schakelen tussen het gebruik van Dev Proxy in ontwikkeling en niet in productie, kunt u de proxy het beste configureren in uw Azure Functions-app met behulp van omgevingsvariabelen. Wijzig het local.settings.json bestand om de HTTPS_PROXY omgevingsvariabele op te nemen. Schakel bovendien certificaatvalidatie uit om de Azure Functions-app toe te staan het zelfondertekende certificaat te vertrouwen dat wordt gebruikt door Dev Proxy.
{
"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"
}
}
Gebruik het process.env object in uw Azure Functions-app om de omgevingsvariabelen te lezen en de proxy voor uw HTTP-aanvragen te configureren.
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
});