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>
Und viele asynchrone Anfragen werden gesendet, nachdem 301 an die neue Adresse gesendet wurde, wie in der Abbildung gezeigt:
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?!
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>
Und viele asynchrone Anfragen werden gesendet, nachdem 301 an die neue Adresse gesendet wurde, wie in der Abbildung gezeigt:
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.