Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Архив Flasher.ru > Программирование > PHP

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему  
Старый 23.12.2003, 14:12
koox вне форума Посмотреть профиль Отправить личное сообщение для koox Посетить домашнюю страницу koox Найти все сообщения от koox
  № 1  
koox

Регистрация: Feb 2001
Адрес: Екатеринбург
Сообщений: 18
По умолчанию Проверка данных с сервера

День добрый всем!
Трабл такой: как мне проверить, откуда пришли данные - с моего сервака или нет?
То есть, данные из формы, расположенной на http://myservak.com, к скрипту myscript.php, должны обрабатываться и использоваться дальше, а из формы (такой же), лежащей на любом другом сервере и заполненной, не обрабатывались вообще?
Какая проверка должна быть в myscript.php?
Сорри за путанность ;-(
__________________
Если в вене у торчка появилась дырочка - знать, того торчка пора отправлять до доктора...

Старый 23.12.2003, 14:34
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 2  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Ответ: ты не должен этого хотеть. Если интересно -- могу объяснить причины.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 23.12.2003, 14:42
juggy вне форума Посмотреть профиль Отправить личное сообщение для juggy Посетить домашнюю страницу juggy Найти все сообщения от juggy
  № 3  
juggy
 
Аватар для juggy

Регистрация: Feb 2001
Адрес: LJ/~aleshru
Сообщений: 4,778
Отправить сообщение для juggy с помощью ICQ Отправить сообщение для juggy с помощью MSN Отправить сообщение для juggy с помощью Yahoo Отправить сообщение для juggy с помощью Skype™
PHP код:
<?
// ©2003 Authors Mitya Aleshkovsky [email]mitya@127.ru[/email]

    
$var=stripslashes(strip_tags($HTTP_POST_VARS['testvar']));
    
$from=$HTTP_SERVER_VARS['HTTP_REFERER'];

    if(!isset(
$var))
    {
    echo 
"<form method=post action=\"".$PHP_SELF."\">\n<input type=\"text\" name=\"testvar\">\n</form>\n";
    }else{
        if(!isset(
$from))
        {
            echo 
"Не понятно вообще откуда были переданы данные.";
        }
        else
        {
        
            
$from=parse_url($from);
            if(
stristr($from['host'],"myservak.com"))
            {
                echo 
"Переменная пришла именно с MyServak.com";
            }
            else
            {
                echo 
"Переменная пришла не понятно откуда.";
            }
        }

    }

?>
__________________
Что за дурь? 50 символов в подписи!?

Старый 23.12.2003, 14:51
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 4  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Какая наивность.

PHP код:
$ch curl_init (); 
...
curl_setopt($ch,CURLOPT_REFERER'http://myservak.com/form.html');
...
$result curl_exec ($ch); 
... 
Кстати, читая данный конкретный код проверки я нашел способ хакнуть его даже без использования серверных скриптов.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++


Последний раз редактировалось Crazy; 23.12.2003 в 14:53.
Старый 23.12.2003, 14:57
juggy вне форума Посмотреть профиль Отправить личное сообщение для juggy Посетить домашнюю страницу juggy Найти все сообщения от juggy
  № 5  
juggy
 
Аватар для juggy

Регистрация: Feb 2001
Адрес: LJ/~aleshru
Сообщений: 4,778
Отправить сообщение для juggy с помощью ICQ Отправить сообщение для juggy с помощью MSN Отправить сообщение для juggy с помощью Yahoo Отправить сообщение для juggy с помощью Skype™
ну да.
ещё можно
PHP код:
@fputs($fp"GET ".$uri["path"].$uri["query"]." HTTP/1.0\r\nHost: ".$uri["host"]."\r\nUser-Agent: NaebExplorer\r\nReferer: http://myservak.com\r\n\r\n"); 
А есть ли реальные способы это обойти?
__________________
Что за дурь? 50 символов в подписи!?


Последний раз редактировалось juggy; 23.12.2003 в 14:59.
Старый 23.12.2003, 15:03
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 6  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Реальных способов обойти -- нет. Можно защититься от тупой пионерской установки формы, адресующей чужой скрипт. В этом подойдет твой скрипт, если исправить в нем ошибку.

Далее: есть мнение, что произошла подмена задач и на само деле требуется нечто иное, а не именно защита от поста с другого сайта.

P.S. Тестовый пример:

PHP код:
<?php
$from 
'http://myservak.com.foobar.ru/form.html';
$from=parse_url($from);
if(
stristr($from['host'],"myservak.com"))
  echo 
"Переменная пришла именно с MyServak.com";
else
  echo 
"Переменная пришла не понятно откуда.";
?>
Думаю, исправить будет несложно.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 23.12.2003, 21:22
koox вне форума Посмотреть профиль Отправить личное сообщение для koox Посетить домашнюю страницу koox Найти все сообщения от koox
  № 7  
koox

Регистрация: Feb 2001
Адрес: Екатеринбург
Сообщений: 18
Спасибо большое! Сейчас посмотрю ваш код, есличего не пойму - поспрошаю еще чуток, ОК?
А насчет неправильно поставленной задачи - согласен целиком и полностью, может я чего не так объяснил, сорри еще раз!
Просто мне нужно, чтоб скриптик мой рассматривал переменные, пришедшие только из МОЕЙ формы (лежащей на моем серваке), а со всех остальных - нет. А то и выводил чего в браузере ;-)
__________________
Если в вене у торчка появилась дырочка - знать, того торчка пора отправлять до доктора...

Старый 23.12.2003, 21:28
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 8  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Цитата:
Оригинал написал(а) koox
пришедшие только из МОЕЙ формы
Ты все перепутал. Никакие переменные из ТВОЕЙ формы не приходят. Они приходят из браузера пользователя.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 24.12.2003, 02:55
koox вне форума Посмотреть профиль Отправить личное сообщение для koox Посетить домашнюю страницу koox Найти все сообщения от koox
  № 9  
koox

Регистрация: Feb 2001
Адрес: Екатеринбург
Сообщений: 18
Да, верно, sorry again. Они должны приходить вообще из флэшки, которая ембэдится, например, в flash.html. То, что данные были внесены в форму во флэше, что лежит на моем серваке, я могу проверить? Переменные уходят к пхп-шному скрипты, который их обрабатывает и пишет что-либо на сервере в файл. А так получается, что разобрав пары переменная-значение и зная адрес скрипта, проще простого положить на лябой сервак форму, назвать поля, как надо и в экшне написать хттп://ля-ля.ком/скрипт.пхп, ГЕТ - и вуаля! А это не есть гуд ;-(
__________________
Если в вене у торчка появилась дырочка - знать, того торчка пора отправлять до доктора...

Старый 24.12.2003, 09:56
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 10  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Цитата:
Оригинал написал(а) koox
Д А это не есть гуд ;-(
Для начала определимся: чем конкретно тебе это не нравится?
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Создать новую тему   Часовой пояс GMT +4, время: 06:00.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 06:00.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.