it-roy-ru.com

Как перенаправить http на https в codeigniter

Точка # 1 Если я наберу:

www.myurl.com/somepage
http://www.myurl.com/somepage
http://myurl.com/somepage
https://myurl.com/somepage

перенаправить на

https://www.myurl.com/somepage

Точка № 2

When I type in something like www.myurl.com it is redirecting to https://www.myurl.com/index.php.
Make it so the index.php is not displaying. It should just display https://www.myurl.com

Из комментария htaccess

RewriteEngine On 
RewriteCond %{HTTP_Host} ^myhost\.com$ [NC] 
RewriteRule ^(.*)$ myhost.com/$1 [R=301,L] 
RewriteCond %{THE_REQUEST} ^[A-Z]+\ /index\.php(/[^\ ]*)?\ HTTP/ 
RewriteRule ^index\.php(/(.*))?$ myhost.com/$2 [R=301,L] 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteRule ^(.*)$ index.php/$1 [L] 
13
asiya khan

Теперь у меня есть решение, Я обновил свой файл htaccess .--

RewriteEngine On
RewriteCond %{HTTPS} off [OR]
RewriteCond %{HTTP_Host} !^www\. [OR]
RewriteCond %{HTTP_Host} ^myhost\.com$ [NC]
RewriteRule ^ https://www.myhost.com%{REQUEST_URI} [R=301,L,NE]
RewriteCond %{THE_REQUEST} ^[A-Z]+\ /index\.php(/[^\ ]*)?\ HTTP/ 
RewriteRule ^index\.php(/(.*))?$ myhost.com/$2 [R=301,L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php/$1 [L]

Теперь это сработало для меня гладко .. :)

4
asiya khan

Пожалуйста, проверьте это может помочь

Изменения конфигурации: - Перейдите в «application/config/config.php» и включите или установите хуки в true.

$config['enable_hooks'] = TRUE;

создайте новый файл с именем hooks.php в «application/config/hooks.php» и добавьте следующий код в hooks.php: -

$hook['post_controller_constructor'][] = array(
                                'function' => 'redirect_ssl',
                                'filename' => 'ssl.php',
                                'filepath' => 'hooks'
                                );

Теперь создайте новый каталог с именем «hooks» в каталоге приложения, а затем создайте новый файл с именем «ssl.php» в «application/hooks/ssl.php» И добавьте следующий код в «ssl.php»: -

function redirect_ssl() {
    $CI =& get_instance();
    $class = $CI->router->fetch_class();
    $exclude =  array('client');  // add more controller name to exclude ssl.
    if(!in_array($class,$exclude)) {
      // redirecting to ssl.
      $CI->config->config['base_url'] = str_replace('http://', 'https://', $CI->config->config['base_url']);
      if ($_SERVER['SERVER_PORT'] != 443) redirect($CI->uri->uri_string());
    } 
    else {
      // redirecting with no ssl.
      $CI->config->config['base_url'] = str_replace('https://', 'http://', $CI->config->config['base_url']);
      if ($_SERVER['SERVER_PORT'] == 443) redirect($CI->uri->uri_string());
    }
}
15
Preetham Hegde

Я пытался прежде всего, но они не работали должным образом в моем случае. Я нашел решение ниже, оно работает в моем случае. Я надеюсь, что это будет полезно и для вас.

RewriteEngine on

RewriteCond %{HTTPS} off
RewriteRule (.*) https://%{HTTP_Host}%{REQUEST_URI} [R=301,L]

RewriteCond $1 !^(index\.php|resources|robots\.txt|public)
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?/$1 [QSA,L]
8
Nioya

Сначала перейдите в файл application/config/config.php и найдите следующую строку:

$config['base_url'] = "";

Установите его на свой URL с помощью https, например. https://example.com 

$config['base_url'] = "https://example.com";

Затем перейдите к своему файлу .htaccess и добавьте эту строку в приведенном ниже примере.

RewriteRule ^ (. *) $ https://example.com/ $ 1 [R, L]

<IfModule mod_rewrite.c>

    #Options +FollowSymLinks
    #Options -Indexes
    RewriteEngine on

    # Send request via index.php
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule ^(.*)$ index.php/$1 [L]
    RewriteRule ^(.*)$ https://example.com/$1 [R,L]


</IfModule>
0
Oteng Kwame

да, действительно, это

   RewriteEngine On
   RewriteCond %{HTTPS} off [OR] 
   RewriteCond %{HTTP_Host} !^www\. [OR]
   RewriteCond %{HTTP_Host} ^myhost\.com$ [NC]
   RewriteRule ^ https://www.myhost.com%{REQUEST_URI} [R=301,L,NE]
   RewriteCond %{THE_REQUEST} ^[A-Z]+\ /index\.php(/[^\ ]*)?\ HTTP/ 
   RewriteRule ^index\.php(/(.*))?$ myhost.com/$2 [R=301,L]
   RewriteCond %{REQUEST_FILENAME} !-f
   RewriteCond %{REQUEST_FILENAME} !-d
   RewriteRule ^(.*)$ index.php/$1 [L]

работает, но вы должны сделать небольшое редактирование. В файле codeiginiterfolder/application/config.php замените http на https

Кроме того, базовый URL в приведенном выше коде вы должны заменить myhost на ваше имя хоста. Предположим, мое имя хоста internetseekho.com, так что вместо myhost у вас есть запись internetseekho.

0
interntseekho

Если вы обнаружите ошибку«Не указан входной файл»затем добавьте «?» в последней строке 

RewriteRule ^ (. *) $ Index.php /? $ 1 [L]

в ответе @asiya khan

0
hitesh balyan

для меня ни один из приведенных выше ответов не сработал, поскольку он показывал мне слишком много перенаправлений, но этот сработал как шарм. Поэтому я подумал поделиться, если кто-то еще попадет в подобную проблему:

RewriteEngine on

RewriteCond %{HTTPS} off
RewriteCond %{REQUEST_URI} (sale|success|cancel) [NC]
RewriteRule ^(.*)$ https://%{HTTP_Host}%{REQUEST_URI} [R=301,L]

RewriteCond %{HTTPS} on
RewriteCond %{REQUEST_URI} !(static|sale|success|cancel) [NC]
RewriteRule ^(.*)$ http://%{HTTP_Host}%{REQUEST_URI} [R=301,L]

RewriteCond $1 !^(index\.php|resources|robots\.txt|static) [NC]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php/$1 [L,QSA]
0
harshal lonare

Наш SSL взят из CloudFlare CDN, поэтому приведенные выше решения не работают. 

Следующий код обнаружения SSL (в SSL.php на основе решения @Preetham Hegde) работает:

$isSecure = false;
if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') {
    $isSecure = true;
}
elseif (!empty($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https' || !empty($_SERVER['HTTP_X_FORWARDED_SSL']) && $_SERVER['HTTP_X_FORWARDED_SSL'] == 'on') {
    $isSecure = true;
}
$REQUEST_PROTOCOL = $isSecure ? 'https' : 'http';


if ($REQUEST_PROTOCOL=="http")
{
    $redirect = 'https://' . $_SERVER['HTTP_Host'] . $_SERVER['REQUEST_URI'];
    header('HTTP/1.1 301 Moved Permanently');
    header('Location: ' . $redirect);
    exit();
}
0
James