apache - mod_rewrite, questo sconosciuto :)
Moderatore: Staff
1) Citare in modo preciso il linguaggio di programmazione usato.
2) Se possibile portare un esempio del risultato atteso.
3) Leggere attentamente le risposte ricevute.
4) Scrivere i messaggi con il colore di default, evitare altri colori.
5) Scrivere in Italiano o in Inglese, se possibile grammaticalmente corretto, evitate stili di scrittura poco chiari, quindi nessuna abbreviazione tipo telegramma o scrittura stile SMS o CHAT.
6) Appena registrati è consigliato presentarsi nel forum dedicato.
La non osservanza delle regole porta a provvedimenti di vari tipo da parte dello staff, in particolare la non osservanza della regola 5 porta alla cancellazione del post e alla segnalazione dell'utente. In caso di recidività l'utente rischia il ban temporaneo.
- danix
- Staff
- Messaggi: 3287
- Iscritto il: ven 27 ott 2006, 19:32
- Nome Cognome: Danilo M.
- Slackware: 64 current
- Kernel: 5.4.43 x86_64
- Desktop: i3
- Località: Siderno (RC)
- Contatta:
apache - mod_rewrite, questo sconosciuto :)
oggi mi è venuta la brillante idea di andare a dare un'occhiata a mod_rewrite... inutile dire che non è proprio la cosa più semplice del mondo, comunque sto leggendo varie guide...
Qualcuno di voi lo usa?? Mi interesserebbe sapere se effettivamente mi è utile riscrivere gli url del mio sito in ottica SEO...
Chiariti questi dubbi iniziali passerò a qualche domanda pratica...
Grazie mille a tutti...
Ciau
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Sì che lo uso (sopratutto redirect e redirectmatch), ma non fare come me con slackers che sono ancora nel dubbio e cambio sempre. Decidi prima gli url in ottica seo e se possibile non usare mod_rewritedanix85 ha scritto:Ciao a tutti,
oggi mi è venuta la brillante idea di andare a dare un'occhiata a mod_rewrite... inutile dire che non è proprio la cosa più semplice del mondo, comunque sto leggendo varie guide...
Qualcuno di voi lo usa?? Mi interesserebbe sapere se effettivamente mi è utile riscrivere gli url del mio sito in ottica SEO...
Chiariti questi dubbi iniziali passerò a qualche domanda pratica...
Grazie mille a tutti...
Ciau
comunque se non puoi fare a meno di scrivere qualcosa come index.php?id=pippo allora ti serve.
quello sopra per esempio potrebbe essere
redirectmatch 301 /index.php?id=(.*)$ http://tuosito/$1
che significa che ogni pagina index.php?id=pippo diventa http://tuosito/pippo
Questo è solo un banale esempio di quel che puoi fare
tieni presente che i cms stanno indirizzandosi a fare tutto lato php, anche Wordpress ha per esempio un .htaccess
Codice: Seleziona tutto
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>
per darti un'idea prima aveva una regola per ogni possibile match
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Allora a me servirebbe una soluzione, penso con .htaccess, per bloccare l'accesso diretto ai file
Mi spiego, ho degli applicativi php che permettono l'upload e la consultazione di documenti (principalmente pdf) agli utenti che si loggano
Ora io vorrei impedire che, anche solo indovinando, sia possibile accedere a tali documenti semplicemente scrivendo l'indirizzo completo nel browser
Esempio:
applicativo pubblicato su /www/mioprogramma
documenti su /www/mioprogramma/documenti
Io vorrei che si potesse accedere ai documenti solo tramite applicativo
Ho provato con .htpasswd ma non è una soluzione conveniente diciamo, e spostare i file fuori dalla directory pubblicata non posso farlo
Chi sa come fare batta un colpo!
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Perché no?JohnnyMnemonic ha scritto: Ho provato con .htpasswd ma non è una soluzione conveniente diciamo
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Scusa, ho sbagliato, avevo capito .htaccessJohnnyMnemonic ha scritto:Perchè gli utenti già si collegano inserendo nome e password, e chiedergliene un'altra, tra l'altro pure diversa, non è il massimo purtroppo
Ma puoi usare .htaccess dicendo che quel documento è vietato chiamarli direttamente
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Ma tu devi bloccare tutto, tanto l'applicativo agisce a livello di filesystem immaginoJohnnyMnemonic ha scritto:Purtroppo sono tanti documenti in altrettante sottodirectory, creati automaticamente dall'applicativo
Se nella directory documenti fai un .htaccess così
Codice: Seleziona tutto
Order deny,allow
Deny from all
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Forse il problema risiede nel fatto che io accedo al file via php con
Ma in che altro modo potrei fare?$ID=$_POST['iddocumento'];
$NOMEFILE=$_POST['nomefile'];
$FILEDASCARICARE="documenti/".$_SESSION['database']."/".$ID."/".$NOMEFILE;
header("Location: $FILEDASCARICARE ");
- danix
- Staff
- Messaggi: 3287
- Iscritto il: ven 27 ott 2006, 19:32
- Nome Cognome: Danilo M.
- Slackware: 64 current
- Kernel: 5.4.43 x86_64
- Desktop: i3
- Località: Siderno (RC)
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
non è proprio lo stesso argomento, ma non c'è problema, almeno imparo qualcosa anche io...
@tutti:
ci capisco sempre meno...
il sito è già pronto, quindi di mettermi a riscrivere gli url non se ne parla... però mod_rewrite è più ostico di quanto pensassi...
ad esempio, la cosa più facile dovrebbe essere quella di nascondere il classico /index.php... giusto??
io ho gli url strutturati in questo modo:
Codice: Seleziona tutto
http://www.miosito.com/index.php?p=pagina§ion=sezione
Codice: Seleziona tutto
http://www.miosito.com/pagina/sezione
Un'altra cosa, allo stato attuale la home può essere visualizzata in 3 modi:
Codice: Seleziona tutto
1. http://www.miosito.com/
2. http://www.miosito.com/index.php
3. http://www.miosito.com/index.php?p=home
Codice: Seleziona tutto
http://www.miosito.com
Mi date qualche spunto per iniziare a capirci qualcosa?? non voglio la pappa pronta, però da solo non ci arrivo...
Spero mi aiuterete...
Grazie mille
Ciau
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Prendendolo dal filesystem. Se risiedono nello stesso server perché fare così?JohnnyMnemonic ha scritto:Così mi risponde Internal Server Error quando tento di scaricare il file con l'applicativo
Forse il problema risiede nel fatto che io accedo al file via php con
Ma in che altro modo potrei fare?$ID=$_POST['iddocumento'];
$NOMEFILE=$_POST['nomefile'];
$FILEDASCARICARE="documenti/".$_SESSION['database']."/".$ID."/".$NOMEFILE;
header("Location: $FILEDASCARICARE ");
Quella è una richiesta http
Dovresti prendere il file e poi darlo in output, come faresti per le immagini per esempio.
però devi conoscere l'header del file
header("Content-type: image/png");
e poi il codice...
Nel tuo caso invece ti comporti come un browser, prova ad agire sui referrer
Codice: Seleziona tutto
SetEnvIfNoCase Referer "^http://www.tuodominio.com/" ok_img
SetEnvIfNoCase Referer "^http://www.tuodominio.com$" ok_img
SetEnvIfNoCase Referer "^$" ok_img
<filesmatch "\.*$">
Order Deny,Allow
deny from all
Allow from env=ok_img
</filesmatch>
Oppure puoi usare allo stesso modo RewriteCond e RewriteRule, ma questo lo faccio per esempio per impedire acquisizioni da altri siti, non so se nel tuo caso funziona.
Oppure prova
Codice: Seleziona tutto
Order deny,allow
Deny from all
Allow from localhost
Magari quando ho tempo faccio delle prove
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Prova cosìdanix85 ha scritto:vorrei che diventasse:Codice: Seleziona tutto
http://www.miosito.com/index.php?p=pagina§ion=sezione
non è SEF così?? Solo che non riesco a farlo in nessun modo...Codice: Seleziona tutto
http://www.miosito.com/pagina/sezione
Codice: Seleziona tutto
RewriteRule ^/([a-z]+)/([a-z]+)/ http://www.miosito.com/index.php?p=$1§ion=$2 [NC,L]
Puoi usare i redirectdanix85 ha scritto: Un'altra cosa, allo stato attuale la home può essere visualizzata in 3 modi:Posso fare in modo che a tutti e 3 questi indirizzi corrisponda il primo, cioè:Codice: Seleziona tutto
1. http://www.miosito.com/ 2. http://www.miosito.com/index.php 3. http://www.miosito.com/index.php?p=home
Codice: Seleziona tutto
http://www.miosito.com
Codice: Seleziona tutto
Redirect 301 /index.php$ http://www.miosito.com/
Redirect 301 /index.php?p=home$ http://www.miosito.com/
Codice: Seleziona tutto
RewriteRule ^/index.php$ http://www.miosito.com/ [NC,L]
RewriteRule ^/index.php?p=home$ http://www.miosito.com/ [NC,L]
Per le opzioni ( [NC] per esempio) guardare http://httpd.apache.org/docs/2.2/mod/mod_rewrite.html
p.s.
stai attento se qualche espressione regolare sballa, sono solo esempi scritti in fretta
Se usi
RewriteRule ^/index.php$ http://www.miosito.com/ [NC,L]
RewriteRule ^/index.php?p=home$ http://www.miosito.com/ [NC,L]
o le metti per prime, o togli l'opzione L (last) alla prima
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Ok in questo modo funziona, purtoppo non posso cambiare il comportamento "da browser"...conraid ha scritto:JohnnyMnemonic ha scritto:...
Prendendolo dal filesystem. Se risiedono nello stesso server perché fare così?
Quella è una richiesta http
Dovresti prendere il file e poi darlo in output, come faresti per le immagini per esempio.
però devi conoscere l'header del file
header("Content-type: image/png");
e poi il codice...
Nel tuo caso invece ti comporti come un browser, prova ad agire sui referrer
Cerca il tuo dominio preciso e guarda se il "match" va bene.Codice: Seleziona tutto
SetEnvIfNoCase Referer "^http://www.tuodominio.com/" ok_img SetEnvIfNoCase Referer "^http://www.tuodominio.com$" ok_img SetEnvIfNoCase Referer "^$" ok_img <filesmatch "\.*$"> Order Deny,Allow deny from all Allow from env=ok_img </filesmatch>
L'unica cosa è che così non mi permette l'accesso da fuori della mia rete
Non c'è un modo per dire ad esempio: "se provieni col browser dalla tal pagina accedi al file altrimenti no" ?
EDIT Ops, anzi no non funziona nemmeno così, rinnovo la mia domanda sullo pseduocodice allora
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: apache - mod_rewrite, questo sconosciuto :)
Da php lo saprei fare, da .htaccess... mmm...JohnnyMnemonic ha scritto: Non c'è un modo per dire ad esempio: "se provieni col browser dalla tal pagina accedi al file altrimenti no" ?
Eppure quel codice dovrebbe fare qualcosa di simile. Io lo uso in modo che le immagini sono visualizzabili solamente se la richiesta viena da altre pagine presenti nel sito o direttamente dal browser e non esternamente.
Ma non ti funziona cosa vuol dire?
Che vedono tutti il documento o nessuno?
Perché se lo vedono tutti togli
SetEnvIfNoCase Referer "^$" ok_img
- JohnnyMnemonic
- Staff
- Messaggi: 2733
- Iscritto il: dom 5 set 2004, 0:00
- Nome Cognome: Giuseppe Palmiotto
- Slackware: 14.0
- Kernel: 3.5.5-thanatos
- Località: Bologna
- Contatta: