程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 使用wordpress的$wpdb類讀mysql數據庫做ajax時出現的問題及解決,wordpresswpdb

使用wordpress的$wpdb類讀mysql數據庫做ajax時出現的問題及解決,wordpresswpdb

編輯:關於PHP編程

使用wordpress的$wpdb類讀mysql數據庫做ajax時出現的問題及解決,wordpresswpdb


無聊做了個www.jiazhuangma.com,技術不過關寫不好後台,就想直接讀wordpress裡的數據。做ajax讀後台數據時在網上隨便搜了一段代碼使用wordpress $wpdb類讀mysql數據庫,就是這麼一隨便,搜到了別人的去頭去尾的code,開始了我的改錯之旅。

主要問題有:

1,non-object

2,json中漢字,/被轉碼

3,chrome可以正常訪問php文件,ie顯示http 404,ajax時頭部顯示404,但是響應正文正確,是我想要的json。

轉載請注明http://www.cumt.top/blog/?p=162

 

先貼上網上搜到的代碼:

<?php

global $wpdb;

$a = $wpdb->get_results(“SELECT ID,post_title FROM wp_posts ″);
echo json_encode($a );
?>

  

這時會報錯,non-object;

網上有人說可以添加require_once(‘wp-blog-header.php’);那麼恭喜你中獎了,你會發現chrome可以正常訪問php文件,ie顯示http 404,ajax時頭部顯示404,但是響應正文正確。

修改為require_once(‘wp-config.php’);後正常,

這時得到的json是轉碼後的需要將echo json_encode($a );

修改為echo str_replace(“\\/”, “/”, json_encode($a,JSON_UNESCAPED_UNICODE ));結果才正確

最終結果:

<?php

require_once(‘wp-config.php’);
global $wpdb;

$a = $wpdb->get_results(“SELECT wp_posts.ID,wp_posts.post_title,wp_posts.guid FROM wp_posts inner join wp_term_relationships on wp_term_relationships.object_id=wp_posts.ID where wp_term_relationships.term_taxonomy_id=3 ORDER BY wp_term_relationships.object_id DESC LIMIT 5″);
echo str_replace(“\\/”, “/”, json_encode($a,JSON_UNESCAPED_UNICODE ));
?>

  轉載請注明http://www.cumt.top/blog/?p=162

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved