在Azure AD B2C中使用Azure AD Graph API创建用户

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

我正在尝试在Azure AD B2C目录中创建用户。我已通过在cmd中使用此命令发布示例JSON文件来成功创建用户:

>B2C Create-User <Path to my JSON file>

我想要做的是发布一些JSON字符串而不是JSON文件,命令行给我以下错误:

Error Calling the Graph API:
{
  "odata.error": {
    "code": "Request_BadRequest",
    "message": {
      "lang": "en",
      "value": "A value without a type name was found and no expected type is available. When the model is specified, each value in the payload must have a type which can be either specified in the payload, explicitly by the caller or implicitly inferred from the parent value."
    },
    "requestId": "965dba69-4488-4d24-88a4-989a6d06cd8d",
    "date": "2019-03-19T12:55:27"
  }
}

这就是我试图发布JSON的方式:

private static void CreateUser(string[] args)
    {

        string json = new JavaScriptSerializer().Serialize(new
        {
            accountEnabled = true,
            SignInName = new List<UserInformation.SignInName>()
            {
                new UserInformation.SignInName(){ type = "emailAddress", value = "[email protected]" }
            },
            creationType = "LocalAccount",
            displayName = "Safan Momin",
            mailNickname = "Safan",
            passwordProfile = new UserInformation.PasswordProfile
            {
                password = "Mazik@123", forceChangePasswordNextLogin = false
            },
            passwordPolicies = "DisablePasswordExpiration"

        });

        object formatted = JsonConvert.DeserializeObject(client.CreateUser(json).Result);
    }

这是我的CreateUser方法:

 public async Task<string> CreateUser(string json)
    {
        return await SendGraphPostRequest("/users", json);
    }

这是我的SendGraphPostRequest方法:

private async Task<string> SendGraphPostRequest(string api, string json)
        {
            // NOTE: This client uses ADAL v2, not ADAL v4
            AuthenticationResult result = authContext.AcquireToken(Globals.aadGraphResourceId, credential);
            HttpClient http = new HttpClient();
            string url = Globals.aadGraphEndpoint + tenant + api + "?" + Globals.aadGraphVersion;

            Console.ForegroundColor = ConsoleColor.Cyan;
            Console.WriteLine("POST " + url);
            Console.WriteLine("Authorization: Bearer " + result.AccessToken.Substring(0, 80) + "...");
            Console.WriteLine("Content-Type: application/json");
            Console.WriteLine("");
            Console.WriteLine("JSON: "+json);
            Console.WriteLine("");

            HttpRequestMessage request = new HttpRequestMessage(HttpMethod.Post, url);
            request.Headers.Authorization = new AuthenticationHeaderValue("Bearer", result.AccessToken);
            request.Content = new StringContent(json, Encoding.UTF8, "application/json");
            HttpResponseMessage response = await http.SendAsync(request);

            if (!response.IsSuccessStatusCode)
            {
                string error = await response.Content.ReadAsStringAsync();
                object formatted = JsonConvert.DeserializeObject(error);
                throw new WebException("Error Calling the Graph API: \n" + JsonConvert.SerializeObject(formatted, Formatting.Indented));
            }

            Console.ForegroundColor = ConsoleColor.Green;
            Console.WriteLine((int)response.StatusCode + ": " + response.ReasonPhrase);
            Console.WriteLine("");

            return await response.Content.ReadAsStringAsync();
        }
azure azure-ad-b2c azure-ad-graph-api
1个回答
1
投票

我正在编写我的JSON字符串并在那里发现错误。我写的是SignInName而不是signInNames

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