Heim >Backend-Entwicklung >PHP-Tutorial > jquery ajax交付中文出现乱码

jquery ajax交付中文出现乱码

WBOY
WBOYOriginal
2016-06-13 13:24:181010Durchsuche

jquery ajax提交中文出现乱码?
提交页面为submit.htm代码如下

HTML code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->


<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
<title>欢迎</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
...
            $.ajax({
              type:"POST",
              url: "xx/add_post.php",
              data:'aa='+escape($('#aa').val())+'&bb='+$('#bb').val(),
              success: function(html){ alert('添加成功!'); }
            });     
....



接收数据页为add_post.php
PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
<?php header("Content-Type:text/html;charset=utf-8"); 
                    date_default_timezone_set("PRC"); 

                    try{
                        $pdo=new PDO("mysql:host=localhost;dbname=acom", "root", "abcdefghi");
    }catch(PDOException $e){
                        echo $e->getMessage();
    }

    $stmt=$pdo->prepare("insert into acom_a(aa, bb) values(:aa, :bb)"); 
         $stmt->execute(array(":aa"=>$_POST["aa"], ":bb"=>$_POST["bb"]));
?>



aa字段存入中文为乱码,bb是英文正常!

------解决方案--------------------
单独执行 add_post.php 文件插入中文乱码吗?
------解决方案--------------------
encodeURI($('#bb').val()); 这样,把可能带中文的变量都encodeURI
------解决方案--------------------
探讨

引用:
忽然想起来了,你似乎还没有调试 ajax 的工具或能力
$pdo=new PDO("mysql:host=localhost;dbname=acom", "root", "abcdefghi",array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"));

朋友你的PDO设置解决了问题,谢谢!
同时问一下……

------解决方案--------------------
探讨

有没有在配置文件中一次改完,不再执行该语句的方法?

------解决方案--------------------
问题解决了就好!

在实例化 PDO 时附加的参数 array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8")
表示的意思是:连接mysql成果后,立即执行 set names utf8 指令,即将通讯用的字符集设为 utf-8

由于 mysql 数据库都是独立的,公共的。所以打不大可能就只按你需要的参数被安装
所以使用时声明一下字符集是很有必要的

mysql 对于 PDO 就属于个性化的东西了。对于声明字符集,他需要执行 sql 指令,要是 oralce 就是在 dsn 中声明了
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn