Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Salve! Estou desenvolvendo um sistema de mensagens para o meu site no qual o ADM envia a mensagem para todos os usuarios ou ele pode digitar o email de um usuaio e será enviado apenas para este usuario especifico, além disso, o usuario recebe um tipo de notificação que informa que tem uma nova mensagem. O problema está sendo justamente nesta segunda parte não consigo pensar em uma logica para que a mensagem destinada a apenas um usuario so seja notificado ele.
Alguém pode me ajudar
vejam meu codigo
<?php
//conexao com o banco de dados
include '../php/conexao.php';
//pega a tabela mensagem
$query = mysql_query("select * from mensagem")or die(mysql_error
//ver todos os dados que tem nela
while($mensagem = mysql_fetch_assoc($query)){
//verifica na tabela ler se o codigo do aluno é igual ao codigo do usuario logado se tem alguma mensagem na tabela e se o email do destinatario é igual //ao do usuario logado
$ver = mysql_query("SELECT * FROM ler where codigo_aluno='".$row['id']."' and codigo_mensagem= '".$mensagem['id']."' and destinatario ='".$row['email']."'")or die(mysql_error);
}
//se for igual ao 0 ou seja não tiver tudo ok significa que ele não leu a mensagem então mostra a notificação
if(mysql_num_rows($ver) == 0){
?>
<span class="app-menu__label">Mensagens</span> <i><img src="../img/icone/menu/sino_mensagem.png" width="26px" height="26px"></i></a> </li>
<?php ?>
<span class="app-menu__label">Menssagem</span></a> </li>
<?php
}
?>
Preciso de ajuda acho que o erro é na minha logica>
1 hora atrás, Omar~ disse:
A lógica é simples cara...
Bem, você terá uma tabela para armazenar essa notificação.
Enviou mensagem, salva o registro na tabela de notificação.
Em sua estrutura HTML você terá um local onde a consulta de notificação será feita, se tem alguma registro você indica da forma que achar melhor.
Agora poder notificar em tempo real é um pouco mais complexo, mas simples pois estaremos fazendo a mesma coisa só iremos depender de javascript.
De fato nunca mexi com esse lance de notificação em tempo real, mas está em meus planos implementar em meu website e o caminho a segui é só ler isso:
https://developer.mozilla.org/en-US/docs/Web/API/Notifications_API
https://developer.mozilla.org/pt-BR/docs/Web/API/notificacoes
Omar já agradeço pela ajuda, mas não necessito que essas notificações sejam enviadas em tempo real só preciso que caso a mensagem seja para um usuario especifico só ele recebera essa notificação e não todos os usuarios caso ele seja publica ela todos receberão a notificação
Para deixar algo mais claro vamos de um exemplo (isso seria minha arquitetura você pode fazer conforme suas necessidades):
Tabela
CREATE TABLE `notificar` (
`status` ENUM('nova','antiga'),
`usuario` int(9),
`titulo` varchar(100) NOT NULL DEFAULT '',
`dia` date NOT NULL,
`mensagem` text
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
-
Em status temos a condicional nova e antiga.
-
Toda vez que uma notificação é inserida ela vai como nova, então se o usuário a ver alteramos esse valor para antiga.
-
Em usuario registramos o id da conta daquele usuário para que possamos fazer a consulta e somente ele receba sua notificação.
-
Em titulo poderemos dar um título a notificação exemplo "Você tem uma notificação em blablabla"
-
Em dia poderemos registrar a data que a notificação foi lançada.
-
Em mensagem transcrevemos o conteúdo.
Então para que somente o usuário específico receba suas notificações fazemos a consulta.
"SELECT * FROM notificar WHERE usuario = '{$ID_DO_USUARIO}'"
Esse **$ID_DO_USUARIO** pode ser uma cessão que o identifique.>
3 horas atrás, Omar~ disse:
Para deixar algo mais claro vamos de um exemplo (isso seria minha arquitetura você pode fazer conforme suas necessidades):
Tabela
CREATE TABLE `notificar` (
`status` ENUM('nova','antiga'),
`usuario` int(9),
`titulo` varchar(100) NOT NULL DEFAULT '',
`dia` date NOT NULL,
`mensagem` text
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
-
Em status temos a condicional nova e antiga.
-
Toda vez que uma notificação é inserida ela vai como nova, então se o usuário a ver alteramos esse valor para antiga.
-
Em usuario registramos o id da conta daquele usuário para que possamos fazer a consulta e somente ele receba sua notificação.
-
Em titulo poderemos dar um título a notificação exemplo "Você tem uma notificação em blablabla"
-
Em dia poderemos registrar a data que a notificação foi lançada.
-
Em mensagem transcrevemos o conteúdo.
Então para que somente o usuário específico receba suas notificações fazemos a consulta.
"SELECT * FROM notificar WHERE usuario = '{$ID_DO_USUARIO}'"
Esse **$ID_DO_USUARIO** pode ser uma cessão que o identifique.
Omar, compreendo o que quer dizer e estou fazendo a mesma coisa no meu codigo o problema, como já tinha dito, é sobre as mensagens privadas endereçadas a um usuario especifico. Quando eu enviar essa mensagem para esse usuario apenas ele receberá a notificação o problema é que todos os usuario estão recebendo.@Sapinn
O seu problema é que a mensagem deve ser exibida apenas para o usuário que está logado no seu sistema e para fazer isso, seguindo o exemplo que o @Omar~ lhe deu, basta colocar no seu SELECT um WHERE onde o campo USUARIO tenha o código igual ao usuário da sua base logado no sistema, para que você possa fazer isso, no momento do Login você deve pegar o ID do seu usuário logado e guardar em uma variável de sessão para poder colocar no WHERE desse SELECT.
Entendeu, se eu mandar uma mensagem para você.
Digamos que o seu código no seu sistema seja 1 (Tabela de Usuários) por exemplo.
Mandei uma mensagem para o USUÁRIO 1, salvei nessa tabela como exemplo do @Omar~, quando você estiver logado, NO LOCAL ONDE VOCÊ QUER EXIBIR esta mensagem você deve colocar um SELECT * FROM notificar WHERE usuario = $_SESSION['ID']
Então eu vou obter TODAS as mensagem que tenham o código do usuário IGUAL ao seu ID de Login. Entendeu?
O que está acontecendo é que você está apenas dando um SELECT na base sem um WHERE e por isso esta retornando mensagem que não são endereçadas a você.
Reveja a sua lógica e faça como o @Omar~ e eu estamos sugerindo.
Espero ter ajudado.
Att.
***Felipe Coutinho***
A lógica é simples cara...
Bem, você terá uma tabela para armazenar essa notificação.
Enviou mensagem, salva o registro na tabela de notificação.
Em sua estrutura HTML você terá um local onde a consulta de notificação será feita, se tem alguma registro você indica da forma que achar melhor.
Agora poder notificar em tempo real é um pouco mais complexo, mas simples pois estaremos fazendo a mesma coisa só iremos depender de javascript.
De fato nunca mexi com esse lance de notificação em tempo real, mas está em meus planos implementar em meu website e o caminho a segui é só ler isso:
https://developer.mozilla.org/en-US/docs/Web/API/Notifications_API
https://developer.mozilla.org/pt-BR/docs/Web/API/notificacoes