繁体   English   中英

无法显示来自 responsebody HttpClient 获取请求的数据

[英]Cannot display data from responsebody HttpClient get request

在我之前的帖子中,我询问了如何从 Http Get Request 中获取数据,其中正文为 C#。 现在我面临另一个错误, Android.Util.AndroidRuntimeException: 'Only the original thread that created a view hierarchy can touch its views.' 有谁知道如何解决这个问题?

代码

  var client = new HttpClient();

    var request = new HttpRequestMessage
    {
        Method = HttpMethod.Get,
        RequestUri = new Uri("my url"),
        Content = new StringContent("my json body content", Encoding.UTF8, "application/json"),
    };

    var response = await client.SendAsync(request).ConfigureAwait(false);
    response.EnsureSuccessStatusCode();
    var responsebody = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
    string text = responsebody.ToString();
    string[] str = text.Split(new[] { ',', ':' }, StringSplitOptions.RemoveEmptyEntries);
    string result = str[10];
    labelTxt.Text = result;

试试下面的东西(假设这整个事情是一个 function 称为“ SomeFunction ”)

private void SomeFunction() {
 Device.BeginInvokeOnMainThread(() => {
  var client = new HttpClient();

  var request = new HttpRequestMessage {
   Method = HttpMethod.Get,
    RequestUri = new Uri("my url"),
    Content = new StringContent("my json body content", Encoding.UTF8, "application/json"),
  };

  var response = await client.SendAsync(request).ConfigureAwait(false);
  response.EnsureSuccessStatusCode();
  var responsebody = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
  string text = responsebody.ToString();
  string[] str = text.Split(new [] {
   ',',
   ':'
  }, StringSplitOptions.RemoveEmptyEntries);
  string result = str[10];
  labelTxt.Text = result;
 });
}

嗨,请试试这个代码。

public async static Task<T> GetResultAsync<T>(string Url)
{
    try
    {
        if (CrossConnectivity.Current.IsConnected)
        {
            using (var client = new HttpClient())
            {
                client.BaseAddress = new Uri(BaseUrl);
                client.DefaultRequestHeaders.Clear();
                client.SetBearerToken(Helpers.Settings.ServiceToken);
                client.DefaultRequestHeaders.Add("Language", Helpers.Settings.AppLanuageSetting);
                client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
                HttpResponseMessage response = await client.GetAsync($"{Url}").ConfigureAwait(false);
                if (response.IsSuccessStatusCode)
                {
                    var result = await response.Content.ReadAsStringAsync();
                    return JsonConvert.DeserializeObject<T>(result,new JsonSerializerSettings { PreserveReferencesHandling = PreserveReferencesHandling.None });
                }
                else
                {
                    return default(T);
                }
            }
        }
        else
        {
            Acr.UserDialogs.UserDialogs.Instance.Toast("Please check your internet connection");
            return default(T);
        }
    }
    catch (Exception Ex)
    {
        Logging.ErrorLog(Ex, "GetResultAsync");
        return default(T);
    }
}

并使用这种方法

var 结果 = 等待 APIService.GetResultAsync>($"{ApiEndpoints}/{"Paramters1"}/{pageNo}");

正如上面好奇的男孩所说,您只能从 UI 线程(主线程)修改 UI 元素。

所以你可以尝试把labelTxt.Text = result; Device.BeginInvokeOnMainThread方法中。

var client = new HttpClient();

var request = new HttpRequestMessage
{
    Method = HttpMethod.Get,
    RequestUri = new Uri("my url"),
    Content = new StringContent("my json body content", Encoding.UTF8, "application/json"),
};

var response = await client.SendAsync(request).ConfigureAwait(false);
response.EnsureSuccessStatusCode();
var responsebody = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
string text = responsebody.ToString();
string[] str = text.Split(new[] { ',', ':' }, StringSplitOptions.RemoveEmptyEntries);
string result = str[10];
Device.BeginInvokeOnMainThread(() => {labelTxt.Text = result;});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM