DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   Regular expression i htaccess (http://www.devprotalk.com/forumdisplay.php?f=41)
-   -   .htaccess, http -> jedno pravilo, https -> drugo (http://www.devprotalk.com/showthread.php?t=329)

Ilija Studen 04. 11. 2005. 00:22

.htaccess, http -> jedno pravilo, https -> drugo
 
Da li mi neko može pomoći. Problem je sledeći: želim da kad čovek dolazi sa http da se primeni jedan rewrite rule, ako je pak https da se primeni drugo pravilo. Prilično bitno i hitno ;)

Ilija Studen 04. 11. 2005. 01:01

Rešio, metodom uzaludnog pokušaja i uz pomoć prijatelja (fala Godžo). Evo, možda nekom pomogne:

Kôd:

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{HTTPS} ^on.*
RewriteRule ^(.*)$ https://www.example.com/index.php?req=/$1 [L]

RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ http://www.example.com/index.php?req=/$1 [L]

Navedeni kod prvo proverava da li traženi fajl postoji. Ako ne postoji prepisuje u prvom slučaje kad korisnik koristi https, u drugom kad koristi http.

godza 07. 11. 2005. 22:17

nema frke care (mrzzzzzzzzzzim htaccess)

zextra 05. 12. 2005. 12:57

obozavam htaccess i mod_rewrite :D uzgred, zasto ceo posao obrade url-a prebacivati na php, kada jedan (tj dobar) deo moze da odradi i apache? :D

ivanhoe 05. 12. 2005. 15:17

a tek kad otkrijes RewriteMap komandu i sta sve sa tim moze da se uradi.. ucitavanje rewrite rules iz text fajlova, iz baze, cak i externu skriptu koja radi rewrite :D

jedino sto mora da se napomene da je upotreba mod_rewrite u .htaccessu losije resenje (ali ko nema izbora sta ce), daleko je efikasnije ko ima pristup httpd.conf-u da tamo pise rewrite rules, jer se time stede dodatni redirekti, i tada mod_rewrite prakticno uopste ne utice na perfomanse servera. To je tek onda prava stvar...

Ilija Studen 05. 12. 2005. 15:25

Zato što .htaccess ne može da se gradi i učitava dinamički, a PHP može. Pogledaj sve novije frameworke: svi koriste neki vid rutiranja.

Npr, framework koji koristim ti ne dozvoljava da imaš "prljave" URLove, tj. dozvoljava ti, ali ti je jednostavnije da koristiš /nesto/nesto/nesto/ jer imam niz ruta definisanih za taj tip URLova.

ivanhoe 05. 12. 2005. 23:03

ma moze, kako ne moze...sve moze :D

kao prvo htaccess se ucitava za svaki zahtev, tako da ti mozes da ga generise po volji...tako recimo radi Wordpress...

mada je to primitivno resenje, jer je mnooooogo bolje sa RewriteMap. Tako mozes da imas recimo perl (ili C ili php-cli) skript kome Apache posalje na STDIN neki url, a ovaj mu vrati novi url preko STDOUT, i onda Apache koristi taj novi url.. znaci mozes da rutiras kako ti se svidja, isto kao iz skripta, ali sa jednom velikom prednoscu, sto se taj skript pokrene samo jednom, kad se startuje Apache, i ostaje upaljen trajno (koliko i Apache), pa se izbegava overhead za kompajliranje kod svakog upita...takodje i ako koristis bazu, povezujes se samo jedanput, pa je brze...

moduli za apache su ludilo, ali nazalost u web hosting varijanti ne moze vecina tih stvari da se iskoristi kako treba...

zextra 06. 12. 2005. 12:56

najbolje performanse se postizu ako se mod_rewrite pravila upisu direktno u vhost config. uostalom, neke rewrite opcije ni ne mogu da se promene iz per-directory (.htaccess) config fajlova (kao npr RewriteLog).

RewriteMap je dosta mocan alat. Jasno je meni zasto Ilija radi ovako - zgodnije je da imas sve na jednom mestu i da to kontrolises kako tebi odgovara, ali sto kaze ivanhoe, sa mod_rewrite "nema da ne moze!" ;)

