gpt4 book ai didi

mysql - WAMP:尝试连接到 mysql 时为 'No such host is known'

转载 作者:行者123 更新时间:2023-11-29 06:48:36 27 4
gpt4 key购买 nike

我得到了这个错误:

Warning: PDO::__construct() [<a href='pdo.--construct'>pdo.--construct</a>]: [2002] php_network_getaddresses: getaddrinfo failed: No such host is known. (trying to connect via tcp://1:3306) in Z:\work\...

我的 localhost/phpmyadmin 工作正常,但我无法访问 localhost 或 127.0.0.1 ,我得到一个空白页面“禁止访问:您无权访问此服务器上的/。”

我的 80 端口上没有其他东西在运行

我修改了我的httpd.conf

DocumentRoot "z:/work/"

<Directory />
Options FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
</Directory>

<Directory "z:/work/">
Options Indexes FollowSymLinks
AllowOverride all
Order Deny,Allow
Deny from all
Allow from all
</Directory>

也添加到我的httpd-vhosts.conf

<Directory C:/Users/Alex/Documents/GitHub>
Order Deny,Allow
Allow from all
AllowOverride All
</Directory>

<Directory Z:/work>
Order Deny,Allow
Allow from all
AllowOverride All
</Directory>

<VirtualHost *:80>
DocumentRoot "Z:\work\mysite"
ServerName bullseye.local
</VirtualHost>

<VirtualHost *:80>
DocumentRoot "C:\Users\Alex\Documents\GitHub\Myproject"
ServerName framework.local
</VirtualHost>

我的 phpmyadmin.conf 如下

Alias /phpmyadmin "c:/wamp/apps/phpmyadmin3.5.1/" 

<Directory "c:/wamp/apps/phpmyadmin3.5.1/">
Options Indexes FollowSymLinks MultiViews
AllowOverride all
Order Deny,Allow
Deny from all
Allow from all
</Directory>

给出错误的代码:

$host = 'localhost';
$user = 'root';
$pass = '';
$database = 'mydatabase';
$this->db = new PDO('mysql:dbname=' . $database . ';host=' .$host . ';charset=utf8', $user, $pass);

我使用 mysql 或 msqli 而不是 PDO 时得到同样的错误

最佳答案

我的建议是:

撤消对 httpd.conf 的所有更改。您的更改删除了 Apache 对 WAMP 主页(即本地主机)的所有了解。注释掉虚拟主机配置的包含并检查您是否可以再次访问 WAMP 主页。

确保 WAMP 处于“离线”状态,这将保证 C:\驱动器和 c:\wamp 文件夹的安全。

现在您的虚拟主机定义:

为了保持 wamp 主页正常工作,第一个条目应该如下所示,注意目录 block 应该是 VirtualHost 定义的一部分,安全定义确保您只能从 127.0.0.1 访问 wamp 主页(本地主机)

###must be first so the the wamp menu page loads
<VirtualHost *:80>
ServerAdmin webmaster@homemail.net
DocumentRoot "D:/wamp/www"
ServerName localhost
ServerAlias localhost
<Directory "D:/wamp/www">
Order Deny,Allow
Deny from all
Allow from 127.0.0.1
</Directory>
</VirtualHost>

您定义的每个 VHOST 都应该像这样包含自己的安全设置

<VirtualHost *:80>
DocumentRoot "Z:\work\mysite"
ServerName bullseye.local
ServerAlias bullseye.local
AllowOverride All
<Directory "Z:\work\mysite">
Order Allow,Deny
Allow from all
</Directory>
</VirtualHost>

<VirtualHost *:80>
DocumentRoot "C:\Users\Alex\Documents\GitHub\Myproject"
ServerName framework.local
ServerAlias www.framework.local
<Directory "C:\Users\Alex\Documents\GitHub\Myproject">
Order Allow,Deny
Allow from all
</Directory>
</VirtualHost>

取消注释包含在 https.conf 中的虚拟主机定义,然后尝试再次访问您的其他项目。

我假设您已经对 c:\windows\system32\drivers\etc\hosts 文件进行了必要的更改以包含对所有虚拟主机的引用?如果不是,hosts 文件应该如下所示:-

127.0.0.1  localhost127.0.0.1  framework.local127.0.0.1  bullseye.local

关于mysql - WAMP:尝试连接到 mysql 时为 'No such host is known',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17059199/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com