-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmudarSenha.php
More file actions
71 lines (57 loc) · 1.97 KB
/
mudarSenha.php
File metadata and controls
71 lines (57 loc) · 1.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?php
header('Content-Type: application/json');
require_once 'conexao.php';
session_start();
if (!isset($_SESSION['userid'])) {
echo json_encode(["success" => false, "message" => "Usuário não autenticado."]);
exit;
}
$data = json_decode(file_get_contents('php://input'), true);
if (!$data) {
echo json_encode(["success" => false, "message" => "Nenhum dado recebido."]);
exit;
}
$senhaAtual = $data['senhaAtual'];
$novaSenha = $data['novaSenha'];
$userId = $_SESSION['userid'];
// Verifica se os dados foram fornecidos corretamente
if (empty($senhaAtual) || empty($novaSenha)) {
echo json_encode(["success" => false, "message" => "Senhas não fornecidas corretamente."]);
exit;
}
// Obtém a senha armazenada no banco de dados
$stmt = $conn->prepare("SELECT senha FROM usuarios WHERE id = ?");
if (!$stmt) {
echo json_encode(["success" => false, "message" => "Erro na preparação da consulta: " . $conn->error]);
exit;
}
$stmt->bind_param("i", $userId);
$stmt->execute();
$stmt->bind_result($senhaHash);
$stmt->fetch();
$stmt->close();
// Verifica se a senha foi encontrada
if (empty($senhaHash)) {
echo json_encode(["success" => false, "message" => "Usuário não encontrado."]);
exit;
}
// Verifica a senha atual
if ($senhaAtual !== $senhaHash) {
echo json_encode(["success" => false, "message" => "Senha atual incorreta."]);
exit;
}
// Atualiza a senha no banco de dados
$stmt = $conn->prepare("UPDATE usuarios SET senha = ? WHERE id = ?");
if (!$stmt) {
echo json_encode(["success" => false, "message" => "Erro na preparação da consulta para atualização: " . $conn->error]);
exit;
}
$stmt->bind_param("si", $novaSenha, $userId);
if ($stmt->execute()) {
echo json_encode(["success" => true, "message" => "Senha alterada com sucesso."]);
} else {
echo json_encode(["success" => false, "message" => "Erro ao alterar a senha."]);
}
$stmt->close();
$conn->close();
?>