0

我正在构建一个C#应用程序,该应用程序需要调用网页 (in PHP) 以请求对数据库中的数据执行验证。数据PHP通过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

4 回答 4

2

您的返回实际上是公正的,并且回显或打印掉 - 只需显示您想要返回到您的 c# 脚本的值。

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

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

于 2013-09-23T14:36:31.447 回答
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';
        }
    }
于 2013-09-23T14:35:48.320 回答
0

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

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

  1. 您可以将页面响应加载到 DOM 解析器(例如HtmlAgilityPack,尽管还有其他解析器)并解析出您想要的值。
  2. 您可以让 PHP 代码以某种结构化形式仅发出您想要的值。虽然您仍然只能从中得到一个字符串,但如果它遵循该对象的结构,您可以更轻松地将其反序列化为一个对象。或者,如果值非常简单(数字、布尔值等),那么您可以将结果解析为该类型。
于 2013-09-23T14:37:04.827 回答
0

由于您返回了完整的 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 字符串中可用。

于 2013-09-23T15:18:06.343 回答