[PHP] Notifiche utente, connessione database, struttura generale dati

KILLERIX

Nuovo Utente
13 Gen 2017
14
0
1
27
Buonasera ragazzi, ho un po' di domande da porgervi.

1. Come potrei realizzare "logicamente" un sistema di notifiche con php e mysql? Ovvero, tipo Facebook, che quando io faccio un post, mi arriva la notifica se qualcuno mette mi piace o lo commenta. Per caso devo fare tutto tramite database? Per esempio Utente1 commenta il post di Utente2 e quando preme invio automaticamente apro la tabella relativa a Utente2, una tabella creata apposta per lo storico delle notifiche, con anche un campo flag per vedere se è stata letta o meno, e vado a scrivere che Utente1 ha fatto una determinata cosa e che è una notifica da leggere. Poi quando Utente2 accede al sito, automaticamente il sito legge la tabella notifiche e mostra a questo tutte quelle ancora da leggere. Io l'ho pensata così ma credo che sia troppo lento e costoso fare una cosa del genere. Forse mi sto sbagliando?

2. Come sono strutturate le connessioni, tramite php, ad un database mysql? Esistono degli step fissi da seguire? Sto progettando un sito web e quando ho necessità di accedere al database, eseguo la pagina php, mi collego al database, prendo ciò che mi serve e lo chiudo. Però, già qui mi sono accorto che in questo modo sono soggetto a Sql injection, infatti, per proteggermi dal classico "OR 1=1", quando leggo dal login "username" e "password", prima di inserirlo nella query sql invoco il metodo "addslashes()" che dovrebbe aggiungere slash a eventuali simboli nei campi del form. Però, credo che vi siano degli accorgimenti da poter fare per proteggermi da questo genere di attacchi. Per esempio, devo connettermi al database tramite PDO? Posso aprire una volta solo il database e chiuderlo semplicemente quando l'utente si scollega? Queste domande, anche molto confuse, le faccio perché fino a qualche tempo fa credevo che, essendo php un linguaggio lato server, fosse impossibile risalire alle informazioni di qualsiasi file php sull'host del sito web. Mi hanno detto che invece posso accedere a queste informazioni e, nel caso riescano, se entrano nella pagina di php e leggono come io mi connetto al database per fare le query, ecco che sono fregato! O forse sbaglio anche qui?

3. Come rappresento i dati di un utente? Per esempio, se entro nel profilo di questo forum, mi da tutte informazioni relative al mio profilo, i miei post, ultimo accesso, frase, immagine e altre cose. Le metto sempre in un database sql? O conviene creare altre tipologie di database e gestirle tramite php? Ho la vaga impressione che abusare di sql e delle sue tabelle, soprattutto quando vi sono molte informazioni, sia troppo costoso dal punto di vista di elaborazione di un server.

4. Ultima domanda, che non centra nulla con php ma senza che apro un nuova discussione... Comunque, per la struttura di una pagina html, ho letto che bisogna usare i div e non le table anche perché Google penalizza quelli che usano le table. E' vero? Perché se lo è, evito qualsiasi utilizzo delle table!

Grazie a chiunque risponderà. Qualsiasi cosa chiedetemi!
 
Ultima modifica:

borgo italia

Super Moderatore
Membro dello Staff
SUPER MOD
MOD
4 Feb 2008
16.042
147
63
PR
www.borgo-italia.it
ciao
per rispondere a tutte ci vorrebbe una bibbia e poi si dovrebbe sapere quanto conosci php/mysql (tra l'altro molto probabilmente ti servirà anche js/ajax e/o jquery).
visto così ti convine usare mysql utilizzando le PDO
 

KILLERIX

Nuovo Utente
13 Gen 2017
14
0
1
27
Conosco tutti i linguaggi che mi hai elencato. Sono un informatico ma un conto è studiare ogni singolo linguaggio, un conto è metterli tutti insieme. Infatti io il sito lo sto facendo già, solo che queste domande servivano prettamente per capire meglio se dovevo implementare altro, migliorare o lasciare tutto così come è. Forse ho scritto tanto ma quello che chiedo non è molto. Solo qualche accenno "logico" ai problemi da me descritti, qualche link e qualche guida se ne conoscete. Poi per il resto studio e cerco da solo!
 

borgo italia

Super Moderatore
Membro dello Staff
SUPER MOD
MOD
4 Feb 2008
16.042
147
63
PR
www.borgo-italia.it
ciao ok
vediamo la prima serie come logicamente penso io
è lapalissiano che chi scrive un post nuovo o risponde ad un post debba essere loggato, probabilmente avrai il suo user in sessione
per un post nuovo:
form in cui l'utente scrive qualcosa (titolo, testo) e forse agginge immagini...
al submit:
a) ti fai invire una email in cui avrai "l'utente pinco ha postato titolo de titoli"
b) carichi su db id utente e quant'altro serva (no so se ti conviene mettere un flag che autorizzi la pubblicazione)
es. nel mio sito un utente puo caricare filmati, ma questi non vengono automaticamente resi pubblici anche se carico i, mi arriva un email e io verifico e o lo elimino o metto un flag della tabella 'filmati' a 1 (autorizzato)

