Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP] Call to undefined function unescape()
Forum PHP.pl > Forum > PHP
PawelC
Piszę skrypt którzy przykładowo sprawdzi user agenta google, jeżeli to będzie google to wyświetli tekst, a jak to niebędzie googlebot to przekieruje na inną strone, jednak mam cały czas błąd:
Cytat
Call to undefined function unescape()

Kod wygląda następująco:

  1. <?php
  2. if($_SERVER['HTTP_USER_AGENT']=='Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)' || 
  3. $_SERVER['HTTP_USER_AGENT']=='Googlebot/2.1 (+http://www.googlebot.com/bot.html)'){
  4. } else {
  5.  
  6. eval(unescape('<?
  7. $page="http://www.adres.pl/";
  8. $txt="self.location.href='".$page."'";
  9. for ($i=0; $i<strlen($txt);$i++){
  10. echo('%'.dechex(ord(substr($txt,$i,1))));
  11. }?>'));
  12.  
  13. }
  14. ?>


Najpierw wywala mi
Cytat
Parse error: syntax error, unexpected '"' in /home/exploit1/domains/exploitek.info/public_html/lol.php on line 13

A jak usune te znaki to wyskakuje mi:

Cytat
Fatal error: Call to undefined function unescape() in /home/exploit1/domains/exploitek.info/public_html/lol.php on line 11

Co jest z tym nie tak?
Whisller
PHP nie widzi funkcji o nazwie "unescape".
PawelC
No tak tylko unescape dotyczy się java script ponieważ przed znacznikami php jest <script> i skrypt działa ale gdy nie sprawdzam user agenta.
Taki kod działa normalnie:
  1. eval(unescape('<? $page="http://www.adres.pl/";
  2. $txt="self.location.href='".$page."'";
  3. for ($i=0; $i<strlen($txt);$i++){
  4. echo('%'.dechex(ord(substr($txt,$i,1))));
  5. }?>'));

A jak dodam do tego php już niedziała?
crackcomm
Kod
<script>
eval(unescape('<? $page="http://www.adres.pl/";
$txt="self.location.href='".$page."'";
for ($i=0; $i<strlen($txt);$i++){
echo('%'.dechex(ord(substr($txt,$i,1))));
}?>'));
</script>

eval(unescape(....
podejrzewam ze to nie jest pomiedzy <? a ?> tongue.gif
a
Cytat
Call to undefined function unescape()

to znaczy ze nie masz tej funkcji ;d
sniezny_wilk
Nie wczytywałem się w kod, ale jesteś pewien, że jego budowa jest poprawna ? tzn tej funkcji, np ten znak: %:

  1. eval(unescape('<?
  2. $page="http://www.adres.pl/";
  3. $txt="self.location.href='".$page."'";
  4. for ($i=0; $i<strlen($txt);$i++){
  5. echo('%'.dechex(ord(substr($txt,$i,1))));
  6. }?>'));


Jeśli chcesz wyrzucić po prostu znak %, to chyba musisz użyć \'%\'. Chyba, że to jest modulo czegoś, wtedy może '.%.' zadziała..
PawelC
Ok dałem sobie rade, kod działa tylko czemu po przekierowania na jakąś strone dorzuca mi %d%a do adresu?
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.