>백엔드 개발 >PHP 튜토리얼 >php连接mysql识别不到端口号

php连接mysql识别不到端口号

WBOY
WBOY원래의
2016-06-06 20:19:431586검색

目前的项目开发完了一部分,本地测试正常,但是放到服务器上就不行了。
本地环境:xampp-3.2.2(php-5.6.15, apache-2.4.17)
服务器环境:php-5.3.3nginx-1.0.15php-fpm


我尝试了3种连接mysql的方法,在本地无一失败,在服务器无一成功。。

PDO方法

代码:

<code class="php">$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;
}</code>

因为服务器的php版本太旧,无法使用PDO访问自定义的端口,于是放弃。

mysql方法和mysqli方法

代码:

<code class="php">//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);</code>

这个两个方法都会会提示如下错误:

<code class="php">Can't connect to MySQL server on 'cins.swpu.edu.cn' (13)</code>

很明显并没有去连接服务器的自定义端口,但调用时确实指定了自定义端口,不知道这是什么原因

回复内容:

目前的项目开发完了一部分,本地测试正常,但是放到服务器上就不行了。
本地环境:xampp-3.2.2(php-5.6.15, apache-2.4.17)
服务器环境:php-5.3.3nginx-1.0.15php-fpm


我尝试了3种连接mysql的方法,在本地无一失败,在服务器无一成功。。

PDO方法

代码:

<code class="php">$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;
}</code>

因为服务器的php版本太旧,无法使用PDO访问自定义的端口,于是放弃。

mysql方法和mysqli方法

代码:

<code class="php">//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);</code>

这个两个方法都会会提示如下错误:

<code class="php">Can't connect to MySQL server on 'cins.swpu.edu.cn' (13)</code>

很明显并没有去连接服务器的自定义端口,但调用时确实指定了自定义端口,不知道这是什么原因

服务器的mysql开启远程访问先。
建议还是先使用mysqlworkbench测试一下,确定ok,再上服务端程序。

1、确定是否权限是有的,根据网上查找的信息:mysql 13 的错误是提示有写权限的问题
2、mysql 是否自定义的端口上进行监听
3、mysql服务器是否配置了可以远程连接

根据题主描述,很像mysql没有开启外连,
telnet cins.swpu.edu.cn 端口号,试一下看看什么反馈。或者你直接在服务器上查看mysql user表你的用户信息。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.