Heim > Backend-Entwicklung > PHP-Tutorial > Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

WBOY
Freigeben: 2016-08-31 08:54:52
Original
2054 Leute haben es durchsucht

Frage: Da ich das Programm bereits auf das Slim-Framework migriert habe, habe ich es tatsächlich mitRedirect auf der vorherigen dynamischen Adresse gemacht. Der Code lautet wie folgt:

<code class="php"><?php

namespace Ts\Middleware;

use Psr\Http\Message\RequestInterface as Request;
use Psr\Http\Message\ResponseInterface as Response;
use Interop\Container\ContainerInterface;

/**
 * 兼容的地址,将原有的动态地址转化为伪静态地址
 *
 * @package default
 * @author 
 **/
class CompatibleURL
{
    protected $ci;

    public function __construct(ContainerInterface $ci) {
        $this->ci = $ci;
    }

    /**
     * Compatible URL middleware invokable class.
     *
     * @param  \Psr\Http\Message\RequestInterface  $request  PSR7 request
     * @param  \Psr\Http\Message\ResponseInterface $response PSR7 response
     * @param  callable                            $next     Next middleware
     * @return \Psr\Http\Message\ResponseInterface
     * @author Seven Du <lovevipdsw@outlook.com>
     **/
    public function __invoke(Request $request, Response $response, callable $next)
    {
        $app = $request->getQueryParam('app');
        $mod = $request->getQueryParam('mod');
        $act = $request->getQueryParam('act');

        $param = [];

        if ($app !== null) {
            $param['app'] = $app;
        }

        if ($mod !== null) {
            $param['controller'] = $mod;
        }

        if ($act !== null) {
            $param['action'] = $act;
        }

        $router = $this->ci->get('router');
        $queryParam = $request->getQueryParams();

        unset($queryParam['app'], $queryParam['mod'], $queryParam['act']);

        $uri = $router->pathFor('apps', $param, $queryParam);

        if ($uri != $router->pathFor('apps', [], $queryParam)) {
            // permanently redirect paths with a trailing slash
            // to their non-trailing counterpart
            return $response->withRedirect((string) $uri, 301);
        }

        return $next($request, $response);
    }
} // END class CompatibleURL
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Und viele asynchrone Anfragen werden gesendet, nachdem 301 an die neue Adresse gesendet wurde, wie in der Abbildung gezeigt:
Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

Ich erinnere mich, dass die Umleitung Postdaten übertragen kann, aber wie wäre es im Slim-Modus mit der Einstellung über die Antwort? konsultieren!
Vielen Dank?!

Antwortinhalt:

Frage: Da ich das Programm bereits auf das Slim-Framework migriert habe, habe ich es tatsächlich mitRedirect auf der vorherigen dynamischen Adresse gemacht. Der Code lautet wie folgt:

<code class="php"><?php

namespace Ts\Middleware;

use Psr\Http\Message\RequestInterface as Request;
use Psr\Http\Message\ResponseInterface as Response;
use Interop\Container\ContainerInterface;

/**
 * 兼容的地址,将原有的动态地址转化为伪静态地址
 *
 * @package default
 * @author 
 **/
class CompatibleURL
{
    protected $ci;

    public function __construct(ContainerInterface $ci) {
        $this->ci = $ci;
    }

    /**
     * Compatible URL middleware invokable class.
     *
     * @param  \Psr\Http\Message\RequestInterface  $request  PSR7 request
     * @param  \Psr\Http\Message\ResponseInterface $response PSR7 response
     * @param  callable                            $next     Next middleware
     * @return \Psr\Http\Message\ResponseInterface
     * @author Seven Du <lovevipdsw@outlook.com>
     **/
    public function __invoke(Request $request, Response $response, callable $next)
    {
        $app = $request->getQueryParam('app');
        $mod = $request->getQueryParam('mod');
        $act = $request->getQueryParam('act');

        $param = [];

        if ($app !== null) {
            $param['app'] = $app;
        }

        if ($mod !== null) {
            $param['controller'] = $mod;
        }

        if ($act !== null) {
            $param['action'] = $act;
        }

        $router = $this->ci->get('router');
        $queryParam = $request->getQueryParams();

        unset($queryParam['app'], $queryParam['mod'], $queryParam['act']);

        $uri = $router->pathFor('apps', $param, $queryParam);

        if ($uri != $router->pathFor('apps', [], $queryParam)) {
            // permanently redirect paths with a trailing slash
            // to their non-trailing counterpart
            return $response->withRedirect((string) $uri, 301);
        }

        return $next($request, $response);
    }
} // END class CompatibleURL
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Und viele asynchrone Anfragen werden gesendet, nachdem 301 an die neue Adresse gesendet wurde, wie in der Abbildung gezeigt:
Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

Wenn eine Post-Anfrage 301 oder 302 erfordert, um die Post-Daten zu übertragen?

Ich erinnere mich, dass die Umleitung Postdaten übertragen kann, aber wie wäre es im Slim-Modus mit der Einstellung über die Antwort? konsultieren!
Vielen Dank?!

Ich verstehe es nicht, aber 30X sollte eine Serverumleitung darstellen. Es sollte keinen Zweifel daran geben, dass dieser Statuscode von der Serverantwort stammt. PHP kann über die Header-Funktion eingestellt werden.

Sollten diese Parameter zunächst vor 301 oder danach verarbeitet werden? Ein gutes Design sollte darin bestehen, vor 301 zu verarbeiten. Führen Sie nach der Verarbeitung eine Umleitung durch und zeigen Sie die relevante Ergebnisseite nur mit den erforderlichen Abfrageparametern an , nein Sie sollten die POST-Parameter nicht mehr abrufen, sondern die Ergebnisse direkt basierend auf den Abfrageparametern anzeigen.

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage