现在我有了一个数据库。数据库采用全能的utf-8整理进行编码。实际上整理是utf8,我不确定编码是什么。那应该是另一个问题。
然后我制作了一个从数据库中检索数据的程序。
<?php
require_once('convertArraytoJson.php');
require_once('config.php');
mysql_connect ( "localhost", $databaseuser, $databasepassword);
mysql_query("SET character_set_results = 'utf8', character_set_client = 'utf8', character_set_connection = 'utf8', character_set_database = 'utf8', character_set_server = 'utf8'");
@mysql_select_db ($databasename) or die ( "Unable to select database" );
$data=$_GET['id'];
$query="SELECT * FROM `tabletes` where id = '".$data."'";
$data = mysql_query($query);
while (true){
$info = mysql_fetch_array ( $data, MYSQL_ASSOC );
if ($info == false) {
break;
}
//$output[]=$info;
$output[$info['ID']]=$info;
unset ($output[$info['ID']]['ID']);
}
$result = array2json($output);
echo $result;
?>
数据库的内容如下所示:
现在我通过执行此操作调用该函数(您需要放大屏幕才能看到它):
http://localhost/domainname/api/test2.php?id=jr-東北本線-荒川橋梁__35.79_139.72
它不起作用。
但是,如果我不使用$ _GET,只需直接在其工作的代码中输入日文字符。
所以,如果我改变:
$data = $_GET['id']
到
$data = 'jr-東北本線-荒川橋梁__35.79_139.72'
事情进展顺利。
当然,我不想硬编ID,我想通过$ _GET ['id']访问它。我该怎么办?
答案 0 :(得分:2)
只需使用urlencode()
- 您的字符串就像:
%E6%9D%B1%E5%8C%97%E6%9C%AC%E7%B7%9A-%E8%8D%92%E5%B7%9D%E6%A9%8B%E6%A2%81
。
不允许使用这些中文字符。
检查rfc1738:Uniform Resource Locators (URL)
答案 1 :(得分:2)