Drupal - защищает данные форм от взлома - PullRequest
0 голосов
/ 05 октября 2010
function simple_form($form_state) {
  $form['item'] = array('#type' => 'hidden', '#value' => 'some_value');
  $form['#action'] = 'http://external-website.com/';
  $form['submit'] = array(
    '#type' => 'submit',
  );
  return $form;
}

Простая форма в Drupal, вызывается с помощью drupal_get_form(simple_form).

К сожалению, действительно легко изменить значение 'item' на другое значение в форме, а затем отправить это значениевнешний сайт.

Насколько я пытался, невозможно проверить форму перед тем, как она покинет мой сайт.

function simple_form_validate() и отправить ее никогда не получат.* Как я могу предотвратить это?Установить действие для внутренней функции, а затем отправить его после проверки?Как мне это сделать?

К сожалению, настройка

$form['item'] = array('#type' => 'value', '#value' => 'some_value');

не работает?Внешний сайт не получает значение для элемента.

Любой совет?

1 Ответ

1 голос
/ 05 октября 2010

Это либо / или. и это не имеет ничего общего с Drupal, но с природой HTTP POST.

Либо вы используете # type => value, и Drupal сохраняет свое хранилище вне формы, внутри Drupal, через сеанс, Или вы отправляете сообщение на внешний сервер, и в этом случае внутреннее хранилище сеанса не может помочь.

Система безопасности Drupals в API форм опирается на тот факт, что Drupal «знает» саму точную форму и, следовательно, может избежать неправильных значений, сравнивая их с исходной формой. Внешний сайт ничего не знает об исходной форме и поэтому ничего не знает о том, как ее проверить.

Вам нужно будет выполнить проверку на конце получателя POST (этого внешнего сайта), ничего другого не будет безопасным (достаточно).

Эта проверка может быть локальным сценарием, запущенным на удаленном сайте, который просто проверяет белые списки или регулярные выражения. В качестве альтернативы, этот удаленный сайт может запросить (например, через HTTP-SOAP или XMLRPC) форму на исходном Drupal-сайте, но этого будет довольно сложно достичь.

Третья альтернатива, и IMHO, самая простая, это позволить Drupal обрабатывать всю форму локально, а при проверке обрабатывать ее в ловушке submit. Там вы можете либо отправить значения на удаленный сайт безопасным способом, либо вы можете просто вставить его в базу данных или в некоторую систему спула этого удаленного сайта. В любом случае: в хуке отправки после того, как Drupal проверил форму, вы отправляете ее на удаленный сайт.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...