php连接mysql识别不到端口号
程序员文章站
2022-03-31 08:13:18
...
目前的项目开发完了一部分,本地测试正常,但是放到服务器上就不行了。
本地环境:
服务器环境:
本地环境:
xampp-3.2.2(php-5.6.15, apache-2.4.17)
服务器环境:
php-5.3.3
、nginx-1.0.15
、php-fpm
我尝试了3种连接mysql
的方法,在本地无一失败,在服务器无一成功。。
PDO
方法
代码:
$dsn = "mysql:dbname=$db;port=$this->dbPort;host=$this->dbHost;charset=$charset";
try {
$this->conn = new PDO($dsn, $this->dbUser, $this->dbPasswd);
return $this->conn;
} catch (PDOException $e) {
$this->DealError($e);
return false;
}
因为服务器的php
版本太旧,无法使用PDO
访问自定义的端口,于是放弃。
mysql
方法和mysqli
方法
代码:
//mysql
$this->conn = mysql_connect($this->dbHost.":".$this->dbPort, $this->dbUser, $this->dbPasword);
//mysqli
$this->conn=@mysqli_connect($this->dbHost, $this->dbUser, $this->dbPasswd, $this->dbName. $this->dbPort);
这个两个方法都会会提示如下错误:
Can't connect to MySQL server on 'cins.swpu.edu.cn' (13)
很明显并没有去连接服务器的自定义端口,但调用时确实指定了自定义端口,不知道这是什么原因
回复内容:
目前的项目开发完了一部分,本地测试正常,但是放到服务器上就不行了。
本地环境:xampp-3.2.2(php-5.6.15, apache-2.4.17)
服务器环境:php-5.3.3
、nginx-1.0.15
、php-fpm
我尝试了3种连接mysql
的方法,在本地无一失败,在服务器无一成功。。
PDO
方法
代码:
$dsn = "mysql:dbname=$db;port=$this->dbPort;host=$this->dbHost;charset=$charset";
try {
$this->conn = new PDO($dsn, $this->dbUser, $this->dbPasswd);
return $this->conn;
} catch (PDOException $e) {
$this->DealError($e);
return false;
}
因为服务器的php
版本太旧,无法使用PDO
访问自定义的端口,于是放弃。
mysql
方法和mysqli
方法
代码:
//mysql
$this->conn = mysql_connect($this->dbHost.":".$this->dbPort, $this->dbUser, $this->dbPasword);
//mysqli
$this->conn=@mysqli_connect($this->dbHost, $this->dbUser, $this->dbPasswd, $this->dbName. $this->dbPort);
这个两个方法都会会提示如下错误:
Can't connect to MySQL server on 'cins.swpu.edu.cn' (13)
很明显并没有去连接服务器的自定义端口,但调用时确实指定了自定义端口,不知道这是什么原因
服务器的mysql开启远程访问先。
建议还是先使用mysqlworkbench测试一下,确定ok,再上服务端程序。
1、确定是否权限是有的,根据网上查找的信息:mysql 13 的错误是提示有写权限的问题
2、mysql 是否自定义的端口上进行监听
3、mysql服务器是否配置了可以远程连接
根据题主描述,很像mysql没有开启外连,
telnet cins.swpu.edu.cn 端口号,试一下看看什么反馈。或者你直接在服务器上查看mysql user表你的用户信息。
推荐阅读
-
php 不能连接数据库 php error Can't connect to local MySQL server
-
php后台经常提示无法连接mysql 刷新后又可以访问的解决方法
-
PHP下使用mysqli的函数连接mysql出现warning: mysqli::real_connect(): (hy000/1040): ...
-
解决php用mysql方式连接数据库出现Deprecated报错问题
-
PHP连接MySQL的2种方法小结以及防止乱码
-
PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
-
测试php连接mysql是否成功的代码分享
-
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
-
php中mysql连接和基本操作代码(快速测试使用,简单方便)
-
PHP同时连接多个mysql数据库示例代码