Php 数据库连接错误:Can';t通过套接字连接到本地MySQL服务器
我已经在一个托管网站上实现了数据库,而不是在mac上使用MySQL。 我使用数据库注册/登录IOS应用程序。数据库正在使用PHP代码进行连接 这是PHP代码:Php 数据库连接错误:Can';t通过套接字连接到本地MySQL服务器,php,mysql,Php,Mysql,我已经在一个托管网站上实现了数据库,而不是在mac上使用MySQL。 我使用数据库注册/登录IOS应用程序。数据库正在使用PHP代码进行连接 这是PHP代码: <?php header('Content-type: application/json'); if($_POST) { $Nome = $_POST['nome']; $Cognome = $_POST['cognome']; $Email = $_POST['email']; $DO
<?php
header('Content-type: application/json');
if($_POST) {
$Nome = $_POST['nome'];
$Cognome = $_POST['cognome'];
$Email = $_POST['email'];
$DOB = $_POST['dob'];
$password = $_POST['password'];
$c_password = $_POST['c_password'];
if($_POST['email']) {
if ( $password == $c_password ) {
$db_name = '****************';
$db_user = '****************';
$db_password = '*********************';
$server_url = 'localhost';
$mysqli = new mysqli('localhost', $db_user, $db_name, $db_password);
if (mysqli_connect_errno()) {
error_log("Connect failed: " . mysqli_connect_error());
echo '{"success":0,"error_message":"' . mysqli_connect_error() . '"}';
} else {
$stmt = $mysqli->prepare("INSERT INTO Users (nome, cognome, email, dob, password, c_password) VALUES (?, ?, ?, ?, ?, ?)");
$password = md5($password);
$stmt->bind_param('ssssss', $nome, $cognome, $email, $dob, $password, $c_password);
$stmt->execute();
if ($stmt->error) {error_log("Error: " . $stmt->error); }
$success = $stmt->affected_rows;
$stmt->close();
$mysqli->close();
error_log("Success: $success");
if ($success > 0) {
error_log("User '$email' created.");
echo '{"success":1}';
} else {
echo '{"success":0,"error_message":"Email Exist."}';
}
}
} else {
echo '{"success":0,"error_message":"Passwords does not match."}';
}
} else {
echo '{"success":0,"error_message":"Invalid Email."}';
}
}else {
echo '{"success":0,"error_message":"Invalid Data."}';
}
?>
这是我在尝试数据库时看到的错误:
(HY000/2002):无法通过第20行/srv/disk8/2129310/www/haer2jkqlgjl.co.nf/signUp.php中的套接字“/var/run/mysqld/mysqld.sock”(2)连接到本地MySQL服务器这个错误告诉我第20行有错误,但我不明白原因 它的语法错误
$mysqli = new mysqli('localhost', $db_user, $db_name, $db_password);
正确的语法是
$mysqli = new mysqli('localhost',$db_user,$db_password, $db_name);
您真的不应该使用PHP来处理密码安全性。在散列之前,请确保对它们进行了清理或使用了任何其他清理机制。这样做会更改密码并导致不必要的额外编码。虽然这是正确的,但这不会解决问题,因为他实际上无法连接到MySQL服务器。谢谢@TomWright。但是我回答了我第一次看到的更正。现在尝试解决更多问题。谢谢@devodedra,但我不工作。