<?php try{ $db = new pdo( 'mysql:host=wuxiancheng.cn;port=3306;dbname=mysql;charset=utf8', 'user', 'password', array( PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_TIMEOUT => 3 ) ); }catch(PDOException $e){ echo $e->getMessage(); echo '<br />'; echo iconv('gbk', 'utf-8', $e->getMessage()); } ?>
SQLSTATE[HY000] [2002] 因为目标计算机积极拒绝,没法链接。 php
PHP PDO链接MySQL数据库时,若是MySQL没有启动或者没法访问时将会出现SQLSTATE[HY000] [2002]错误。该错误信息是由PHP所在的计算机系统底层产生的,若是操做系统为Windows而且操做系统语言为简体中文,那么错误信息为GBK编码,PHP使用非GBK编码时会出现乱码,解决方法是将错误信息从GBK转码为UTF-8之后再输出,转码能够使用iconv()函数,该函数须要开启php mbstring扩展之后才能使用,下面是解决 SQLSTATE[HY000] [2002] 乱码的PHP示例代码。html
在php.ini中开启扩展便可mysql