-3
不断收到以下代码的$结尾错误。我通过使用键盘清除了一些错误,但现在我卡住了。我知道这与冒号和分号有关,但我似乎不知道问题出在哪里。 HELP
<?php
$dbName="";
$dbUsername="";
$dbPassword="";
$fromPC=$_POST['fromPC'];
$toPC=$_POST['toPC'];
//
function getDistance($lat1, $long1, $lat2, $long2, $unit)
{
if($unit=="miles"){
$earth = 3960; //miles
}else{
$earth = 6371; //kilometres
}
//From co-ordinates
$lat1 = deg2rad($lat1);
$long1= deg2rad($long1);
//To co-ordinates
$lat2 = deg2rad($lat2);
$long2= deg2rad($long2);
// The Haversine Formula
$dlong=$long2-$long1;
$dlat=$lat2-$lat1;
$sinlat=sin($dlat/2);
$sinlong=sin($dlong/2);
$a=($sinlat*$sinlat)+cos($lat1)*cos($lat2)*($sinlong*$sinlong);
$c=2*asin(min(1,sqrt($a)));
$d=round($earth*$c);
return $d;
}
if((!empty($fromPC)) && (!empty($toPC)))
{
mysql_connect("********",$dbUsername,$dbPassword);
@mysql_select_db($dbName) or die("Unable to select database");
// basic cleaning of input
$firstPC = strtoupper(preg_replace("/[^a-zA-Z0-9]/","",));
$secondPC = strtoupper(preg_replace("/[^a-zA-Z0-9]/","",));
// get first details
$query = 'SELECT `latitude`, `longitude` FROM `uk_postcodes` WHERE `postcode`="'.$firstPC.'";';
$result = mysql_query($query);
$first = mysql_fetch_row($result);
$checkFirst=mysql_num_rows($result);
// get second details
$query = 'SELECT `latitude`, `longitude` FROM `uk_postcodes` WHERE
`postcode`="'.$secondPC.'";';
$result = mysql_query($query);
$second = mysql_fetch_row($result);
$checkSecond=mysql_num_rows($result);
// ensure there were results to calculate with
if(($checkFirst<1) || ($checkSecond<1)){
$outputResults="Unrecognised postcode entered.";
}else{
$distance = getDistance($first[0], $first[1], $second[0], $second[1], "miles");
$outputResults = "The distance between postcode: $firstPC and postcode: $secondPC is ".$distance." miles.";
}
// always close your connections !!
mysql_close();
}
?>
<?=$outputResults?>
检查:http://cs.wellesley.edu/~cs111/review_materials/conditionals.html – hek2mgl 2013-03-27 16:19:07
无知道你的问题实际上是。这就是为什么你减少选票。尝试改写你的问题是什么,并可能在问题中粘贴你的实际错误 – Brad 2013-03-27 16:19:23
我马上注意到的是:a)你已经包含了一个;在你的SQL查询结束时,b)你使用的是旧的mysql驱动程序,而不是mysqli,你可以通过参数传递值,c)你已经在问题中包含了完整的访问证书到你的数据库中,d)这两个选择可以很容易地写成一个。 – Patrick 2013-03-27 16:30:32