Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
Ha Az Azure Functionst JavaScript használatával hozza létre, és Dev Proxyt szeretne használni, kövesse a Dev Proxy és Node.js alkalmazások használatával kapcsolatos általános útmutatást.
Fontos
Ha meg szeretné akadályozni, hogy az Azure Functions indításkor sikertelen legyen, indítsa el a Dev Proxyt anélkül, hogy rendszerproxyként regisztrálná. Ezt megteheti a --as-system-proxy false beállítás használatával, vagy ha beállítja a asSystemProxy értéket false-ra a devproxyrc.json fájlban. Ha a Dev Proxyt rendszerproxyként regisztrálja, az Azure Functions indításakor a következőhöz hasonló hibaüzenet jelenik meg:
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.")'
Ahhoz, hogy könnyen válthasson a Dev Proxy fejlesztési környezetben való használata és a produkciós környezetben való mellőzése között, az Azure Functions alkalmazásban a proxyt a legjobban környezeti változók használatával konfigurálhatja. Módosítsa a fájlt úgy local.settings.json , hogy tartalmazza a környezeti változót HTTPS_PROXY . Emellett tiltsa le a tanúsítványérvényesítést, hogy az Azure Functions-alkalmazás megbízhasson a Dev Proxy által használt önaláírt tanúsítványban.
{
"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"
}
}
Az Azure Functions-alkalmazásban használja az process.env objektumot a környezeti változók olvasására és a HTTP-kérelmek proxyjának konfigurálására.
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
});