我的数据库中用于谷歌地理编码的地址的特殊字符存在问题,但如果我对它们进行硬编码,则不会。
简单的地理编码
$url = "http://maps.googleapis.com/maps/api/geocode/json?address=". $address . "&sensor=true";
$jsonfile = file_get_contents($url);
$jsondata = json_decode($jsonfile);
$lat = $jsondata->results[0]->geometry->location->lat;
$lng = $jsondata->results[0]->geometry->location->lng;
此代码适用于标准地址,但如果地址中包含特殊字符(如果它来自我的数据库)则不起作用。
如果我将地址硬编码为:
$address = "10 Montée de Clausen, 1343 Luxemburg City, Luxembourg";
$address = str_replace(" ","+",$address);
该代码有效。如果地址来自我的数据库
$query="SELECT * FROM mytable";
$result=mysqli_query($GLOBALS["___mysqli_ston"], $query);
while($row=mysqli_fetch_assoc($result)){
$address = $row['address'];
$address = str_replace(" ","+",$address);
// geocode code.
}
它不起作用。
数据库位于 utf8_unicode_ci 中。如果我回显包含地址的 $url,即使它来自我的数据库,然后将该 url 放入浏览器,该 url 实际上会吐出正确的数据,但在我的代码中使用该 url 不起作用。
我试图在 str_replace 之前和 str_replace 之后对地址进行 url 编码,但它仍然不起作用。
我如何让它工作?