2014-10-29 201 views
0

我使用json_encode函数在一个相当简单的报价系统,我有:JSON编码 - 特殊字符

<script type='text/javascript'> 
postQuote[<?php echo json_encode($post['post_id']); ?>] = <?php echo json_encode($post['post_text']); ?> 
</script> 

它输出这样的:

postQuote["11241"] = "&amp;Kappa;&amp;alpha;&amp;lambda;&amp;eta;&amp;sigma;&amp;pi;\u03ad&amp;rho;&amp;alpha; &amp;alpha;&amp;lambda;\u03ac&amp;nu;&amp;iota;&amp;alpha; &amp;mu;&amp;omicron;&amp;upsilon;. \u0388&amp;chi;&amp;omega; &amp;kappa;\u03ac&amp;pi;&amp;omicron;&amp;iota;&amp;epsilon;&amp;sigmaf; &amp;alpha;&amp;pi;&amp;omicron;&amp;rho;\u03af&amp;epsilon;&amp;sigmaf;. \r\n1&amp;omicron;&amp;nu;: &amp;Eta; &amp;pi;&amp;rho;\u03ac&amp;sigma;&amp;iota;&amp;nu;&amp;epsilon;&amp;sigmaf; &amp;delta;&amp;iota;&amp;alpha;&amp;phi;&amp;eta;&amp;mu;\u03af&amp;sigma;&amp;epsilon;&amp;iota;&amp;sigmaf; &amp;mu;&amp;omicron;&amp;upsilon; &amp;delta;\u03af&amp;nu;&amp;omicron;&amp;upsilon;&amp;nu; $0.01; &amp;Alpha;&amp;nu; &amp;nu;&amp;alpha;&amp;iota; &amp;tau;\u03cc&amp;tau;&amp;epsilon; &amp;mu;\u03ac&amp;lambda;&amp;lambda;&amp;omicron;&amp;nu; \u03ad&amp;chi;&amp;omega; &amp;pi;&amp;rho;\u03cc&amp;beta;&amp;lambda;&amp;eta;&amp;mu;&amp;alpha; &amp;gamma;&amp;iota;&amp;alpha;&amp;tau;\u03af &amp;epsilon;\u03af&amp;chi;&amp;alpha; $0.60 &amp;pi;\u03ac&amp;tau;&amp;eta;&amp;sigma;&amp;alpha; &amp;kappa;&amp;alpha;&amp;iota; &amp;tau;&amp;eta;&amp;sigmaf; 4 &amp;pi;&amp;rho;\u03ac&amp;sigma;&amp;iota;&amp;nu;&amp;epsilon;&amp;sigmaf; &amp;kappa;&amp;alpha;&amp;iota; &amp;pi;\u03ae&amp;gamma;&amp;alpha; &amp;mu;\u03cc&amp;nu;&amp;omicron; $0.062.\r\n2&amp;omicron;&amp;nu;: \u03ad&amp;chi;&amp;omega; 5 rented ref. &amp;Tau;\u03ce&amp;rho;&amp;alpha; &amp;mu;&amp;pi;&amp;omicron;&amp;rho;\u03ce &amp;nu;&amp;alpha; &amp;alpha;&amp;gamma;&amp;omicron;&amp;rho;\u03ac&amp;sigma;&amp;omega; \u03ac&amp;lambda;&amp;lambda;&amp;omicron;&amp;upsilon;&amp;sigmaf; 3 &amp;mu;&amp;epsilon; $0.6 &amp;lambda;\u03ad&amp;tau;&amp;epsilon; &amp;nu;&amp;alpha; &amp;tau;&amp;omicron;&amp;upsilon;&amp;sigmaf; &amp;alpha;&amp;gamma;&amp;omicron;&amp;rho;\u03ac&amp;sigma;&amp;omega; &amp;eta; &amp;nu;&amp;alpha; &amp;pi;\u03ac&amp;omega; $1 &amp;kappa;&amp;alpha;&amp;iota; &amp;nu;&amp;alpha; &amp;pi;\u03ac&amp;rho;&amp;omega; \u03ac&amp;lambda;&amp;lambda;&amp;omicron;&amp;upsilon;&amp;sigmaf; 5;\r\n\r\n&amp;Alpha;&amp;upsilon;&amp;tau;\u03ac &amp;pi;&amp;rho;&amp;omicron;&amp;sigmaf; &amp;tau;&amp;omicron; &amp;pi;&amp;alpha;&amp;rho;\u03cc&amp;nu;."  

以上文字是(希腊):

Καλησπέρα αλάνια μου. Έχω κάποιες απορίες. 
1ον: Η πράσινες διαφημίσεις μου δίνουν $0.01; Αν ναι τότε μάλλον έχω πρόβλημα γιατί είχα $0.60 πάτησα και της 4 πράσινες και πήγα μόνο $0.062. 
2ον: έχω 5 rented ref. Τώρα μπορώ να αγοράσω άλλους 3 με $0.6 λέτε να τους αγοράσω η να πάω $1 και να πάρω άλλους 5; 

Αυτά προς το παρόν. 

现在,据我了解,它将字符串编码为HTML字符,因此在输出之前,我这样做:

$(".quote").click(function() { 
    $("#text").val($("<div>").html("[quote]" + postQuote[$(this).attr('name')] + "[/quote]").text()); 
}); 

这没有帮助。输出仍然与上面相同。

我在做什么错?

编辑:

$s = $dbh->prepare(" 
    SELECT t.*, c.forum_name, 
    (SELECT count(*) FROM forum_posts WHERE topic_id=t.topic_id AND post_deleted=0) as posts 
    FROM forum_topics t 
    JOIN forum_cats c on c.forum_id = t.forum_id 
    WHERE t.topic_id=:id 
    "); 
$s->bindParam(':id', $id); 
$s->execute(); 
$q = $s->fetch(PDO::FETCH_ASSOC); 

    while ($post = $p->fetch(PDO::FETCH_ASSOC)) { 

//Postquote inside here. 
}    

我的表forum_postsutf8_general_ci

2日编辑:

好像用希腊字母的问题吗?有什么建议么?

+0

'json_encode()'工作在utf8字符串上,所以你的输出看起来不太可能。你如何填写'$ post'变量,你可以做一个'var_dump($ post);'? – jeroen 2014-10-29 14:47:54

+0

@ jeroen请看我更新的问题。我已经包含了PHP。 – oliverbj 2014-10-29 14:51:54

+0

您需要缩小问题的位置。看起来你在某处使用'htmlentities()'。 – jeroen 2014-10-29 15:07:06

回答

0

您应该使用htmlspecialchars()。这与适当的选项将使您的字符串是有效的HTML。 json_encode是从PHP值获取json字符串。你正在使用这个字符串,所以实际上你不想拥有json。特别是我不明白你为什么用post_id。