C# HttpClient 동기화 사용 방법
3259 단어 코드
private async void getservertime()
{
string servertime = "0";// , ref out
HttpClientHandler handler1 = new HttpClientHandler();
handler1.AllowAutoRedirect = false;
HttpClient httpClient1 = new HttpClient(handler1);
httpClient1.DefaultRequestHeaders.Add("user-agent", UserAgent);
if (InternetGetConnectedState(0, 0) == false)
{
//
servertime = "0";
return ;
}
try
{
HttpResponseMessage result = await httpClient1.GetAsync("https://api.m.taobao.com/rest/api3.do?api=mtop.common.getTimestamp");
if (result.IsSuccessStatusCode)
{
result.EnsureSuccessStatusCode();
string responseBodyAsText = await result.Content.ReadAsStringAsync();
JObject sertime = JObject.Parse(responseBodyAsText);
servertime=sertime["data"]["t"].ToString();
}
else
{
servertime= "0";
}
}
catch (HttpRequestException hre)
{
servertime = "0"; ;
}
handler1.Dispose();
httpClient1.Dispose();
}
반환값 함수 있음
private string getservertime()
{
HttpClientHandler handler1 = new HttpClientHandler();
handler1.AllowAutoRedirect = false;
HttpClient httpClient1 = new HttpClient(handler1);
httpClient1.DefaultRequestHeaders.Add("user-agent", UserAgent);
if (InternetGetConnectedState(0, 0) == false)
{
//
return "0";
}
try
{
var task = httpClient1.GetAsync("https://api.m.taobao.com/rest/api3.do?api=mtop.common.getTimestamp");
task.Wait();
if (task.Result.IsSuccessStatusCode)
task.Result.EnsureSuccessStatusCode();
else
{
return "0";
}
HttpResponseMessage response = task.Result;
// txtStatusCode.Text = response.StatusCode + " " + response.ReasonPhrase + Environment.NewLine;
var result = response.Content.ReadAsStringAsync();
string responseBodyAsText = result.Result;
JObject sertime = JObject.Parse(responseBodyAsText);
handler1.Dispose();
httpClient1.Dispose();
return (sertime["data"]["t"].ToString());
}
catch (HttpRequestException hre)
{
hre.ToString();
}
handler1.Dispose();
httpClient1.Dispose();
return "0";
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
vue 단일 페이지에 여러 개의 echarts 도표가 있을 때의 공용 코드 쓰기html에서: 데이터 처리는 말할 필요가 없다.응, 직접 그림을 그려: 공통 섹션: 이 페이지를 떠날 때 파괴: 추가 정보: Vue + Echarts 차트 표시 및 동적 렌더링 준비 작업 echarts 의존 설치 n...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.