Cocoonフォーラム

サイト内検索
書き込みの前に以下の3点をご確認ください。
  1. 1つのトピックにつき1つの質問を書き込んでください
  2. 不具合・カスタマイズ対象ページのURLを提示高速化を無効にしてください
  3. 該当部分のキャプチャ・環境情報とともに書き込んでいただけると助かります

何を書き込んだら良いか分からない場合は、以下のテンプレートをコピペしてご利用ください。

不具合・カスタマイズ対象ページのURL:

相談内容:

不具合の発生手順:

解決のために試したこと:

※文字だけでは正しく伝わらない可能性があるため、スクショ画像の添付もお願いします。
※高速化設定をしている場合は無効にしてください。
環境情報:

※↑こちらに「Cocoon設定 → テーマ情報」にある「環境情報」を貼り付けてください。

環境情報の取得方法はこちら。
https://wp-cocoon.com/theme-report/
高速化設定を無効にするにはこちら。
https://wp-cocoon.com/theme-trouble/

フォーラム利用ガイドリンク

  1. フォーラムガイドライン
  2. よくある質問と答え(FAQ)
  3. サポート対象外のケース
  4. 原因不明の不具合用トラブルシューティング
  5. トピックにHTMLを貼り付ける方法(推奨ツール:notepad.pw
  6. 真っ白画面でのエラーメッセージの確認方法
  7. ブラウザ環境チェックツール
  8. Cocoonカスタマイズ依頼

フォーラム質問後、問題等が解決した場合は結果を書き込んでいただけると幸いです。同様の問題で調べている方には、結果が一番気になる部分となります。

PWAを有効化するとリダイレクトループ...
 
共有:
通知
すべてクリア

[解決済] PWAを有効化するとリダイレクトループが発生する

10 投稿
2 ユーザー
3 Reactions
3,588 表示
(@tanakan)
Trusted Member Registered
結合: 6年前
投稿: 28
Topic starter  

PWAを有効化するとリダイレクトループが発生し、公開しているサイトも管理画面も見られなくなります。.htaccessから

#BEGIN COCOON HTTPS REDIRECT HTACCESS
<IfModule mod_rewrite.c>
RewriteEngine on
RewriteCond %{HTTPS} !=on [NC]
RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
</IfModule>

#END COCOON HTTPS REDIRECT HTACCESS

を削除すると正常に戻りますが、PWA機能を有効化したままだと何らかの(投稿を編集した?)タイミングで再びこれが追加され、リダイレクトループが発生してしまいます。

Conoha Wingの無料独自SSL機能を利用しており、ここの説明には、自動でリダイレクトするので.htaccessにリダイレクトを書き込むとループする場合があると書かれています。上の.htaccessへの追記が入らないようにする方法はありますでしょうか?


   
わいひら reacted
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17220
 

ご連絡ありがとうございます。

よろしければ、Conoha Wingの.htaccessのリダイレクト記述を貼り付けていただいてよろしいでしょうか。
その記述があれば、挿入しないように処理を追加しようと思います。
一応、リダイレクトがあれば購入しないような仕様にはしているのですが、何かしら書式が違うもので除外されなかったのかもしれません。


   
(@tanakan)
Trusted Member Registered
結合: 6年前
投稿: 28
Topic starter  

それが、どうも.htaccessにはHTTPSへのリダイレクトは見当たらないのです。念のため貼り付けると、

<IfModule mod_rewrite.c>
RewriteEngine On
(旧サイトからのページごとの転送を行うための記述省略)
RewriteRule ^(.*)\.html$ $1/ [R=301,L]
</IfModule>


<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType text/css "access plus 1 weeks"
ExpiresByType application/javascript "access plus 1 weeks"
ExpiresByType text/javascript "access plus 1 weeks"
ExpiresByType image/gif "access plus 1 weeks"
ExpiresByType image/jpeg "access plus 1 weeks"
ExpiresByType image/png "access plus 1 weeks"
ExpiresByType image/svg "access plus 1 weeks"
ExpiresByType image/x-icon "access plus 1 weeks"
</IfModule>

#SITEGUARD_PLUGIN_SETTINGS_START
#==== SITEGUARD_RENAME_LOGIN_SETTINGS_START
<IfModule mod_rewrite.c>
RewriteEngine on
RewriteBase /
RewriteRule ^wp-signup\.php 404-siteguard [L]
RewriteRule ^wp-activate\.php 404-siteguard [L]
RewriteRule ^login_30561(.*)$ wp-login.php$1 [L]
</IfModule>
#==== SITEGUARD_RENAME_LOGIN_SETTINGS_END
#SITEGUARD_PLUGIN_SETTINGS_END

# BEGIN WordPress
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>

# END WordPress

となっています。どういうわけかこれでhttpからhttpsへの自動転送が行われています。.htaccessではない何かで転送をしているように思われるのですが、何が使われているのかはわかりません。このあたりかもしれないのですが。

PWAを有効化すると#BEGIN COCOON HTTPS REDIRECT HTACCESSから#END COCOON HTTPS REDIRECT HTACCESSまでが挿入されるのが仕様なのですね。それなら、RewriteCond %{HTTPS} !=on [NC]に条件を追加してなんとか回避できないか試してみます。ここに書いてあるものなどが試してご報告します。


   
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17220
 

この部分は、自前で記入した部分ですか?

<IfModule mod_rewrite.c>
RewriteEngine On
(旧サイトからのページごとの転送を行うための記述省略)
RewriteRule ^(.*)\.html$ $1/ [R=301,L]
</IfModule>

ここがリダイレクトっぽいけど。.htmlのっぽいし。

RewriteRule ^(.*)\.html$ $1/ [R=301,L]

   
(@tanakan)
Trusted Member Registered
結合: 6年前
投稿: 28
Topic starter  

はい、そこは自前です。元のサイトでは末尾が.htmlだったポストを末尾/にしました。あと多少名前を変えたポストを列挙してあります。基本的にURLの最後の部分だけの書き換えで、httpをhttpsに書き換えたりはしていません。

二行追加して

#BEGIN COCOON HTTPS REDIRECT HTACCESS
<IfModule mod_rewrite.c>
RewriteEngine on
RewriteCond %{HTTP:X-Forwarded-Proto} !=https
RewriteCond %{HTTP:CloudFront-Forwarded-Proto} !=https
RewriteCond %{HTTPS} !=on [NC]
RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
</IfModule>

#END COCOON HTTPS REDIRECT HTACCESS

にしたらリダイレクトループにならなくなりました。


   
わいひら reacted
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17220
 

はい、そこは自前です。

だとしたら、Conoha Wingのものでは確実にないですね。
そしたら、確かに参考にする書き込みはたしかになさそう。

二行追加

コード、ありがとうございます!
僕の環境でも、動作確認しましたが、これで全く問題ありませんでした。
PWA化の際に、このコードを利用したものに修正しておきました。
https://qiita.com/kawaz/items/5e96dae9686e3ac402fe

一応修正版はこちら。

https://github.com/yhira/cocoon
最新ファイルをダウンロードする場合は、上記ページのダウンロードボタンからzipファイルをダウンロードしてください。


   
(@tanakan)
Trusted Member Registered
結合: 6年前
投稿: 28
Topic starter  

ありがとうございます。Githubからダウンロードしたものは無事ループせず動作しています。

これに関連してもう一点お願いがあります。さきほど、動作の確認のため「PWAを有効化する」にチェックを入れて「変更をまとめて保存」、チェックを外して「変更をまとめて保存」を繰り返してみたところ、それは正常に動作したのですが、.htaccessに

# END WordPress




























#BEGIN COCOON HTTPS REDIRECT HTACCESS

<IfModule mod_rewrite.c>

RewriteEngine on

RewriteCond %{HTTP:X-Forwarded-Proto} !=https

RewriteCond %{HTTP:CloudFront-Forwarded-Proto} !=https

RewriteCond %{HTTPS} !=on [NC]

RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]

