当我尝试POST到Azure功能时禁止

问题描述 投票:0回答:1

我已经使用了Azure功能。

功能应用程序由Azure Active Directory保护,因此为了调用它,我必须使用我的AAD凭据登录。

当我对该函数进行GET调用时,一切都很好。

但是当我尝试进行POST调用时,我收到以下错误:403 Forbidden You do not have permission to view this directory or page.

该函数使用Visual Studio进行部署,其入口点如下所示:

public static async Task<HttpResponseMessage> Run(
    [HttpTrigger(
        AuthorizationLevel.Anonymous, 
        "post", "get", 
        Route = null)] HttpRequestMessage req, 
    TraceWriter log)
{
    ...
}
c# azure post azure-functions http-status-code-403
1个回答
1
投票

它对我和以下的工作正常是我做的步骤:

  1. 使用以下代码从Visual Studio部署azure函数v1:
[FunctionName("Function1")]
        public static async Task<HttpResponseMessage> Run([HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)]HttpRequestMessage req, TraceWriter log)
        {
            log.Info("C# HTTP trigger function processed a request.");

            // parse query parameter
            string name = req.GetQueryNameValuePairs()
                .FirstOrDefault(q => string.Compare(q.Key, "name", true) == 0)
                .Value;

            if (name == null)
            {
                // Get request body
                dynamic data = await req.Content.ReadAsAsync<object>();
                name = data?.name;
            }

            return name == null
                ? req.CreateResponse(HttpStatusCode.BadRequest, "Please pass a name on the query string or in the request body")
                : req.CreateResponse(HttpStatusCode.OK, "Hello " + name);
        }
  1. 使用AAD从Portal启用EasyAUth。

EasyAuthImage

  1. 从身份验证/授权刀片中获取AAD应用程序的ClientID和Client Secret。

ClientID/ClientSceret

  1. 使用以下邮递员电话获取令牌:

Postman

  1. 一旦你从邮递员那里得到令牌,如上图所示,使用下面显示的相同令牌调用azure函数:

FunctionCall

© www.soinside.com 2019 - 2024. All rights reserved.