切换导航
首页
技术问答
编程语言
前端开发
移动开发
开发工具
程序设计
行业应用
CMS系统
服务器
频道导航
▸ PHP
▸ Java
▸ Java SE
▸ Python
▸ C#
▸ C&C++
▸ Ruby
▸ VB
▸ asp.Net
▸ Go
▸ Perl
▸ netty
▸ Django
▸ Delphi
▸ Jsp
▸ .NET Core
▸ Spring
▸ Flask
▸ Springboot
▸ SpringMVC
▸ Lua
▸ Laravel
▸ Mybatis
▸ Asp
▸ Groovy
▸ ThinkPHP
▸ Yii
▸ swoole
▸ HTML
▸ HTML5
▸ JavaScript
▸ CSS
▸ jQuery
▸ Bootstrap
▸ Angularjs
▸ TypeScript
▸ Vue
▸ Dojo
▸ Json
▸ Electron
▸ Node.js
▸ extjs
▸ Express
▸ XML
▸ ES6
▸ Ajax
▸ Flash
▸ Unity
▸ React
▸ Flex
▸ Ant Design
▸ Web前端
▸ 微信小程序
▸ 微信公众号
▸ iOS
▸ Android
▸ Swift
▸ Hybrid
▸ Cocos2d-x
▸ Flutter
▸ Xcode
▸ Silverlight
▸ cocoa
▸ Cordova
前端之家
PHP
php和mysql中uft-8中文编码乱码的几种解决办法
php和mysql中uft-8中文编码乱码的几种解决办法
2018-12-30
PHP
前端之家
前端之家
收集整理的这篇文章主要介绍了
php和mysql中uft-8中文编码乱码的几种解决办法
,
前端之家
小编觉得挺不错的,现在分享给大家,也给大家做个参考。
PHP
页面
转UTF-8编码问题
1.在
代码
开始出加入一行:
<div class="codetitle">
@L_
404
_0@
代码
如下:
<div class="codebody" id="code50379">
header("Content-Type: text/html;charset=utf-8");
2.
PHP
文件
编码问题
点击编辑器的
菜单
:“
文件
”->“另存为”,可以看到当前
文件
的编码,确保
文件
编码为:UTF-8,
如果是ANSI,需要将编码改成:UTF-8。
3.
PHP
文件
头BOM问题:
PHP
文件
一定不可以有BOM
标签
否则,会出现session不能使用的情况,并有类似的
提示
:
Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent
这是因为,在执行session_start() 的时候,整个
页面
不能有
输出
,但是当由于前
PHP
页面
存在BOM
标签
,
PHP
把这个BOM
标签
当成是
输出
了,所以就出错了!
所以
PHP
页面
一定要
删除
BOM
标签
删除
这个BOM
标签
的
方法
:
1.可以用Dreamweaver打开
文件
,并重新保存,即可以
去除
BOM
标签
!
2.可以用EditPlus打开
文件
,并在
菜单
“首选项”->“
文件
”->"UTF-8标识",设置为:“总是
删除
签名”,
然后保存
文件
,即可以
去除
BOM
标签
!
4.
PHP
以附件形式保存
文件
的时候,UTF-8编码问题:
PHP
以附件形式保存
文件
,
文件
名必须是GB2312编码,
否则,如果
文件
名中有
中文
的话,将是
显示
乱码:
如果你的
PHP
本身是UTF-8编码格式的
文件
,
需要将
文件
名变量由UTF-8转成GB2312:
iconv("UTF-8","GB2312","$filename");
利用程序来实例字符
截取
方法
<div class="codetitle">
<a style="CURSOR: pointer" data="42093" class="copybut" id="copybut42093" onclick="doCopy('code42093')">
代码
如下:
<div class="codebody" id="code42093">
function utf8_substr($str,$len)
{
for($i=0;$i<$len;$i++)
{
$temp_str=substr($str,1);
if(ord($temp_str) > 127){
$i++;
if($i<$len){
$new_str[]=substr($str,3);
$str=substr($str,3);
}
}else {
$new_str[]=substr($str,1);
$str=substr($str,1);
}
}
return join($new_str);
}
MysqL
数据库
使用UTF-8编码的问题 1.用
PHP
myadmin创建
数据库
和数据表
创建
数据库
的时候,请将“整理”设置为:“utf8_general_ci”
或执行语句:
<div class="codetitle">
<a style="CURSOR: pointer" data="20067" class="copybut" id="copybut20067" onclick="doCopy('code20067')">
代码
如下:
<div class="codebody" id="code20067">
CREATE DATABASE
dbname
DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
创建数据表的时候:如果是该字段是存放
中文
的话,则需要将“整理”设置为:“utf8_general_ci”,
如果该字段是存放英文或数字的话,默认就可以了。
相应的
sql
语句,例如:
<div class="codetitle">
<a style="CURSOR: pointer" data="59588" class="copybut" id="copybut59588" onclick="doCopy('code59588')">
代码
如下:
<div class="codebody" id="code59588">
CREATE TABLE
test
(
id
INT NOT NULL,
name
VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
PRIMARY KEY (
id
)
) ENGINE = MYISAM ;
2.用
PHP
读写
数据库
在连接
数据库
之后:
<div class="codetitle">
<a style="CURSOR: pointer" data="41025" class="copybut" id="copybut41025" onclick="doCopy('code41025')">
代码
如下:<div class="codebody" id="code41025">
$connection =
MysqL
_connect($host_name,$host_user,$host_pass);
加入两行:
<div class="codetitle">
<a style="CURSOR: pointer" data="23271" class="copybut" id="copybut23271" onclick="doCopy('code23271')">
代码
如下:<div class="codebody" id="code23271">
MysqL
_query("set character set 'utf8'");//读库
MysqL
_query("set names 'utf8'");//写库
就可以正常的读写
MysqL
数据库
了。 用的appserv-win32-2.5.10做的环境,装这个包的时候用默认的utf8编码。
在写
数据库
连接
文件
时,写成:
<div class="codetitle">
<a style="CURSOR: pointer" data="49975" class="copybut" id="copybut49975" onclick="doCopy('code49975')">
代码
如下:<div class="codebody" id="code49975">
$conn =
MysqL
_connect("$host","$user","$password");
MysqL
_query("SET NAMES 'UTF8'");
MysqL
_select_db("$database",$conn);
然后在做
页面
时,注意这句:
<div class="codetitle">
<a style="CURSOR: pointer" data="69865" class="copybut" id="copybut69865" onclick="doCopy('code69865')">
代码
如下:<div class="codebody" id="code69865">
这样不管输入
数据库
的
中文
,还是
页面
显示
,就都正常了。
在DW CS4版里,默认
生成
的也是utf8
页面
。
同样的,如果一开始写
数据库
连接
文件
时写成:
<div class="codetitle">
<a style="CURSOR: pointer" data="36752" class="copybut" id="copybut36752" onclick="doCopy('code36752')">
代码
如下:<div class="codebody" id="code36752">
MysqL
_query("SET NAMES 'GBK'");
那
页面
也要相应变成:
<div class="codetitle">
<a style="CURSOR: pointer" data="36089" class="copybut" id="copybut36089" onclick="doCopy('code36089')">
代码
如下:<div class="codebody" id="code36089">
总结,最后主要是
页面
编码要统一就可以很方便的
解决
乱码问题,特别是在
MysqL
_query()这个set names的设置必须和
页面
及
数据库
编码
统计
一就可以了。
原文链接:https://www.f2er.com/php/27236.html
uft-8
中文编码乱码
上一篇:php递归创建和删除文件夹的代码小结
下一篇:php开发分页实现代码
猜你在找的PHP相关文章
Hessian通讯协议【附PHP源代码】
Hessian开源的远程通讯,采用二进制 RPC的协议,基于 HTTP 传输。可以实现PHP调用Java,Pyt...
作者:前端之家 时间:2021-02-22
初识Mongodb总结
初识Mongodb的一些总结,在Mac Os X下真实搭建mongodb环境,以及分享个Mongodb管理工具,学习...
作者:前端之家 时间:2021-02-22
初识Mongodb之[CURD]-PHP版
边看边操作,这样才能记得牢,实践是检验真理的唯一标准.光看不练假把式,光练不看傻把式,边看...
作者:前端之家 时间:2021-02-22
php学习日志 - echo&print
在php中,结果输出一共有两种方式:echo和print,下面将对两种方式做一个比较。 echo与pri...
作者:前端之家 时间:2021-02-21
The mbstring extension is missing. Please check your PHP configuration错误及解决方法
在安装好wampServer后,一直没有使用phpMyAdmin,今天用了一下,phpMyAdmin显示错误:The m...
作者:前端之家 时间:2021-02-21
解决Windows Live Writer错误:WindowsLive.Writer.CoreServices.HttpRequestHelper的类型初始值设定发生异常
以前用Windows Live Writer写日志都好好的,前几天用写完日志,点击发布,突然弹出意外错误...
作者:前端之家 时间:2021-02-21
在PHP项目中使用Standford Moss代码查重系统
Standford Moss 系统是斯坦福大学大名鼎鼎的代码查重系统,它可以查出哪些同学提交的代码是...
作者:前端之家 时间:2021-02-18
Windows下PHP安全环境的搭建
笔者一直在Windows环境下搭建PHP的运行环境,大大小小的运行环境用过不少,从开始的WAMP到...
作者:前端之家 时间:2021-02-18
ThinkPHP5作业管理系统中处理学生未交作业与已交作业信息
在作业管理系统中,学生登陆到个人中心后可以通过左侧的菜单查看自己已经提交的作业和未提...
作者:前端之家 时间:2021-02-18
ThinkPHP5项目目录规划实践
ThinkPHP5安装后(或者下载后的压缩文件解压后)可以看到下面的目录结构: 一般的信息管理...
作者:前端之家 时间:2021-02-18
编程分类
PHP
Java
Java SE
Python
C#
C&C++
Ruby
VB
asp.Net
Go
Perl
netty
Django
Delphi
Jsp
.NET Core
Spring
Flask
Springboot
SpringMVC
Lua
Laravel
Mybatis
Asp
Groovy
ThinkPHP
Yii
swoole
最新文章
• Hessian通讯协议【附PHP源
• 初识Mongodb总结
• 初识Mongodb之[CURD]-PHP版
• php学习日志 - echo&p
• The mbstring extension i
• php学习日志 - php变量
• 解决Windows Live Writer错
• 在PHP项目中使用Standford
• Windows下PHP安全环境的搭
• ThinkPHP5作业管理系统中处
热门标签
更多 ►
文件时间
pythonm
相等性
PHP Warning
时间问题
问题解决
pcntl_signal
采样点
wav模块
动态文本
调用频率限制
对外暴露
多个访问请求
更新数据表
模型结构
type()方法
比较速度
手写体
sobel算子
保存模型
Image类
nn.Conv2d
pytorch1.0
kaggle
DCGAN
交并比
range()用法
打印模型
反卷积
卷积