如何通过调用PHP网页获取值?

时间:2013-09-23 14:28:39

标签: c# php httpwebrequest httpwebresponse

我正在构建一个C#应用程序,需要调用一个网页(在PHP中)来请求对数据库中的数据执行验证。数据通过PHP中的HTTP参数提供给URL页面。

我想从调用我的PHP网页中检索一个响应值。在此特定示例中,我只需要Boolean值。但是,我学习如何请求任何东西,甚至是一个请求中的多个值(如果可能的话),这似乎是谨慎的。

这是我正在调用的PHP页面的简化版本:

<?php
    $type = $_GET['type'];
    $accessid = $_GET['accessid'];
    $license = $_GET['license'];
    $machine = $_GET['machine'];
    $osver = $_GET['osver'];
    $ip = getenv("REMOTE_ADDR");

    $query = "select * from validatetable where licnum = '" . $license . "'";
    if ($result = db_doquery($query))
    {
        if (db_dofetcharray($result))
        {
            $query = "update validatetable set lastdate = CURRENT_TIMESTAMP, lastmachine = '" . $machine . "', accessip = '" .  $ip . "', osver = '" . $osver . "' where type = '" . $type . "' and licnum = '" . $license . "'";
            db_doquery($query);
        }
        else
        {
            $query = "insert into validatetable set type = '" . $type . "', name = '<unknown>', licnum = '" . $license . "', accessid = '" . $accessid . "', lastdate = CURRENT_TIMESTAMP, machine = '" . $machine . "', accessip = '" .  $ip . "', osver = '" . $osver . "'";
            db_doquery($query);
        }
    }
?>

PHP页面只是接收值并在数据库表中插入或更新记录。这将继续,但还有另一个表,我想从中提取信息,与提供的信息进行比较,并将验证指标返回为Boolean

这是我在C#应用程序中的当前请求代码:

String webUrl = String.Format("http://www.mywebsite.com/validate.php?type=type&accessid={0}&license={1}&machine={2}&osver={3}.{4}", accessID, licNum, clientMachineName, Environment.OSVersion.Version.Major, Environment.OSVersion.Version.Minor);
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(webUrl);
request.Credentials = CredentialCache.DefaultCredentials;
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
if (response.StatusCode == HttpStatusCode.OK)
{
    using (Stream dataStream = response.GetResponseStream())
    {
        using (StreamReader reader = new StreamReader(dataStream, Encoding.UTF8))
        {
            String theResponse = reader.ReadToEnd();  //<--- THIS LINE
        }
    }
}
response.Close();

注意到的行导致变量包含要返回的页面的完整HTML。

我想知道的是我如何能够将这些回复作为一个或多个回复(无论可能的是什么):

  1. 单个值
  2. 值集合
  3. 我可以可靠地提取值的东西

4 个答案:

答案 0 :(得分:2)

您的返回真的只是回显或打印 - 只需显示您想要返回到c#脚本的值。

<?php
if( // true ) {
echo 'TRUE';
} else { 
echo 'FALSE';
}

当然你要返回一个字符串,而不是一个布尔值。但是你可以创建一个数组或一个对象,并使用json_encode()将值传递给c#。

答案 1 :(得分:0)

函数db_doquery中的代码是什么?

您是否尝试使用if语句查看查询是否已成功运行?

    if (db_dofetcharray($result))
    {
        $query = "update validatetable set lastdate = CURRENT_TIMESTAMP, lastmachine = '" . $machine . "', accessip = '" .  $ip . "', osver = '" . $osver . "' where type = '" . $type . "' and licnum = '" . $license . "'";

        if(db_doquery($query))
        {
            echo '1';
        }
        else
        {
            echo '0';
        }
    }
    else
    {
        $query = "insert into validatetable set type = '" . $type . "', name = '<unknown>', licnum = '" . $license . "', accessid = '" . $accessid . "', lastdate = CURRENT_TIMESTAMP, machine = '" . $machine . "', accessip = '" .  $ip . "', osver = '" . $osver . "'";

        if(db_doquery($query))
        {
            echo '1';
        }
        else
        {
            echo '0';
        }
    }

答案 2 :(得分:0)

  

注意到的行导致变量包含要返回的页面的完整HTML。

嗯,那是因为PHP页面发出的是一个网页,而不是一个特定的值(作为API调用)。您可以通过以下几种方式解决此问题:

  1. 您可以将页面响应加载到DOM解析器中(例如,HtmlAgilityPack,但还有其他解析器)并解析出您想要的值。
  2. 您可以让PHP代码仅以某种结构化形式发出您想要的值。虽然你仍然只能从中获取一个字符串,但如果它遵循该对象的结构,则可以更容易地将其反序列化为对象。或者,如果值真的简单(数字,布尔值等),那么您可以将结果解析为该类型。

答案 3 :(得分:0)

由于你要返回FULL html对象,你可以随时做我做的事情,在某些标签中设置参数(我称之为'数据',你可以随意调用它们!) 你可以用PHP做什么:

send('this string should be returned with data tags');
function send(dat) {
  echo '<data>'. $dat .'</data>'
}

然后在C#中删除标签:

public string removeDataTags(string fullhtml) {
  string rmt = fullhtml.Substring(fullhtml.IndexOf("<data>") + ("<data>").Length);
  rmt = rmt.Substring(0, rmt.IndexOf("</data>"));
  return rmt;
}

现在你所要做的就是:

theResponse = removeDataTags(theResponse);

发送的数据将在theResponse字符串中提供。