JavaScript Azure Functions 개발 프록시 사용
JavaScript를 사용하여 Azure Functions 빌드하고 개발 프록시를 사용하려는 경우 Node.js 애플리케이션에서 개발 프록시를 사용하기 위한 일반적인 지침을 따릅니다.
개발 시 개발 프록시를 사용하는 것과 프로덕션 환경에서 사용하지 않는 사이를 쉽게 전환할 수 있도록 환경 변수를 사용하여 Azure Functions 앱에서 프록시를 가장 잘 구성할 수 있습니다. 환경 변수를 local.settings.json
포함 HTTPS_PROXY
하도록 파일을 변경합니다. 또한 Azure Functions 앱이 Dev Proxy에서 사용하는 자체 서명된 인증서를 신뢰할 수 있도록 인증서 유효성 검사를 사용하지 않도록 설정합니다.
{
"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
});
GitHub에서 Microsoft와 공동 작업
이 콘텐츠의 원본은 GitHub에서 찾을 수 있으며, 여기서 문제와 끌어오기 요청을 만들고 검토할 수도 있습니다. 자세한 내용은 참여자 가이드를 참조하세요.
Dev Proxy