繁体   English   中英

Datatables.net | 表 id=tbl_portfolio - 无效的 JSON 响应

[英]Datatables.net | table id=tbl_portfolio - Invalid JSON response

这是我在 stackoverflow.com 上的第一个问题:我过去在这里找到了很多答案,但现在我遇到了一个无法解决的问题:我有一个项目,我使用 DataTables jquery 插件来显示来自一个简单的 SQL 数据库。 一切正常,但数据库已经有大约 18K 条目,所以速度很慢。 我试图让 ajax 和服务器端处理工作,但我总是收到错误:“数据表警告:表 id=tbl_portfolio - 无效的 JSON 响应。有关此错误的更多信息,请参阅http://datatables.net/吨/1 "

我检查了链接,但没有得到任何回应,所以我无法那样调试。 我阅读了很多并尝试了各种方法,但没有任何效果。

也许值得说的是 DataTables 在 Wordpress 子主题中运行。

HTML是:

<table id="tbl_portfolio" class="display nowrap" style="width:100%">
<thead>
    <tr>
        <th>URL</th>
        <th>Themen</th>
        <th>Keywords</th>
        <th>Land</th>
        <th>Kennzeichnung</th>
        <th>Linkart</th>
        <th>Ek Preis</th>
        <th>Text inkl.</th>
        <th>Text Preis</th>
        <th>End Preis</th>
        <th>Anmerkungen</th>
        <th>Firma</th>
        <th>Anrede</th>
        <th>Vorname</th>
        <th>Nachname</th>
        <th>Strasse</th>
        <th>Adresszusatz</th>
        <th>PLZ</th>
        <th>Ort</th>
        <th>Land</th>
        <th>eMail</th>
        <th>Telefon</th>
    </tr>
</thead>
<tfoot>
    <tr>
        <th>URL</th>
        <th>Themen</th>
        <th>Keywords</th>
        <th>Land</th>
        <th>Kennzeichnung</th>
        <th>Linkart</th>
        <th>Ek Preis</th>
        <th>Text inkl.</th>
        <th>Text Preis</th>
        <th>End Preis</th>
        <th>Anmerkungen</th>
        <th>Firma</th>
        <th>Anrede</th>
        <th>Vorname</th>
        <th>Nachname</th>
        <th>Strasse</th>
        <th>Adresszusatz</th>
        <th>PLZ</th>
        <th>Ort</th>
        <th>Land</th>
        <th>eMail</th>
        <th>Telefon</th>
    </tr>
</tfoot>

这是 javascript 部分:

// DB table to use
$table = 'portfolio_test';

// Table's primary key
$primaryKey = 'id';

// Array of database columns which should be read and sent back to DataTables.
// The `db` parameter represents the column name in the database, while the `dt`
// parameter represents the DataTables column identifier. In this case simple
// indexes
$columns = array(
array( 'db' => 'url', 'dt' => 0 ),
array( 'db' => 'themen', 'dt' => 1 ),
array( 'db' => 'keywords', 'dt' => 2 ),
array( 'db' => 'location', 'dt' => 3 ),
array( 'db' => 'kennzeichnung', 'dt' => 4 ),
array( 'db' => 'link_art', 'dt' => 5 ),
array( 'db' => 'preis_platz', 'dt' => 6 ),
array( 'db' => 'text_inkl', 'dt' => 7 ),
array( 'db' => 'preis_text', 'dt' => 8 ),
array( 'db' => 'preis_ek', 'dt' => 9 ),
array( 'db' => 'details', 'dt' => 10 ),
array( 'db' => 'firma', 'dt' => 11 ),
array( 'db' => 'anrede', 'dt' => 12 ),
array( 'db' => 'vorname', 'dt' => 13 ),
array( 'db' => 'nachname', 'dt' => 14 ),
array( 'db' => 'strasse', 'dt' => 15 ),
array( 'db' => 'adresszusatz', 'dt' => 16 ),
array( 'db' => 'plz', 'dt' => 17 ),
array( 'db' => 'ort', 'dt' => 18 ),
array( 'db' => 'land', 'dt' => 19 ),
array( 'db' => 'email', 'dt' => 20 ),
array( 'db' => 'telefon', 'dt' => 21 )
);

// SQL server connection information
$sql_details = array(
'user' => 'db_adm',
'pass' => '',
'db'   => 'seo_metrics',
'host' => 'localhost:3306'
);

require 'ssp.class.php';

echo json_encode(
SSP::simple( $_GET, $sql_details, $table, $primaryKey, $columns ) 
);

我正在使用来自https://github.com/DataTables/DataTablesSrc/blob/master/examples/server_side/scripts/ssp.class.php的标准 ssp.class.php 文件

也许我在测试所有不同的东西时产生了一些新的错误,但我希望你们中的一些人能找到问题!

谢谢你们!

图片来自开发者控制台网络:空白响应:

我今天遇到了同样的问题。 这对我有用。 ssp.class.php 中,替换

$db = @new PDO(
            "mysql:host={$sql_details['host']};dbname={$sql_details['db']}",
            $sql_details['user'],
            $sql_details['pass'],
            array( PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION)
        );

$db = @new PDO(
            "mysql:host={$sql_details['host']};dbname={$sql_details['db']}",
            $sql_details['user'],
            $sql_details['pass'],
            array( PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8' )
        );

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM