我正在构建一个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。
我想知道的是我如何能够将这些回复作为一个或多个回复(无论可能的是什么):
答案 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调用)。您可以通过以下几种方式解决此问题:
答案 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字符串中提供。