Forțare HTTPS folosind .htaccess - blocat în buclă de redirecționare
Site-ul meu WordPress este găzduit la example.com/wordpress și am nevoie ca tot conținutul din interior să fie accesibil doar folosind SSL.
Am creat o regulă .htaccess care redirecționează http -> https:
RewriteEngine On
RewriteRule ^/?(.*) https://%{SERVER_NAME}/wordpress/directory/$1 [R,L]
După implementarea acestei reguli, site-ul web este inaccesibil deoarece este blocat într-o buclă de redirecționare.
Ce fac greșit?
Fișierul meu .htaccess WordPress:
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /wordpress/directory/
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /wordpress/directory/index.php [L]
</IfModule>
Acesta este un răspuns întârziat, dar funcționează pentru mine:
Schimbă RewriteCond în această variantă
RewriteCond %{HTTP:X-Forwarded-Proto} !https
Ar trebui să arate astfel:
RewriteEngine On
RewriteCond %{HTTP:X-Forwarded-Proto} !https
RewriteRule ^(.*)$ https://domeniultau.com/$1 [R,L]

Acest lucru a funcționat în cele din urmă pentru mine. Poate cineva să explice de ce această RewriteCond ar funcționa atunci când RewriteCond %{HTTPS} off
nu funcționează?

Fără a fi un expert în htaccess, aș spune că îți lipsește o condiție RewriteCond
.
Verifică dacă este pe portul 80. Încearcă asta:
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^/?(.*) https://%{SERVER_NAME}/wordpress/directory/$1 [R,L]
ACTUALIZARE:
După ce am văzut întrebarea ta actualizată, cu întregul fișier .htaccess - aș face asta:
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /wordpress/directory/
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /wordpress/directory/index.php [L]
RewriteCond %{HTTPS} off
RewriteRule ^/?(.*) https://%{SERVER_NAME}/wordpress/directory/$1 [R,L]
</IfModule>
Punând condiția și regula ta sub cele standard din Wordpress.

Adăugarea acestuia în fișierul meu .htaccess nu a ajutat, încă întâmpin aceeași problemă de buclă de redirecționare.

Poți să copiezi conținutul fișierului tău htaccess? Postează-l în întrebare - voi edita răspunsul meu pentru o altă încercare!

Încearcă RewriteCond %{HTTPS} off
în loc de condiția cu server_port.

Nu a funcționat și întregul meu fișier .htaccess este deja în întrebare :)

Dacă nimic altceva - Încearcă să incluzi din nou RewriteEngine On
, deasupra răspunsului meu actualizat!

Hmm, poate asta e problema - nu am altceva decât asta în fișierul meu .htaccess

Am restaurat .htaccess la setările implicite, dar problema încă nu este rezolvată. Am actualizat întrebarea mea.

RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
Sursă https://www.godaddy.com/help/redirect-http-to-https-automatically-8828

RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://www.example.com/$1 [R,L]
sau pentru o singură pagină
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteCond %{REQUEST_URI} director
RewriteRule ^(.*)$ https://www.example.com/director/$1 [R,L]
sau poți adăuga acest cod php într-un anumit fișier
if (!isset($_SERVER['HTTPS']) || !$_SERVER['HTTPS']) { // dacă cererea nu este securizată, redirecționează către URL securizat
$url = 'https://' . $_SERVER['HTTP_HOST']
. $_SERVER['REQUEST_URI'];
header('Location: ' . $url);
exit;
}
sau poți combina regulile de rescriere WordPress cu cele SSL..
RewriteRule ^(.*)$ https://www.example.com/director/index\.php[R,L]

Site-urile web care se află în spatele balanțerilor de sarcină sau proxy-urilor inverse care suportă HTTP_X_FORWARDED_PROTO
pot fi remediate prin adăugarea următorului cod în fișierul wp-config.php
, deasupra apelului require_once:
if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')
$_SERVER['HTTPS'] = 'on';
sau prin utilizarea unui plugin
Adăugați în folderul de plugin-uri WordPress pe site-ul dvs., apoi activați-l în administrarea Plugin-urilor
<? /* Plugin Name: Set headers */
if (stripos(get_option('siteurl'), 'https://') === 0) {
$_SERVER['HTTPS'] = 'on';
// adaugă detectarea JavaScript a protocolului paginii și speră la bine!
add_action('wp_print_scripts', 'force_ssl_url_scheme_script');
}
function force_ssl_url_scheme_script() {
?>
<script>
if (document.location.protocol != "https:") {
document.location = document.URL.replace(/^http:/i, "https:");
}
</script>
<?php
}
Funcționează astfel:
http://www.exmaple.com/blog/
cătrehttps://www.exmaple.com/blog/
http://www.exmaple.com/
cătrehttps://www.exmaple.com/