</IfModule>




#END COCOON HTTPS REDIRECT HTACCESS

のようにスペースが大きく入ってしまいました(# END WordPressから#BEGIN COCOON HTTPS REDIRECT HTACCESSの間に9行空行がある)。どうもオンオフを一度行うたび改行が一個増えるようです。機能的には問題はないのですが、ご確認いただければ幸いです。


   
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17220
 

改行問題も修正しておきました。

https://github.com/yhira/cocoon


   
(@tanakan)
Trusted Member Registered
結合: 6年前
投稿: 28
Topic starter  

改行が増えなくなりました。ありがとうございます。


   
わいひら reacted
わいひら
(@yhira)
Illustrious Memberサイト Admin
結合: 7年前
投稿: 17220
 

動作確認ありがとうございます ? 


   
共有:

問題の解決に至った場合には、トピック冒頭の「解決済み」をクリックしていただけますと幸いです。

また、有用な回答があった場合は返信右下にある「いいね!」もご活用ください。回答者の励みになります。

「いいね!」機能はフォーラム登録者のみが利用できる機能です。

CC BY-ND 2.1)準じていれば(リンクを貼っていただければ)転載も自由です。カスタマイズ記事を書く際にコード等をコピペ利用していただいて構いません。

フォーラムの使い方がよくわからない場合は、テストトピックで自由にテストしていただいて構いません。

最近の書き込みはこちら。

詳細なカスタマイズ依頼をするならこちら。

タイトルとURLをコピーしました