Often search engine bots store cached information about website pages, which leads the user to a blank page or the user goes over the insecure HTTP protocol instead of the encrypted HTTPS.
For these cases there is redirection or redirect from one page of the site to other domains/pages, it can be implemented at different stages. In this material we will consider the main ways and cases!
Redirect from HTTP to HTTPS
Connecting via HTTP protocol is not considered a benchmark for secure communication for a long time, so many services already use the upgrade to HTTPS, an encrypted connection on top of the classic one.
There are rules in Apache and Nginx that allow you to manage virtual hosts and the server as a whole. To configure such an upgrade of a URL scheme from HTTP to HTTPS, you need to go to the configuration files of the virtual host and configure the traffic handling rules:
sudo nano /etc/nginx/sites-available/default
By default, the configuration file is called default, if it is different in your case, replace it. Add the configuration:
server {
listen 80;
server_name example.com;
return 301 https://$host;
}
server {
listen 443 ssl;
ssl_certificate /etc/nginx/keys/subkeys/certificate.crt;
ssl_certificate_key /etc/nginx/keys/subkeys/private.key;
ssl_protocols TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!MD5;
server_name example.com;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains";
}
data:image/s3,"s3://crabby-images/3435e/3435e8c96eebc5f1f18e0e45333a219a00cb6617" alt="Code 301"
Virtual hosts are divided into logical server blocks, where internally contain traffic handling policies. Thus, if the first block receives a network packet on port 80, which is classically HTTP, it will return a return 301 directive requiring the browser to visit the site, which will already be with the HTTPS scheme.
Note that in addition to the classic settings, a Strict-Transport-Security header is added, which gives the users' browsers a label that it is necessary to force an HTTPS connection instead of a non-secure one. This feature allows to mitigate the HTTP downgrade attack, which allows to downgrade a client connection to an insecure protocol, without authentication and integrity checks, technically by the same return 301!
Let's check the performance of our service and the previously configured redirect:
data:image/s3,"s3://crabby-images/27dd4/27dd4594c72ade0cbfa0ce6f96f991274d7ac187" alt="Test of Redirect"
However, if we don't want to send redirect codes to the user, there are great alternatives to internal redirects.
Internal Redirect
To handle traffic in nginx there is a whole array of directives that allows you to implement another redirect. In this case, the web server will redirect the request internally and process it internally, giving a correct response. The syntax of the directive is as follows:
server {
listen 80;
server_name example.com;
location / {
internal_redirect @check_antivirus;
}
location @check_antivirus {
internal;
root /var/www/html
}
location /url {
internal_redirect /newurl;
}
location /newurl {
internal;
root /var/www/html
}
}
data:image/s3,"s3://crabby-images/efde4/efde489e563245891478790adcf6414f5f4a4769" alt="Internal redirection"
In this example, when traffic comes in on the / and /url paths, an internal redirect to the other path will occur with the rest of the packet intact. For example, your request was on the path /url/new/id?customer=675 and it will become /newurl/new/new/id?customer=675. The examples indicate that you can use a named @location or path. After making the changes, don't forget to verify the configuration with the command:
sudo nginx -t
data:image/s3,"s3://crabby-images/3dc19/3dc19829dd875f5d45acf64ab0866809be5952d5" alt="Test configuration"
The redirect logic itself can be stored not only on the server, but also in passed JS/HTML forms!
Redirection via HTML/JS
To implement the redirection logic in the browser you need to use directives of the following form:
<head>
<meta http-equiv='refresh' content='0;URL=http://site.ru'/>
<head>
In fact, there is a handler in the browser that allows you to read the strings in the HTML and according to the directives perform the action, in this case, the redirect directive is embedded. Where http-equiv=‘refresh’ indicates the need to reload the page, content='0;URL=http://site.ru' after 0 seconds at a URL of the form http://site.ru.
data:image/s3,"s3://crabby-images/684cc/684cc51ab3788e3c32269e40e1d53f9c852f4c11" alt="HTML Redirect"
For JS there is a set of functions that can allow the client to connect to another resource independently, in this case the functionality is more extensive:
window.location = 'https://www.example.com';
The line represents a direct redirection without conditions, where a new connection is opened instead of an existing one. And in the second case below, a logical condition must be met, which will also redirect the user.
if (CONDITION) { window.location.href = 'https://www.example.com'; }
The possibilities on the web to control the logic of traffic processing are as extensive as possible, at every stage, from the browser and its HTML/JS handlers to the web server with directives! If you don't have sufficient resources than you can perform actions on powerful cloud servers. Serverspace provides isolated VPS / VDS servers for common and virtualize usage.
data:image/s3,"s3://crabby-images/8836b/8836b19a1a513768063298ec6132ad5c2ffdd5c0" alt="Create Server"