我现在正在使用 JSON 一段时间,但这是我无法解决的问题。
该程序是用 C# 编写的,并有一个名为 CreateWebRequest() 的方法:
public void CreateWebRequest()
{
CurrentTime = DateTime.Now;
target = link;
request = WebRequest.Create(target) as HttpWebRequest;
request.ContentType = "application/json; charset=utf-8";
request.Method = "PUT";
request.ServicePoint.Expect100Continue = false;
string postData = jsonString;
System.Console.WriteLine("POSTDATA: " + postData);
StreamWriter requestWriter;
using (requestWriter = new StreamWriter(request.GetRequestStream()))
{
requestWriter.Write(postData);
}
}
另一个获取结果的函数被调用:CreateWebResponse():
public void CreateWebResponse()
{
WebResponse response;
string text;
try
{
response = (HttpWebResponse)request.GetResponse();
}
catch (WebException e)
{
MessageBox.Show(e.Message);
return;
}
using (var sr = new StreamReader(response.GetResponseStream()))
{
text = sr.ReadToEnd();
}
APIresult apiresult = JsonConvert.DeserializeObject<APIresult>(text); //Deserialize the text
}
这些功能都可以正常工作,只有一个问题:代码执行了两个请求。
当我在 mozilla FireFox 的 RESTClient 中放入相同的 JSON 时,JSON 工作正常。当我只使用 CreateWebRequest() 时它也很有效,但是当我同时使用这两种方法时,代码似乎创建了第二个请求?
是否可以只创建一个响应?将这两个功能组合成一个直接产生响应的功能?
我尝试了其他解决方案并将它们放在一起,它们似乎都不起作用。当我要求响应时,代码不再正常工作并创建两个请求。
有没有人有解决方案?
提前致谢。
我调用的 JSON 函数有几个 if 语句,并且根据 Firefox 中的 RESTClient 可以正常工作。下面的代码显示了被 RESTClient 调用的代码是正确的,并且被 C# 代码调用了两次:
$sql = 'SELECT...';
$result = $db->sql_query($sql);//search for member id.
if($row = $db->sql_fetchrow($result)){//when found, the user has access.
$member_id = $row['member_id'];
$sql = 'SELECT ...';
$result = $db->sql_query($sql);//search for last login today.
if($row = $db->sql_fetchrow($result)){//if the user has logged in today update the row.
$row_check_in_timestamp = $row['check_in_timestamp'];
$sql = 'UPDATE ...';//update the row with the check out timestamp
$db->sql_query($sql);
break;
}else{//the user hasn't logged in yet today, log in.
$start_session_array = array(
'club_id' => (int)$club_id,
'member_id' => (int)$member_id,
'check_in_timestamp' => (int)time(),
);
$sql = 'INSERT ...';//check user in and add a new row in the database
$db->sql_query($sql);
break;
}
}else{
break;
}