PHP-перенаправление и отправка данных по почте

У меня есть онлайн-шлюз, который требует отправки HTML-формы со скрытыми полями. Мне нужно сделать это через php-скрипт без каких-либо HTML-форм (у меня есть данные для скрытых полей в БД)

для этого отправьте данные через GET:

header('Location: http://www.provider.com/process.jsp?id=12345&name=John');

и для этого отправлять данные через POST?

14 ответов


вы не можете сделать это с помощью PHP.

Как говорили другие, вы можете использовать cURL-но тогда PHP-код становится клиентом, а не браузером.

Если вы должны использовать POST, то единственный способ сделать это-создать заполненную форму с помощью PHP и использовать окно.onload hook для вызова javascript для отправки формы.

С.


вот пример обходного пути.

function redirect_post($url, array $data)
{
    ?>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <script type="text/javascript">
            function closethisasap() {
                document.forms["redirectpost"].submit();
            }
        </script>
    </head>
    <body onload="closethisasap();">
    <form name="redirectpost" method="post" action="<? echo $url; ?>">
        <?php
        if ( !is_null($data) ) {
            foreach ($data as $k => $v) {
                echo '<input type="hidden" name="' . $k . '" value="' . $v . '"> ';
            }
        }
        ?>
    </form>
    </body>
    </html>
    <?php
    exit;
}

другое решение, если вы хотите избежать вызова curl и перенаправить браузер, как обычно, и имитировать вызов POST:

сохраните сообщение и сделайте временный редирект:

function post_redirect($url) {
    $_SESSION['post_data'] = $_POST;
    header('Location: ' . $url);
}

тогда всегда проверяйте переменную сеанса post_data:

if (isset($_SESSION['post_data'])) {
    $_POST = $_SESSION['post_data'];
    $_SERVER['REQUEST_METHOD'] = 'POST';
    unset($_SESSION['post_data']);
}

там будут какие-то недостающие компоненты, такие как apache_request_headers() не будет отображаться в заголовке размещать контент и т. д..


это будет включать расширение curl PHP.

$ch = curl_init('http://www.provider.com/process.jsp');
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, "id=12345&name=John");
curl_setopt($ch, CURLOPT_RETURNTRANSFER , 1);  // RETURN THE CONTENTS OF THE CALL
$resp = curl_exec($ch);

/**
 * Redirect with POST data.
 *
 * @param string $url URL.
 * @param array $post_data POST data. Example: array('foo' => 'var', 'id' => 123)
 * @param array $headers Optional. Extra headers to send.
 */
public function redirect_post($url, array $data, array $headers = null) {
    $params = array(
        'http' => array(
            'method' => 'POST',
            'content' => http_build_query($data)
        )
    );
    if (!is_null($headers)) {
        $params['http']['header'] = '';
        foreach ($headers as $k => $v) {
            $params['http']['header'] .= "$k: $v\n";
        }
    }
    $ctx = stream_context_create($params);
    $fp = @fopen($url, 'rb', false, $ctx);
    if ($fp) {
        echo @stream_get_contents($fp);
        die();
    } else {
        // Error
        throw new Exception("Error loading '$url', $php_errormsg");
    }
}

я нашел лучшее и более аккуратное решение, поэтому я подумал, что должен поделиться им:

использовать сессии:

$_SESSION['POST'] = $_POST;

и для запроса заголовка перенаправления вы должны использовать:

header('Location: http://www.provider.com/process.jsp?id=12345&name=John', true, 307;)

307 - это htttp_response_code вы можете использовать для запроса перенаправления с submitted POST значения.


используйте curl для этого. Google для "curl php post", и вы найдете это:http://www.askapache.com/htaccess/sending-post-form-data-with-php-curl.html.

обратите внимание, что вы также можете использовать массив для параметра CURLOPT_POSTFIELDS. От php.net docs:

полные данные для публикации в HTTP-операции "POST". Чтобы опубликовать файл, добавьте имя файла с @ и используйте полный путь. Это может быть передано как строка urlencoded, например 'para1=val1 & para2=val2&... или как массив с именем поле ключа и поле данных значение. Если value является массивом, заголовок Content-Type будет установлен в multipart / form-data.


кроме того, установка переменной сеанса перед перенаправлением и проверка ее в целевом url-адресе могут решить эту проблему для меня.


вы должны открыть сокет для сайта с помощью fsockopen и имитировать HTTP-Post-запрос. Google покажет вам много фрагментов, как имитировать запрос.


боюсь, для этой задачи вам понадобится завиток. Хороший простой способ сделать это здесь: http://davidwalsh.name/execute-http-post-php-curl

надеюсь, что это поможет


я использовал следующий код для захвата данных POST, которые были отправлены из формы.php, а затем объединить его на URL, чтобы отправить его обратно в форму для исправления проверки. Работает как шарм и фактически преобразует данные POST в данные GET.

foreach($_POST as $key => $value) {
   $urlArray[] =  $key."=".$value;  
}
$urlString = implode("&", $urlArray);

echo "Please <a href='form.php?".$urlString."'>go back</a>";

старый пост, но вот как я его обработал. Метод с использованием newms87 это:

if($action == "redemption")
{
    if($redemptionId != "")
    {
        $results = json_decode($rewards->redeemPoints($redemptionId));

        if($results->success == true)
        {
            $redirectLocation = $GLOBALS['BASE_URL'] . 'rewards.phtml?a=redemptionComplete';
            // put results in session and redirect back to same page passing an action paraameter
            $_SESSION['post_data'] = json_encode($results);
            header("Location:" . $redirectLocation);
            exit();
        }
    }
}
elseif($action == "redemptionComplete")
{
    // if data is in session pull it and unset it.
    if(isset($_SESSION['post_data']))
    {
        $results = json_decode($_SESSION['post_data']);
        unset($_SESSION['post_data']);
    }
    // if you got here, you completed the redemption and reloaded the confirmation page. So redirect back to rewards.phtml page.
    else
    {
        $redirectLocation = $GLOBALS['BASE_URL'] . 'rewards.phtml';
        header("Location:" . $redirectLocation);
    }
}

Да, вы можете сделать это в PHP, например, в

Silex или Symfony3

использование subrequest

$postParams = array(
    'email' => $request->get('email'),
    'agree_terms' => $request->get('agree_terms'),
);

$subRequest = Request::create('/register', 'POST', $postParams);
return $app->handle($subRequest, HttpKernelInterface::SUB_REQUEST, false);

обходной путь, который прекрасно работает :

на странице источник начните открывать сеанс и назначьте столько значений, сколько захотите. Затем выполните перемещение с помощью "header":

<!DOCTYPE html>
<html>
   <head>
       <?php
           session_start();
           $_SESSION['val1'] = val1;
           ...
           $_SESSION['valn'] = valn;
           header('Location: http//Page-to-redirect-to');
       ?>
   </head>
</html>

и затем, на странице targe:

<!DOCTYPE html>
<?php
    session_start();
?>
<html>
    ...
    <body>
        <?php
            if (isset($_SESSION['val1']) && ... && isset($_SESSION['valn'])) {
                YOUR CODE HERE based on $_SESSION['val1']...$_SESSION['valn'] values
            }
        ?>
    </body>
</html>

нет необходимости в Javascript или JQuery.. Удачи !