ユーザーがコンテンツ(テキスト、画像、swfs、mp3など)を追加/編集/置換/削除できるようにするアプリケーションがあります。管理者は、キャッシュなしのヘッダーを使用して常に最新の更新ファイルを入手し、ユーザーがアプリケーションを実行すると、すべてがキャッシュを取得/使用するようにします。
私は解決策を調べ、次のようなhtmlメタタグを使用してみました。
<meta http-equiv="expires" content="0" />
<meta http-equiv="cache-control" content="no-cache, no-store" />
<meta http-equiv="pragma" content="no-cache" />
ただし、これはヘッダーが作成された後に発生し、メディア(画像、swfs、mp3など)ヘッダーを変更しないため、これは適切な解決策ではないようです。
私はapacheを使用してヘッダーを設定したかったので、このサイトのこのコードに出くわしました:
<filesMatch "\.(html|htm|js|css)$">
FileETag None
<ifModule mod_headers.c>
Header unset ETag
Header set Cache-Control "max-age=0, no-cache, no-store, must-revalidate"
Header set Pragma "no-cache"
Header set Expires "Wed, 11 Jan 1984 05:00:00 GMT"
</ifModule>
</filesMatch>
これは優れたソリューションのようですが、キャッシュが必要な場合とキャッシュすべきでない場合の唯一の本当の違いはURL(preview.jspとrun.jsp)であるため、ファイルタイプで一致させることはできません。ほとんどのファイルは同じです。
誰かがこのタイプのシナリオに適した解決策を持っていますか?
ありがとう。
編集:
Preview.jspとrun.jspは基本的に同じですが、jspとjsの処理が異なります。彼らはiframeを介して同じコンテンツとメディアを読み込みます。たとえば、それぞれ次のようになります。
<%
//Some JSP
%>
/* HTML Headers, JS, ETC */
<iframe id="contentFrame" seamless="1" src="http://somedomain.com/template.html"></iframe>
/* End HTML */
Preview.jspとrun.jspは同じディレクトリに表示され、すべて同じリソースを使用します。何もキャッシュしないpreview.jspと、キャッシュするrun.jspを持つソリューションを探しています。
サーバーはApacheTomcatでセットアップされています。