調査履歴

Webデザイン

カテゴリー: HTML5  閲覧数:452 配信日:2015-04-02 22:04


当初予定


ファイル存在確認後、条件分岐
・file_exists()関数で、ファイル存在確認後、条件分岐しようと考えていた


問題発生


いざコーディング開始してみると
・パスは正しいのに期待した通り条件分岐しないことに気が付く
・ファイル存在しているのに全く認識してくれない

調査した結果判明した事実
・セーフモードではファイル操作系関数が使用不可
・getimagesize関数とか色々試すも、全滅

セーフモード環境下でのファイル存在確認
・こんなに難易度高いとは夢にも思わなかったよ

CGIモードへは変更したくない
・CGIモードへ変更すれば動作することは分かっているが、他への影響を考慮すると変更したくない


JSでファイル確認


最初に試した方法
・目的は達成できたが、コンソールにエラーが表示されまくっている
<script>
 function filesize (url) {
 // http://kevin.vanzonneveld.net
 // +   original by: Enrique Gonzalez
 // +      input by: Jani Hartikainen
 // +   improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
 // +   improved by: T. Wild
 // %        note 1: This function uses XmlHttpRequest and cannot retrieve resource from different domain.
 // %        note 1: Synchronous so may lock up browser, mainly here for study purposes.
 // *     example 1: filesize('http://kevin.vanzonneveld.net/pj_test_supportfile_1.htm');
 // *     returns 1: '3'
 var req = this.window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest();
 if (!req) {
   throw new Error('XMLHttpRequest not supported');
 }

 req.open('HEAD', url, false);
 req.send(null);

 if (!req.getResponseHeader) {
   try {
     throw new Error('No getResponseHeader!');
   } catch (e) {
     return false;
   }
 } else if (!req.getResponseHeader('Content-Length')) {
   try {
     throw new Error('No Content-Length!');
   } catch (e2) {
     return false;
   }
 } else {
   return req.getResponseHeader('Content-Length');
 }
}
</script>

<td>
 <?php $targetPath = "/img/".$user['img_sample2']; ?>
 <script>
   var gazou = "<?php echo $targetPath; ?>";
   imgsize = filesize(gazou);
   if(imgsize >300) {
     document.write('<a href="<?php echo $this->escape($user['url']); ?>"><img src="<?php echo $targetPath; ?>" alt=""></a>');
   }
 </script>
</td>


週間人気ページランキング / 4-13 → 4-19
順位 ページタイトル抜粋 アクセス数
1 16進数カラーコード / 2進数 28
2 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 15
3 RGB ⇔ Lab | 色変換(色) 13
4 Design 0 11
4 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 11
5 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 10
6 RGBの種類 / ビットカラー | RGB(色) 9
7 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 7
8 「z-index」効果を打ち消すスタイルシートは、「z-index:auto;」 6
8 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 6
9 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 5
9 「bgcolor」「background-color」「background」の違い | CSS 5
10 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 3
10 「Google Chrome」の文字が突然ギザギザで表示されるようになったら、「chrome://flags/#top-chrome-md」へアクセス後、右上の「Reset all」ボタンをクリックします。 | Google Chrome(ブラウザ) 3
10 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 3
11 カラーコード / 色コード | カラーコード(色) 2
11 「Create Link」代替拡張機能を探した結果は、「CopyTabTitleUrl」でした。 | CopyTabTitleUrl(Chrome 拡張機能) 2
11 イラスト素材 | デザイン 2
11 HTML5でiframeスクロールバーを表示しない方法が不明 | HTML5(HTML) 2
11 HSLとHSVの違い | 色変換(色) 2
2024/4/20 1:01 更新
指定期間人気ページランキング / 2020-5-30 → 2024-4-19
順位 ページタイトル抜粋 アクセス数
1 RGB ⇔ Lab | 色変換(色) 8125
2 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 4344
3 血の色 / #b30000 / #360800 / #ff0000 | 色 3476
4 Design 0 3399
5 RGBの種類 / ビットカラー | RGB(色) 2443
6 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2340
7 「bgcolor」「background-color」「background」の違い | CSS 1770
8 コズミックブルーが何色か分からない | 色 1697
9 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 1696
10 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 1526
11 「属性」「プロパティ」「アトリビュート」の違い | CSS 1524
12 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 1457
13 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 1413
14 16進数カラーコード / 2進数 1386
15 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 1224
16 HSLとHSVの違い | 色変換(色) 1130
17 使用していないCSSをチェックする、標準的な方法を知りたい | CSS 1008
18 黒体 / 色温度 / D65(6500K)/ D50(5000K)/ K | 色 965
19 「:after擬似要素」は、Chromeの「要素を検証」で確認できない | 擬似(CSS) 956
20 GIFアニメーション | 画像 912
2024/4/20 1:01 更新