analogamente per una risposta ad un post

intanto detto questo e riassumendo ti serviranno alcune tabelle:
utenti: id_utente, username, password, email (quant'altro ti serva)//la password deve essere criptata quindi eviti OR 1=1
post: id_post, id_utente, titolo, testo....
risposta: id_risposta, id_post, testo....

intanto mi fermo qui
comunque io uso mysql+php, non uso le PDO (anche se sarebbe meglio) in quanto nato con la programmazione "a spagetti" e quindi non amo la programmazione ad oggetti

p.s.
per le guide guarda nella home -> didattica e vedi se c'è qualcosa che ti serva
 
Discussioni simili
Autore Titolo Forum Risposte Data
bubino8 [PHP] Notifiche tempo reale PHP 0
C [PHP] Soluzioni notifiche real-time? PHP 0
A invio massivo dati a file php Javascript 4
Z MySql injection PHP PHP 1
V PHP form intersecate PHP 0
I [Offro][Retribuito] Programmatore Php Offerte e Richieste di Lavoro e/o Collaborazione 0
P Funzione jQuery Ajax invio file a php jQuery 1
C Dopo chiusura del tag php la stringa html va a capo PHP 1
E Transaction php PHP 11
B ciclare file xml con PHP PHP 1
L Estrazione dati php Database 6
A Aiuto per pagina php PHP 0
E Php select option e ajax PHP 23
I Aiuto php Dependent Lookup PHP 0
T arretramento versione PHP... PHP 3
D problema php mysql PHP 1
D problema php mysql PHP 1
E Barra di avanzamento codice PHP PHP 4
G creazione menu a tendina e invio a pagina php PHP 1
A inserire variabile php colore in div html PHP 2
Z Video protetto con PHP PHP 0
Z Problema di sincronizzazione PAYPAL con PHP PHP 1
I Eecuzione di javascript in ciclo foreach php. PHP 7
S Libreria PHP per creare file dwg o dxf PHP 0
A [cerco - retribuito] Sviluppatore Php freelance per progetti vari Offerte e Richieste di Lavoro e/o Collaborazione 2
L Google chart php mysql PHP 2
R Download file multipli da directory php PHP 0
F pagina dinamica PHP PHP 3
P Rimozione automatica url da sitemap.xml con PHP PHP 1
L php tinymce mi duplica la classe label PHP 3
S Errore PHP - Notice: Undefined index ... PHP 14
N file manager da php 5 a 7 PHP 15
M Utilizzare la funzione mysql_num_rows() in PHP 5 PHP 3
elpirata Update dinamico informazioni scritte in una pagina php jQuery 11
N Mysql_result per PHP 7 PHP 2
Emix Select concatenate php sql ajax PHP 2
P Modifica con PHP di un node in una sitemap xml PHP 0
D Come usare funzione php PHP 6
P Cancellazione specifici files in una folder php PHP 1
R Tradurre stringhe con php e google translator PHP 4
I Salvataggio snapshot IPCAM tramite PHP PHP 5
felino PHP e script generazione file excel PHP 2
L Aiuto per programma web php/mySQL PHP 2
A Estrapolare parti di testo con PHP PHP 2
A Aiuto php colore diverso PHP 10
E Errore di lettura php in html PHP 8
J php, scegliere autista da select e mostrare se ha fatto un incidente PHP 8
P Passaggio id php a javascript PHP 6
MarcoGrazia [PHP] [regex] Validare un url PHP 2
W Rinominare un file in PHP PHP 7

Discussioni simili