(追記/2013.02.24)Insert 1.3にて対応されたようですので、モジュールのアップデートのみで大丈夫です。
Drupal 7.20にアップデートした際に、本文エリアへ画像を挿入するInsertモジュールが利用できない場合の暫定的な対処法です。
セキュリティアップデートのDrupal 7.20では、画像スタイルのパスにGET変数でitokを付加するかたちになりました。
そのためInsertモジュールで画像を挿入した場合に、正しく画像を生成・表示できない状態になっています。
暫定的な対処法として「sites/default/setting.php」に、次の1行を追記することで従来のスタイルに戻すことが可能です。
|
$conf['image_allow_insecure_derivatives'] = TRUE; |
セキュリティ的な面では好ましくないので、あくまで暫定的な方法です。
PHPでフォームから渡される変数が1,000以上の場合に、制限により受け取れないときの対処法です。
PHPのバージョン5.3.9よりセキュリティの面から、デフォルト値が1,000に制限されているので、PHPプログラムによっては、エラーとなってしまうことがあります。
自分の場合、DrupalのViewsで、外部設置フォームに「Better Exposed Filters」を利用した際に、エラーが頻発してしまいました。
「.htaccess」でデフォルト値を変更する場合には、次の様に追記します。
|
php_value max_input_vars 2500 |
「php.ini」の場合には、次の様に追記します。
ちなみに2,500という数字には、特に意味はありません。
Drupalでカスタムブロックを作成した際に、表示しているコンテンツタイプ別にブロックの表示内容を変更したい場合があります。
下記のようなコードでコンテンツタイプを判定することができます。
|
<?php $sign = false; $types = array('news', 'blog'); if (arg(0) == 'node' && is_numeric(arg(1))) { $nid = arg(1); $node = node_load($nid); $type = $node->type; $sign |= in_array($type, $types); } print $sign; ?> |
表示しているコンテンツタイプが「news」「blog」の場合に$signが「true」になります。
JavaScriptの正規表現でファイル名を、名称の部分と拡張子の部分を分割する際のメモです。
|
var pattern = /(.+)(\.[^.]+$)/; var test = "image-test.jpg"; //「image-test」と表示されます alert(test.match(pattern)[1]); //「.jpg」と表示されます alert(test.match(pattern)[2]); |
Drupal 7での「page.tpl.php」などのテンプレート内で、ユーザーの権限(ロール)によって処理を変えたい場合に、判定するためのコードのメモです。
|
<?php global $user; if (in_array('administrator', $user->roles)) { //administrator権限ユーザーの場合の処理 } ?> |
また、複数の権限を判定したい場合には、下記の様にも書けます。
|
<?php global $user; if (checkValuesInArray(array('administrator', 'manager'), $user->roles)) { //administrator、またはmanager権限ユーザーの場合の処理 } function checkValuesInArray($search, $target) { $sign = false; foreach ($search as $value) { if (in_array($value, $target)) $sign = true; } return $sign; } ?> |