Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP]Powiadomienie o nowej wiadomości
stefik4
post
Post #1





Grupa: Zarejestrowani
Postów: 176
Pomógł: 1
Dołączył: 18.11.2007

Ostrzeżenie: (0%)
-----


Witam. Mam zrobiona pocztę, która opreuje na tabeli `poczta` w bazie i tam zapisywane są wszystkie wiadomosci. Struktura bazy wygląd nastepująco:

Kod
CREATE TABLE `poczta` (
  `id` int(11) NOT NULL auto_increment,
  `nadawca` varchar(50) NOT NULL,
  `odbiorca` varchar(50) NOT NULL,
  `data` varchar(55) NOT NULL,
  `tytul` varchar(55) NOT NULL,
  `tresc` varchar(200) NOT NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin2 AUTO_INCREMENT=86;


I teraz jak zrobić, że gdy dojdzie nowa wiadomość do usera tego ktory jest zalogowany to pokazywlo sie jakies powiadomienie, że jest nowa wiadomośc (IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
phpion
post
Post #2





Grupa: Moderatorzy
Postów: 6 072
Pomógł: 861
Dołączył: 10.12.2003
Skąd: Dąbrowa Górnicza




batman:
No nie do końca bo co jeśli ktoś nie odbierze wiadomości w ciągu X dni? Wówczas otrzyma X razy to samo powiadomienie (przy założeniu, że wysyłka powiadomień odpalana jest raz na dobę).

stefik4:
Rozumiem, że nadal problemem jest wyświetlenie (lub nie) komunikatu o tym, czy użytkownik ma nową wiadomość. Jeśli tak to użyj czegoś takiego:
  1. <?php
  2. $q = 'SELECT COUNT(*) FROM `poczta` WHERE odbiorca="'.$odbiorca.'" AND `status`=0';
  3. $q = mysql_query($q);
  4.  
  5. if (mysql_result($q, 0) > 0) {
  6.    echo 'Masz nowa wiadomosc';
  7. }
  8. else {
  9.    // brak nowych wiadomosci
  10. }
  11. ?>

Nie sprawdzałem ale powinno działać. Pamiętaj tylko o odpowiednim zabezpieczeniu zmiennej $odbiorca (mysql_real_escape_string" title="Zobacz w manualu PHP" target="_manual). Ponadto powinieneś w tym polu trzymać ID użytkownika odwołujące się do tabeli z użytkownikami, a nie jego login.

PS: stefik4 - nie pomagam przez PW.

Ten post edytował phpion 17.02.2009, 10:41:37
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 27.12.2025 - 23:51