Używanie serwera proxy deweloperskiego z usługą Azure Functions w języku JavaScript
Jeśli tworzysz usługę Azure Functions przy użyciu języka JavaScript i chcesz używać serwera proxy deweloperskiego, postępuj zgodnie z ogólnymi wskazówkami dotyczącymi korzystania z serwera proxy deweloperskiego z aplikacjami Node.js.
Aby móc łatwo przełączać się między używaniem serwera proxy deweloperskiego w środowisku deweloperskim i nie używać go w środowisku produkcyjnym, najlepiej skonfigurować serwer proxy w aplikacji usługi Azure Functions przy użyciu zmiennych środowiskowych. Zmień plik, local.settings.json
aby uwzględnić zmienną HTTPS_PROXY
środowiskową. Ponadto wyłącz walidację certyfikatu, aby umożliwić aplikacji Usługi Azure Functions ufanie certyfikatowi z podpisem własnym używanemu przez serwer proxy deweloperów.
{
"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"
}
}
W aplikacji usługi Azure Functions użyj process.env
obiektu , aby odczytać zmienne środowiskowe i skonfigurować serwer proxy dla żądań 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
});