0

Postman を使用しているときに外部 API を呼び出そうとすると、次のように動作し、値が返されます。

投稿先 URL: https://test.com/api/v1/users/check

投稿する Data Raw Jason:

 { 
  "access_token":"4444-EA444B6-2844C7-A09C-44B05CA78E42A3", 
  "email":"test@test.com", 
  "create_user": true, 
  "first_name": "test4", 
  "last_name": "test", 
  "phone": 3104054512 
  } 

これは機能しており、応答モデルを返しています。

しかし、このコードを試してAPIを呼び出すと:

コントローラ:

     [Route("CreateUser")]
    public Task<UserReturn> CreateUser([FromBody] User user)
    {

        return  homebirdRepository.CreateUser(user);
    }



 public async Task<UserReturn> CreateUser(User userCheck)
    {
        using (GetWSObject<UserReturn> addObjectInt = new GetWSObject<UserReturn>())
        {
            return await addObjectInt.PostWSObjectModel("api/v1/users/check", userCheck, "API_URI");
        }
    }






    public async Task<T> PostWSObjectModel(string uriActionString, Object model, string apiKey)
    {
        T returnValue = default(T);

        try
        {
            using (var client = new HttpClient())
            {
                client.BaseAddress = new Uri(WebConfigurationManager.AppSettings[apiKey]);
                var content = new StringContent(JsonConvert.SerializeObject(model));
                content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
                HttpResponseMessage response = await client.PostAsync(uriActionString, content);
                response.EnsureSuccessStatusCode();


                var test = response.Content.ReadAsStringAsync().Result;


                returnValue = JsonConvert.DeserializeObject<T>(((HttpResponseMessage)response).Content.ReadAsStringAsync().Result);
            }

            return returnValue;
        }
        catch (Exception e)
        {
            throw (e);
        }
    }

このコードは私にこのエラーを返しています:

   StatusCode: 401, ReasonPhrase: 'Unauthorized', Version: 1.1, Content: 
 System.Net.Http.StreamContent, 
   Headers:
  {
   Connection: keep-alive
 Access-Control-Allow-Origin: *
 Access-Control-Allow-Headers: Content-Type, Access-Control-Allow-Headers, Authorization, X-Requested- 
With
 Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS
  Cache-Control: no-cache, private
 Date: Sat, 28 Dec 2019 00:00:04 GMT
 Set-Cookie:laravel_session=eyJpdiI6IlI2MUdzOFJmS0RcL1k1VmJCeTc4bk1nPT0iLCJ2YWx1ZSI6IlZXNW11MGw2bXk0ajFEaTM2VnhmbUZjQnFzdnRDRHV5ejJMaDRqTVJYQm1yclNyUUkweDNRMUhpZDZwblpES1MiLCJtYWMiOiI0NmFiODA4YzEyNTkxZDllNDViNGUwOGIzYjY2ZWYxZGQwNzI1NmZmYzYxYTBkZGU0M2NmMDBlYzIzN2E3OTFjIn0%3D; expires=Sat, 28-Dec-2019 02:00:04 GMT; Max-Age=7200; path=/; httponly
Server: Apache
Content-Length: 21
Content-Type: text/html; charset=UTF-8
}}
4

2 に答える 2

0

Authorization ヘッダーを追加する必要があります。これは郵便配達員によって追加および計算されます。コピー/投稿できます。基本認証を使用している場合は、次のようになります。

client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", "郵便配達員からコピーする値");

于 2020-12-03T14:52:02.870 に答える