PHP页面显示乱码处理(数据库、html页面、服务器php页面编码)

MySQL数据库编码、html页面编码、PHP或html文件本身编码要全部一致。

1、MySQL数据库编码:建立数据库时指定编码(如gbk_chinese_ci),建立数据表、建立字段、插入数据时不要指定编码,会自动继承数据库的编码。
数据库连接时,也有编码,可以在连接完数据库后,执行

mysql_query('SET NAMES gbk');

完整连接数据库,并插入一条记录的示例:

<?php

  // 1.连接数据库
  $conn = mysql_connect('127.0.0.1:3306', 'root', '518666');
  if (!$conn)
  {
    die("Could not connect:" . mysql_error());
  }

  // 2.选择数据库
  mysql_select_db('mytest', $conn);


  // 3.设置编码,注意这里是utf8而不是utf-8,如果写后者,MySQL不会识别的,会出现乱码的。
  mysql_query("SET NAMES utf8");

  $title = "我们的爱情";
  $content = '你是谁啊,大几都做做没';
  $add_time = date("Y-m-d H:i:s");

  // 转义字符
  // $pwd = mysql_real_escape_string($pwd);

  // 4.插入一条数据
  $insert_sql = "insert into post_tbl (title, content, user_id, add_time) values ('{$title}', '{$content}', '4742551', '{$add_time}')";

  if(mysql_query($insert_sql))
  {
    echo 'ok';

  }
  else
  {
    echo "Error : " . mysql_error();
  }

 $ret = mysql_affected_rows();
  print_r($ret);
/*
// 5.查询一条数据
  $insert_sql = "select * from posts limit 1";

  $result = mysql_query($insert_sql);

  while($row = mysql_fetch_array($result))
  {
     print_r($row);
  }
*/

  // 关闭数据库连接
  mysql_close($conn);

注意:1.这个示例的数据库,表,php文件都是utf8编码。
注意:2.这里是utf8而不是utf-8,如果写后者,MySQL不会识别的,还会出现乱码的。

2、html页面的编码,指的是这一行的设置:

<meta http-equiv="Content-Type" content="text/html; charset=gbk" />

3、PHP或html文件本身的编码:用editplus打开php文件或html文件,另存时,选择的编码,如果数据库和页面编码是gbk,则这儿的编码选择ansi;如果数据库和页面编码是utf-8,则这儿也选择utf-8。

4、另外要注意的是,Javascript或Flash中传递的数据是utf-8编码,如果数据库和页面编码是gbk,要进行转码,然后写入数据库。
将”你好”从GBK转换到UTF-8格式

iconv("gbk","utf-8","你好");

5、在PHP程序中,可以加上一行,来指定PHP源程序的编码:

header('Content-type: text/html; charset=gbk');
    原文作者:Corwien
    原文地址: https://segmentfault.com/a/1190000005896758
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