PHP數組傳遞給JavaScript以及json_encode的gbk中文亂碼
來源:程序員人生 發布時間:2013-10-26 21:23:25 閱讀次數:3263次
文章介紹了關于PHP數組傳遞給JavaScript以及json_encode的gbk中文亂碼的解決 ,下面是創建JSON函數,這一段來自網上某一位大俠
-
-
-
-
-
-
-
-
-
- function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
- {
- foreach ($array as $key => $value) {
- if (is_array($value)) {
- arrayRecursive($array[$key], $function, $apply_to_keys_also);
- } else {
- $array[$key] = $function($value);
- }
- if ($apply_to_keys_also && is_string($key)) {
- $new_key = $function($key);
- if ($new_key != $key) {
- $array[$new_key] = $array[$key];
- unset($array[$key]);
- }
- }
- }
- }
-
-
-
-
-
-
-
-
- function JSON($array) {
- arrayRecursive($array, 'urlencode', true);
- $json = json_encode($array);
- return urldecode($json);
- }
- 連接數據庫取值給數組$array1
- 代碼如下 復制代碼
- $dbcnx = @mysql_connect ( "localhost", "root", "1234" );
- if (! $dbcnx) {
- echo ("Unable to connect to the " . "database server at this time.");
- exit ();
- }
- if (! @mysql_select_db ( "pms" )) {
- echo ("Unable to locate the joke " . "database at this time.");
- exit ();
- }
- mysql_query ( "SET NAMES 'GB2312'" );
- $q=mysql_query("select * from ability where ALV = 1");
- while($row=mysql_fetch_array($q)){
- $array1[] = $row[AName];
- }
數組array1傳遞到JavaScript給數組ability1
- <script type="text/javascript" src="JS/jquery-1.7.2.min.js"></script>
- <script type="text/javascript">
- var ability1=<?php echo JSON($array1);?>;
- var a=eval("ability1");
- alert(a[0]);
- </script>
另一種json中文亂碼解決方法,如果是中文的話就要注意了,在網上找到一種解決方法:
- <?php
-
- $data = array ('game' => '冰火國度', 'name' => '刺之靈', 'country' => '冰霜國', 'level' => 45 );
- echo json_encode ( $data );
- echo "<br>";
- $newData = array ();
- foreach ( $data as $key => $value ) {
- $newData [$key] = urlencode ( $value );
- }
- echo urldecode ( json_encode ( $newData ) );
- ?>
后來請教了別人,還可以用base64編碼,不過base64編碼不可以放在URL中,百度是這樣解釋的:標準的Base64并不適合直接放在URL里傳輸,因為URL編碼器會把標準Base64中的“/”和“+”字符變為形如“%XX”的形式,而這些“%”號在存入數據庫時還需要再進行轉換,因為ANSI SQL中已將“%”號用作通配符。
不過我的數據是要通過POST發送的,并不在HTTP 的head中,而在message-body里,所以不受影響。
json_encode 只能接受utf-8格式的數據
例如:'胥'經過json_encode處理后變為'u80e5',最終的json中中文部分被替換為unicode編碼。我們要解決的就是將對象轉換為json并保證對象內部的中文在json中仍然是以正常的中文出現,現在看來只使用json_encode是不能達到目的的.
我的解決方法:先將類中的中文字段進行url編碼(urlencode),然后再對對象進行json編碼(jsonencode),最后url解碼(urldecode)json,即最終的json,里面的中文依舊是那個中文! 測試代碼如下:
- <?php
- class myClass {
- public $item1 = 1;
- public $item2 = '中文';
- function to_json() {
-
- $this->item2 = urlencode($this->item2);
- $str_json = json_encode($this);
-
- $this->item2 = urldecode($this->item2);
- return urldecode($str_json);
- }
- }
- $c = new myClass();
- echo json_encode($c);
- echo '<br/>';
- echo $c->to_json();
- echo '<br/>';
- echo json_encode($c);
- echo '<br/>';
- echo json_encode('胥');
- ?>
程序輸出結果:
- {"item1":1,"item2":"u4e2du6587"}
- {"item1":1,"item2":"中文"}
- {"item1":1,"item2":"u4e2du6587"}
- "u80e5"
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