1

我有一个 php 代码,它从 URL 参数中捕获一个变量,并通过一个 html edditbale 文本字段将其传递给 Jquery/Ajax,然后再传递给一个将其传递给我的 Firebird DB 的外部 php 代码。问题是 jquery/ajax 正在将 ä 之类的字符更改为 ä 等等。

首先,我认为我必须使用 ISO8859_1(该表正在使用)位对 firebird SQl 更新进行编码,然后我发现它正在更改字符的 Jquery。

这是我的代码:

?>
    <div id="wrap">
        <h3>Comment</h3>
        <div id="status"></div>
        <div id="content">
        <div id="editable" contentEditable="true">
<?php
        echo $row[21];
        ?>
</div>  
        <button id="save">Save</button>
        </div>  
    </div>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js" type="text/javascript"></script>
  <script>
    $(document).ready(function() {  
        $("#save").click(function (e) {         
            var content = $('#editable').html()
            var nr = <?php echo $s; ?>; 
            $.ajax({
                url: 'save.php',
                type: 'POST',
                data: {
                content: content,
                nr: nr
                },      
                success:function (data) {               
                    if (data == '1')
                    {
                        $("#status")
                        .addClass("success")
                        .html("Data saved successfully")
                        .fadeIn('fast')
                        .delay(3000)
                        .fadeOut('slow');   
                    }
                    else
                    {
                        $("#status")
                        .addClass("error")
                        .html("An error occured, the data could not be saved")
                        .fadeIn('fast')
                        .delay(3000)
                        .fadeOut('slow');   
                    }
                }
            });     
        });     
        $("#editable").click(function (e) {
            $("#save").show();
            e.stopPropagation();
        });
        $(document).click(function() {
            $("#save").hide();  
        });
    });
</script>
4

5 回答 5

1

我在将值发送到数据库之前通过简单地使用 php 翻译解决了这个问题:

$content2 = utf8_decode($content);

于 2012-10-15T22:51:55.983 回答
0

阅读jQuery.ajax 文档

默认 [content-type] 是“application/x-www-form-urlencoded; charset=UTF-8”

换句话说,您发布到您的 PHP 页面的是一个UTF-8 编码的字符串。如果您想要其他任何东西(如 ISO-8859-1),则需要对其进行转换。

于 2012-10-14T17:35:00.103 回答
0

试试看

$.ajax({
        data: parameters,
        type: "POST",
        url: ajax_url,
        timeout: 20000,
        contentType: "application/x-www-form-urlencoded;charset=ISO-8859-15",
        dataType: 'json',
        success: callback
});

您还必须在服务器上指定字符集。

<?php header('Content-Type: text/html; charset=ISO-8859-15'); ?>

发表评论后再次更新答案

请参阅下面的 URL,我认为这对您非常重要。

如何将 javascript 字符串转码为 iso-8859-1

如何将 Javascript 字符串转码为 ISO-8859-1?

于 2012-10-14T18:00:14.863 回答
0

正如 Joachim Isaksson 所说,您不能以 UTF-8 以外的其他字符集提交数据。

我通常在我的前端控制器中使用这个函数来转换所有$_POST数组。

<?php
public function direct($POST)
{
          if (!empty($_POST)) {

            $flag_unicoded = false;

            if (strpos(strtolower($_SERVER['CONTENT_TYPE']), 'charset=utf-8') !== false) $flag_unicoded = true;
            if (isset($_SERVER['HTTP_X_REQUESTED_WITH']) && $_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest' && strpos(strtolower($_SERVER['CONTENT_TYPE']), 'charset') === false) $flag_unicoded = true;

            if ($flag_unicoded) {
              function utf8_decode_recursive($input) {
                $return = array();
                foreach ($input as $key => $val) {
                  if (is_array($val)) $return[$key] = utf8_decode_recursive($val);
                  else $return[$key] = utf8_decode($val);
                }
                return $return;          
              }
              $_POST = utf8_decode_recursive($_POST);
            }
            return $_POST;
          }
}
?>

编辑

未经测试,但你可以试试这个:

jQuery.ajaxSetup({'beforeSend' : function(xhr) {xhr.overrideMimeType('charset=ISO-8859-1'); }});
于 2012-10-15T06:44:29.157 回答
0

我希望这不会显示为重复的答案。我在一个jsp应用程序中遇到了这个问题。该页面位于 iso-8859-1 中,但使用 jquery.serialize(),从 IE 发布时数据会损坏。我在上面看到了 Abid Hussain 的建议,但将其更改为

contentType: "application/x-www-form-urlencoded;charset=UTF-8",

例如。告诉服务器它是 UTF-8,而不是 iso-8859-1 这解决了我的问题。

 $("#caleditform").submit(function(){
 $.ajax(
 {
 url:$("#caleditform").attr('action'),
 type: "POST",
 contentType: "application/x-www-form-urlencoded;charset=UTF-8",
 data: $('#caleditform').serialize(),
 success:function(html){
   $('#projectdialog').html(html);
 }
 }
 );
 return false;

});

谢谢

于 2013-10-23T13:03:24.627 回答