aboutsummaryrefslogtreecommitdiff
path: root/files/pt-br/web/http/redirecionamento/index.html
diff options
context:
space:
mode:
authorPeter Bengtsson <mail@peterbe.com>2020-12-08 14:42:52 -0500
committerPeter Bengtsson <mail@peterbe.com>2020-12-08 14:42:52 -0500
commit074785cea106179cb3305637055ab0a009ca74f2 (patch)
treee6ae371cccd642aa2b67f39752a2cdf1fd4eb040 /files/pt-br/web/http/redirecionamento/index.html
parentda78a9e329e272dedb2400b79a3bdeebff387d47 (diff)
downloadtranslated-content-074785cea106179cb3305637055ab0a009ca74f2.tar.gz
translated-content-074785cea106179cb3305637055ab0a009ca74f2.tar.bz2
translated-content-074785cea106179cb3305637055ab0a009ca74f2.zip
initial commit
Diffstat (limited to 'files/pt-br/web/http/redirecionamento/index.html')
-rw-r--r--files/pt-br/web/http/redirecionamento/index.html260
1 files changed, 260 insertions, 0 deletions
diff --git a/files/pt-br/web/http/redirecionamento/index.html b/files/pt-br/web/http/redirecionamento/index.html
new file mode 100644
index 0000000000..c429ac82cb
--- /dev/null
+++ b/files/pt-br/web/http/redirecionamento/index.html
@@ -0,0 +1,260 @@
+---
+title: Redirecionamentos em HTTP
+slug: Web/HTTP/Redirecionamento
+tags:
+ - Guía
+ - HTTP
+ - Redirecionamento
+translation_of: Web/HTTP/Redirections
+---
+<div>{{HTTPSidebar}}</div>
+
+<p class="summary">Redirecionamento de URL, também conhecido como encaminhamento de URL, é uma técnica que à uma página, formulário ou uma aplicação web inteira, mais de um endereço de URL. HTTP fornece uma espécie especial de respostas, <em><strong>HTTP redirects</strong></em>,  executar esta operação é utilizada para vários objetivos: redirecionamento temporário enquanto está sendo feita a manutenção do web site, redirecionamento permanente para manter links externos funcionando após alterações na arquitetura do web site, páginas de progresso enquanto é feito o envio de um arquivo, e assim por diante.</p>
+
+<h2 id="Princípio">Princípio</h2>
+
+<p>Em HTTP, um redirecionamento é acionado pelo servidor enviando respostas especiais para uma solicitação: <em>redirects</em>. Os redirecionamentos HTTP são respostas com um código de status de 3xx. Um navegador, ao receber uma resposta de redirecionamento, usa o novo URL fornecido e carrega-o imediatamente: a maior parte do tempo, o redirecionamento é transparente para o usuário, além de um pequeno desempenho.</p>
+
+<p><img alt="" src="https://mdn.mozillademos.org/files/13785/HTTPRedirect.png"></p>
+
+<p>Existem vários tipos de redirecionamentos e eles se enquadram em três categorias: redirecionamentos permanentes, temporários e especiais.</p>
+
+<h3 id="Redirecionamentos_permanentes">Redirecionamentos permanentes</h3>
+
+<p>Estes redirecionamentos devem durar permanentemente. Eles implicam que o URL original não deve mais ser usado e que o novo é preferido. Os robôs dos mecanismos de pesquisa desencadeiam uma atualização do URL associado para o recurso em seus índices.</p>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">Code</th>
+ <th scope="col">Text</th>
+ <th scope="col">Method handling</th>
+ <th scope="col">Typical use case</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td><code>301</code></td>
+ <td><code>Movido permanentemente</code></td>
+ <td>{{HTTPMethod("GET")}} métodos inalterados.<br>
+ Outros podem ou não serem alterados para {{HTTPMethod("GET")}}.<sup><a href="#attr1">[1]</a></sup></td>
+ <td>Reorganização de um web site.</td>
+ </tr>
+ <tr>
+ <td><code>308</code></td>
+ <td><code>Permanentemente redirecionado</code></td>
+ <td>Método e corpo não alterados</td>
+ <td>Reorganização de um web site, com não-GET links/operações.</td>
+ </tr>
+ </tbody>
+</table>
+
+<p><a id="attr1" name="attr1"></a>[1]A especificação não tinha intenção de permitir mudanças de método, mas praticamente existem agentes de usuários lá fazendo isso. 308 foi criado para remover a ambiguidade do comportamento ao usar métodos não-GET.</p>
+
+<h3 id="Redirecionamentos_temporários">Redirecionamentos temporários</h3>
+
+<p>Às vezes, o recurso solicitado não pode ser acessado a partir da sua localização canônica, mas pode ser acessado a partir de outro local. Neste caso, um redirecionamento temporário pode ser usado. Os robôs do mecanismo de busca não memorizam o novo e temporário link. Os redirecionamentos temporários também são usados ao criar, atualizar e excluir recursos para apresentar páginas de progresso temporárias.</p>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">Code</th>
+ <th scope="col">Text</th>
+ <th scope="col">Method handling</th>
+ <th scope="col">Typical use case</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td><code>302</code></td>
+ <td><code>Encontrado</code></td>
+ <td>{{HTTPMethod("GET")}} métodos inalterados.<br>
+ Outros podem ou não serem alterados para {{HTTPMethod("GET")}}.<sup><a href="#attr2">[2]</a></sup></td>
+ <td>A página da Web não está temporariamente disponível por motivos imprevisíveis. Dessa forma, os motores de busca não atualizam seus links.</td>
+ </tr>
+ <tr>
+ <td><code>303</code></td>
+ <td><code>Ver outro</code></td>
+ <td>{{HTTPMethod("GET")}} Métodos inalterados.<br>
+ Outros <em>alterados</em> para <code>GET</code> (corpo perdido).</td>
+ <td>Usado para redirecionar após um {{HTTPMethod ("PUT")}} ou um {{HTTPMethod ("POST")}} para evitar uma atualização da página que reativaria a operação.</td>
+ </tr>
+ <tr>
+ <td><code>307</code></td>
+ <td><code>Redirecionamento temporário</code></td>
+ <td>Método ou corpo não alterados</td>
+ <td>A página da Web não está temporariamente disponível por motivos imprevisíveis. Dessa forma, os motores de busca não atualizam seus links. Melhor que 302 quando os links / operações não-GET estão disponíveis no site.</td>
+ </tr>
+ </tbody>
+</table>
+
+<p><a id="attr2" name="attr2"></a>[2] A especificação não tinha intenção de permitir mudanças de método, mas praticamente existem agentes de usuários lá fazendo isso. 307 foi criado para remover a ambiguidade do comportamento ao usar métodos não-GET.</p>
+
+<h3 id="Redirecionamentos_Especiais">Redirecionamentos Especiais</h3>
+
+<p>Além desses redirecionamentos usuais, existem dois redirecionamentos específicos. O {{HTTPStatus ("304")}} (Não Modificado) redireciona uma página para a cópia em cache local (que estava obsoleta) e {{HTTPStatus ("300")}} (Múltipla escolha) é um redirecionamento manual: o corpo, apresentado pelo navegador como uma página da Web, lista os possíveis redirecionamentos e o usuário clica em um para selecioná-lo.</p>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">Code</th>
+ <th scope="col">Text</th>
+ <th scope="col">Typical use case</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td><code>300</code></td>
+ <td><code>Múltipla Escolha</code></td>
+ <td>Não muitas: as opções estão listadas em uma página HTML no corpo. Poderia ser servido com um estado {{HTTPStatus ("200")}} OK.</td>
+ </tr>
+ <tr>
+ <td><code>304</code></td>
+ <td><code>Não Modificado</code></td>
+ <td>Atualização de cache: isso indica que o valor do cache ainda é recente e pode ser usado.</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="Alternative_way_of_specifying_redirections">Alternative way of specifying redirections</h2>
+
+<p>HTTP redirects aren't the only way to define redirections. There are two other methods: HTML redirections using the {{HTMLElement("meta")}} element, and JavaScript redirections using the <a href="/en-US/docs/Web/API/Document_Object_Model">DOM</a>.</p>
+
+<h3 id="HTML_redirections">HTML redirections</h3>
+
+<p>HTTP redirects are the preferred way to create redirections, but sometimes the Web developer doesn't have control over the server or cannot configure it. For these specific cases, the Web developers can craft an HTML page with a {{HTMLElement("meta")}} element and the {{htmlattrxref("http-equiv", "meta")}} attribute set to <code>refresh</code> in the {{HTMLElement("head")}} of the page. When displaying the page, the browser will find this element and will go to the indicated page.</p>
+
+<pre class="brush: html">&lt;head&gt;
+ &lt;meta http-equiv="refresh" content="0; URL=http://www.example.com/" /&gt;
+&lt;/head&gt;
+</pre>
+
+<p>The {{htmlattrxref("content")}} attribute starts with a number indicating how many seconds the browser should wait before redirecting to the given URL. Always set it to <code>0</code>, for better accessibility.</p>
+
+<p>Obviously, this method only works with HTML pages (or similar) and cannot be used for images or any other type of content.</p>
+
+<div class="note">
+<p>Note that these redirections break the back button in a browser: you can go back to a page with this header but it instantaneously moves forward again.</p>
+</div>
+
+<h3 id="JavaScript_redirections">JavaScript redirections</h3>
+
+<p>Redirections in JavaScript are created by setting a value to the {{domxref("window.location")}} property and the new page is loaded.</p>
+
+<pre class="brush: js">window.location = "http://www.example.com/";</pre>
+
+<p>Like HTML redirections, this can't work on all resources, and obviously, this will only work on clients that execute JavaScript. On the other side, there are more possibilities as you can trigger the redirection only if some conditions are met, for example.</p>
+
+<h3 id="Order_of_precedence">Order of precedence</h3>
+
+<p>With three possibilities for URL redirections, several methods can be specified at the same time, but which one is applied first? The order of precedence is the following:</p>
+
+<ol>
+ <li>HTTP redirects are always executed first when there is not even a page transmitted, and of course not even read.</li>
+ <li>HTML redirects ({{HTMLElement("meta")}}) are executed if there weren't any HTTP redirects.</li>
+ <li>JavaScript redirects are used as the last resort, and only if JavaScript is enabled on the client side.</li>
+</ol>
+
+<p>When possible, always try to use HTTP redirects, and don't use a {{HTMLElement("meta")}} element. If a developer changes the HTTP redirects and forgets the HTML redirects, redirects are no more identical or end up in an infinite loop, or other nightmares happen.</p>
+
+<h2 id="Use_cases">Use cases</h2>
+
+<p>There are numerous use cases for redirects, but as performance is impacted with every redirect, their use should be kept to a minimum.</p>
+
+<h3 id="Domain_aliasing">Domain aliasing</h3>
+
+<p>Ideally, there is one location, and therefore one URL, for one resource. But there are reasons for wanting to have alternative names for a resource (several domains, like with and without the www prefix or shorter and easy to remember URLs, …). In these cases, rather than duplicating the resource, it is useful to use a redirect to the one true (canonical) URL.</p>
+
+<p>Domain aliasing can be done for several reasons:</p>
+
+<ul>
+ <li>Expanding the reach of your site. A common case is when your site resides under the <code>www.example.com</code> domain and accessing your pages from <code>example.com</code> should be possible, too. Redirections for <code>example.com</code> pages to <code>www.example.com</code> are set up in this case. You might also provide commonly used synonym names or frequent typos of your domain names.</li>
+ <li>Moving to a different domain. For example, your company has been renamed and you when searching for the old name, you want people used to the old company Web site still find you under the new name.</li>
+ <li>Forcing HTTPS. Requests to the HTTP version of your site will be redirected to the HTTPS version of your site.</li>
+</ul>
+
+<h3 id="Keeping_links_alive">Keeping links alive</h3>
+
+<p>When you restructure Web sites, URLs of resources change. Even if you can update the internal links of your Web site to match the new naming scheme, you have no control over the URLs used by external resources. You don't want to break these links, as they bring you valuable users (and help your SEO), so you set up redirects from the old URLs to the new ones.</p>
+
+<div class="note">
+<p>Even if this technique also works for internal links, you should try to avoid having internal redirects. A redirect has a significant performance cost (as an extra HTTP request is done) and if you can avoid it by correcting internal links, you should fix these links.</p>
+</div>
+
+<h3 id="Temporary_responses_to_unsafe_requests">Temporary responses to unsafe requests</h3>
+
+<p>{{Glossary("safe", "Unsafe")}} requests modify the state of the server and the user shouldn't replay them inadvertently. Typically, you don't want your users to resend {{HTTPMethod("PUT")}}, {{HTTPMethod("POST")}} or {{HTTPMethod("DELETE")}} requests. If you just serve the response as the result of this request, a simple press of the reload button will (possibly after a confirmation message), resend the request.</p>
+
+<p>In this case, the server can send back a {{HTTPStatus("303")}} (See Other) response that will contain the right information, but if the reload button is pressed, only this page is redisplayed, without replaying the unsafe requests.</p>
+
+<h3 id="Temporary_responses_to_long_requests">Temporary responses to long requests</h3>
+
+<p>Some requests may need more time on the server like sometimes {{HTTPHeader("DELETE")}} requests that are scheduled for later processing. In this case, the response is a {{HTTPStatus("303")}} (See Other) redirect that links to a page indicating that the action has been scheduled, and eventually informs about the progress, or allows to cancel it.</p>
+
+<h2 id="Configuring_redirects_in_common_servers">Configuring redirects in common servers</h2>
+
+<h3 id="Apache">Apache</h3>
+
+<p>Redirects can be set either in the server config file or in the <code>.htaccess</code> of each directory.</p>
+
+<p>The <a href="https://httpd.apache.org/docs/current/mod/mod_alias.html">mod_alias</a> module has <code>Redirect</code> and <code>Redirect_Match</code> directives that set up a {{HTTPStatus("302")}} response (by default):</p>
+
+<pre>&lt;VirtualHost *:80&gt;
+ ServerName example.com
+ Redirect / http://www.example.com
+&lt;/VirtualHost&gt;
+</pre>
+
+<p>The URL <code>http://example.com/</code> will be redirected to <code>http://www.example.com/</code> (but not <code>http://example.com/other.html</code> )</p>
+
+<p><code>Redirect_Match</code> does the same but takes a regular expression to define a collection of URLs that are affected:</p>
+
+<pre>RedirectMatch ^/images/(.*)$ http://images.example.com/$1</pre>
+
+<p>All documents in the <code>images/</code> folder will be redirected to a different domain.</p>
+
+<p>If you don't want to set up a temporary redirect, an extra parameter (either the HTTP status code to use or the <code>permanent</code> keyword) can be used to set up a different redirect:</p>
+
+<pre>Redirect permanent / http://www.example.com
+Redirect 301 / http://www.example.com
+</pre>
+
+<p>The <a href="http://httpd.apache.org/docs/current/mod/mod_rewrite.html">mod_rewrite</a> module can also be used to create redirects. It is more flexible, but a bit more complex to use.</p>
+
+<h3 id="Nginx">Nginx</h3>
+
+<p>In Nginx, you create a specific server block for the content you want to redirect:</p>
+
+<pre>server {
+ listen 80;
+ server_name example.com;
+ return 301 $scheme://www.example.com$request_uri;
+}</pre>
+
+<p>To apply a redirect to a folder or a subset of the pages only, use the <code>rewrite</code> directive:</p>
+
+<pre>rewrite ^/images/(.*)$ http://images.example.com/$1 redirect;
+rewrite ^/images/(.*)$ http://images.example.com/$1 permanent;
+</pre>
+
+<h3 id="IIS">IIS</h3>
+
+<p>In IIS, you use the <code><a href="https://www.iis.net/configreference/system.webserver/httpredirect">&lt;httpRedirect&gt;</a></code> element to configure redirections.</p>
+
+<h2 id="Redirection_loops">Redirection loops</h2>
+
+<p>Redirection loops happen when successive redirections follow the one that has already been followed. In other words, there is a loop that will never be finished and no page will be found ultimately.</p>
+
+<p>Most of the time this is a server problem, and if the server cannot detect it, it will send back a {{HTTPStatus("500")}} <code>Internal Server Error</code>. If you encounter such an error soon after modifying a server configuration, this is likely a redirection loop.</p>
+
+<p>Sometimes, the server won't detect it: a redirection loop can spread over several servers which each don't have the full picture. In this case, browsers will detect it and post an error message. Firefox will display:</p>
+
+<pre class="bz_comment_text" id="comment_text_0">Firefox has detected that the server is redirecting the request for this address in a way that will never complete.</pre>
+
+<p>while Chrome will display:</p>
+
+<pre>This Webpage has a redirect loop</pre>
+
+<p>In both cases, the user can't do much (unless a corruption is happening on their side, like a mismatch of cache or cookies).</p>
+
+<p>It is important to avoid redirection loops as they completely break the user experience.</p>