kad smo vec kod .htaccess-a, evo sta ja koristim za moj home-made cms.

Kôd:

# .htaccess

# Configure PHP and add source highlighting

AddType application/x-httpd-php-source .phps

php_value display_errors "0"
php_value error_reporting "E_NONE"
php_value magic_quotes_gpc "0"
php_value magic_quotes_runtime "0"
php_value expose_php "0"

# Disable directory indexes

Options -Indexes

# Configure rewrite engine

RewriteEngine On
RewriteOptions MaxRedirects=10

# If http://www.someplace.com/index/ is requested, transform it and stop.
# (otherwise, it will lead to error 500)

RewriteCond %{REQUEST_URI}              /index/
RewriteRule ^.+$                        index.php                [L]

#
# If an existing file is requested, allow direct access
#
# (if a directory contents should be protected, create .htaccess
# file with following contents:
#
# order allow,deny
# deny from all
#
# and save in directory you need.
#

RewriteCond %{SCRIPT_FILENAME}          -f
RewriteRule ^(.+)$                      $1                      [L]

# If user enters http://www.someplace.com/something, check if something.php
# exists in specified directory (/ in this case), and if it does, let user
# access it.

RewriteCond %{SCRIPT_FILENAME}\.php    -f
RewriteRule ^(.+)$                      $1.php                  [L]

#
# Now do some magic: convert url of form
#
# http://www.someplace.com/subdir/mod/act/parm1/val1/
#
# into
#
# http://www.someplace.com/subdir/index.php?subdir/mod/act/parm1/val1/
#
# That allows script to parse all input parameters, and makes it possible to
# move whole directory structure in some subdirectory, without modifications
# in this file. In other hand, script has to figure out which part of param
# string belongs to the path.
#

RewriteCond %{SCRIPT_FILENAME}          !-d
RewriteCond %{REQUEST_URI}              ^/(([^\.]+)?(/((.+)?(/(.+)?)?)?)?)?$
RewriteRule ^.+$                        index.php?%2%3          [L]

# eof .htaccess

da budem iskren, resenje je gotovo identicno onome sto ilija koristi, plus sto sam ja to jos malo zakomplikovao (bez potrebe, ispostavilo se), ali samo zato sto sam imao nesto drugo na umu kada sam pisao ovo.

ivanhoe 06. 12. 2005. 13:12

kad koristite -f i -d opcije obratite paznju da to zahteva da Apache u tom rewrite koraku pristupi fajl sistemu i proveri da li fajl, odnosno dir postoji... znaci usporava se rad, pogotovo ako ima dosta fajlova...

naravoucenije, gledajte uvek da vam pravila sa -f i -d budu pri kraju spiska, ili jos bolje da budu negde u nekom subdirektorijumu u zasebnom .htaccessu, tako da se pozivaju samo kad stvarno treba, a ne da se ta provera vrsi za svaku mogucu stranicu...

Takodje te provere mogu obicno da se rese upotrebom custom 404 handlera...naprosto ako trazeni fajl postoji bice pokrenut, a ako ne bice pozvana zadata skripta da handluje 404.. ona samo treba da posalje header sa 200 OK statusom, da ne bi browser slucajno dao Not Found upozorenje, i da uradi sta god treba da uradi...ovakav nacin je manje flexibilan (za nijansu), ali je dosta efikasniji u smislu perfomansi ( a i ne zahteva mod_rewrite)...

zextra 06. 12. 2005. 18:45

citao sam o tom pristupu, ali sam se odlucio da zadrzim ovakav nacin, jer je, kao sto si sam rekao, malo flexibilniji.

mada, mozda sam samo lenj da menjam nesto sto vec radi posao. :)
generalno, tamo gde ovaj cms bude radio, nece biti bas puno direktnih poziva fajlovima, izuzev slika, koje ce verovatno stajati u jednom folderu sa htaccess rewriteengine off opcijom, ili necim slicnim.


Vreme je GMT +2. Trenutno vreme je 08:15.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.