2

我现在正在使用 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;
        }
4

1 回答 1

0

已解决:我很抱歉,感谢所有回复,但我发现了问题。我有一个旧版本作为服务一直在运行,并进行了第二次 JSON 调用。

我通过在服务器端记录调用和阻塞代码找到了它,这些调用和阻塞代码在我自己的代码中调用 JSON 来解决这个问题。

于 2012-10-31T08:24:08.090 回答