arrParam = $array;
} else {
$this->arrParam = $_POST;
}
}
/**
* @param string[] $arrFunc
*/
public function doFunc($value, $arrFunc)
{
foreach ($arrFunc as $key) {
$this->$key($value);
}
}
/**
* HTMLのタグをチェックする
*
* @param array $value value[0] = 項目名
* value[1] = 判定対象
* value[2] = 許可するタグが格納された配列
* @return void
*/
public function HTML_TAG_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$arrAllowedTag = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// HTMLに含まれているタグを抽出する
$match = array();
preg_match_all('/<\/?([a-z]+)/i', $this->arrParam[$keyname], $match);
$arrTagIncludedHtml = $match[1];
// 抽出結果を小文字に変換
foreach ($arrTagIncludedHtml as $key => $matchedTag) {
$arrTagIncludedHtml[$key] = strtolower($matchedTag);
}
$arrDiffTag = array_diff($arrTagIncludedHtml, $arrAllowedTag);
if (empty($arrDiffTag)) return;
// 少々荒っぽいが、表示用 HTML に変換する
foreach ($arrDiffTag as &$tag) {
$tag = '[' . htmlspecialchars($tag) . ']';
}
$html_diff_tag_list = implode(', ', $arrDiffTag);
$this->arrErr[$keyname] = sprintf(
'※ %sに許可されていないタグ %s が含まれています。
',
$disp_name,
$html_diff_tag_list
);
}
/**
* 必須入力の判定
*
* 受け取りがない場合エラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象
* @return void
*/
public function EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
if (is_array($input_var)) {
if (count($input_var) == 0) {
$this->arrErr[$keyname] =
"※ {$disp_name}が選択されていません。
";
}
} else {
if (strlen($input_var) == 0) {
$this->arrErr[$keyname] =
"※ {$disp_name}が入力されていません。
";
}
}
}
/**
* 必須入力の判定(逆順)
*
* 受け取りがない場合エラーを返す
* @param array $value value[0] = 判定対象 value[1] = 項目名
* @return void
*/
public function EXIST_CHECK_REVERSE($value)
{
$keyname = $value[0];
$disp_name = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
// $this->createParam($value);
if (strlen($this->arrParam[$keyname]) == 0) {
$this->arrErr[$keyname] =
"※ {$disp_name}が入力されていません。
";
}
}
/**
* スペース、タブの判定
*
* 受け取りがない場合エラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象
* @return void
*/
public function SPTAB_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) != 0
&& preg_match("/^[ \t\r\n]+$/", $input_var)
) {
$this->arrErr[$keyname] = sprintf(
'※ %sにスペース、タブ、改行のみの入力はできません。
',
$disp_name
);
}
}
/**
* スペース、タブの判定
*
* 受け取りがない場合エラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象
* @return void
*/
public function NO_SPTAB($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) != 0
&& preg_match("/[ \t\r\n]+/u", $input_var)
) {
$this->arrErr[$keyname] = sprintf(
'※ %sにスペース、タブ、改行は含めないで下さい。
',
$disp_name
);
}
}
/**
* ゼロで開始されている数値の判定
*
* ゼロで始まる数値の場合エラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象
* @return void
*/
public function ZERO_START($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) != 0
&& preg_match("/^[0]+[0-9]+$/", $input_var)
) {
$this->arrErr[$keyname] =
"※ {$disp_name}に0で始まる数値が入力されています。
";
}
}
/**
* 必須選択の判定
*
* プルダウンなどで選択されていない場合エラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象
* @return void
*/
public function SELECT_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if (strlen($this->arrParam[$keyname]) == 0) {
$this->arrErr[$keyname] =
"※ {$disp_name}が選択されていません。
";
}
}
/**
* 同一性の判定
*
* 入力が指定文字数以上ならエラーを返す
* @param array $value value[0] = 項目名1
* value[1] = 項目名2
* value[2] = 判定対象文字列1
* value[3] = 判定対象文字列2
* @return void
*/
public function EQUAL_CHECK($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[3];
if (isset($this->arrErr[$keyname1])
|| isset($this->arrErr[$keyname2])
) {
return;
}
// $this->createParam($value);
// 文字数の取得
if ($this->arrParam[$keyname1] !== $this->arrParam[$keyname2]) {
$this->arrErr[$keyname1] =
"※{$disp_name1}と{$disp_name2}が一致しません。
";
}
}
/**
* 値が異なることの判定
*
* 入力が指定文字数以上ならエラーを返す
* @param array $value value[0] = 項目名1
* value[1] = 項目名2
* value[2] = 判定対象文字列1
* value[3] = 判定対象文字列2
* @return void
*/
public function DIFFERENT_CHECK($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[3];
if (isset($this->arrErr[$keyname1])
|| isset($this->arrErr[$keyname2])
) {
return;
}
// $this->createParam($value);
// 文字数の取得
if ($this->arrParam[$keyname1] == $this->arrParam[$keyname2]) {
$this->arrErr[$keyname1] = sprintf(
'※ %sと%sは、同じ値を使用できません。
',
$disp_name1,
$disp_name2
);
}
}
/**
* 値の大きさを比較する value[2] < value[3]でなければエラー
*
* 入力が指定文字数以上ならエラーを返す
* @param array $value value[0] = 項目名1
* value[1] = 項目名2
* value[2] = 判定対象文字列1
* value[3] = 判定対象文字列2
* @return void
*/
public function GREATER_CHECK($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[3];
if (isset($this->arrErr[$keyname1])
|| isset($this->arrErr[$keyname2])
) {
return;
}
// $this->createParam($value);
// 文字数の取得
$input_var1 = $this->arrParam[$keyname1];
$input_var2 = $this->arrParam[$keyname2];
if ($input_var1 != ''
&& $input_var2 != ''
&& ($input_var1 > $input_var2)
) {
$this->arrErr[$keyname1] = sprintf(
'※ %sは%sより大きい値を入力できません。
',
$disp_name1,
$disp_name1
);
}
}
/**
* 最大文字数制限の判定
*
* 入力が指定文字数以上ならエラーを返す
* @param integer[] $value value[0] = 項目名
* value[1] = 判定対象文字列
* value[2] = 最大文字数(半角も全角も1文字として数える)
* @return void
*/
public function MAX_LENGTH_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$max_str_len = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// 文字数の取得
if (mb_strlen($this->arrParam[$keyname]) > $max_str_len) {
$this->arrErr[$keyname] = sprintf(
'※ %sは%d字以下で入力してください。
',
$disp_name,
$max_str_len
);
}
}
/**
* 最小文字数制限の判定
*
* 入力が指定文字数未満ならエラーを返す
* @param array $value value[0] = 項目名
* value[1] = 判定対象文字列
* value[2] = 最小文字数(半角も全角も1文字として数える)
* @return void
*/
public function MIN_LENGTH_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$min_str_len = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// 文字数の取得
if (mb_strlen($this->arrParam[$keyname]) < $min_str_len) {
$this->arrErr[$keyname] = sprintf(
'※ %sは%d字以上で入力してください。
',
$disp_name,
$min_str_len
);
}
}
/**
* 最大文字数制限の判定
*
* 入力が最大数以上ならエラーを返す
* @param array $value value[0] = 項目名
* value[1] = 判定対象文字列
* value[2] = 最大数
* @return void
*/
public function MAX_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$max_threshold = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// 文字数の取得
if ($this->arrParam[$keyname] > $max_threshold) {
$this->arrErr[$keyname] = sprintf(
'※ %sは%d以下で入力してください。
',
$disp_name,
$max_threshold
);
}
}
/**
* 最小数値制限の判定
*
* 入力が最小数未満ならエラーを返す
* @param array $value value[0] = 項目名
* value[1] = 判定対象文字列
* value[2] = 最小数
* @return void
*/
public function MIN_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$min_threshold = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if ($this->arrParam[$keyname] < $min_threshold) {
$this->arrErr[$keyname] = sprintf(
'※ %sは%d以上で入力してください。
',
$disp_name,
$min_threshold
);
}
}
/**
* 数字の判定
*
* 入力文字が数字以外ならエラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象文字列
* @return void
*/
public function NUM_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if ($this->numelicCheck($this->arrParam[$keyname])) {
$this->arrErr[$keyname] =
"※ {$disp_name}は数字で入力してください。
";
}
}
/**
* 小数点を含む数字の判定
*
* 入力文字が数字以外ならエラーを返す
* @param array $value value[0] = 項目名 value[1] = 判定対象文字列
* @return void
*/
public function NUM_POINT_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if (strlen($this->arrParam[$keyname]) > 0
&& !is_numeric($this->arrParam[$keyname])
) {
$this->arrErr[$keyname] =
"※ {$disp_name}は数字で入力してください。
";
}
}
public function ALPHA_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if (strlen($this->arrParam[$keyname]) > 0
&& !ctype_alpha($this->arrParam[$keyname])
) {
$this->arrErr[$keyname] =
"※ {$disp_name}は半角英字で入力してください。
";
}
}
/**
* 電話番号の判定
*
* 数字チェックと文字数チェックを実施する。
* @param array $value 各要素は以下の通り。
* [0]: 項目名
* [1]: 電番1項目目
* [2]: 電番2項目目
* [3]: 電番3項目目
* [4]: 電話番号各項目制限 (指定なしの場合、TEL_ITEM_LEN)
* [5]: 電話番号総数 (指定なしの場合、TEL_LEN)
* @return void
*/
public function TEL_CHECK($value)
{
$disp_name = $value[0];
$keyname1 = $value[1];
$keyname2 = $value[2];
$keyname3 = $value[3];
$telItemLen = isset($value[4]) ? $value[4] : TEL_ITEM_LEN;
$telLen = isset($value[5]) ? $value[5] : TEL_LEN;
if (isset($this->arrErr[$keyname1])
|| isset($this->arrErr[$keyname2])
|| isset($this->arrErr[$keyname3])
) {
return;
}
$this->createParam($value);
$cnt = 0;
for ($i = 1; $i <= 3; $i++) {
$keyname = ${"keyname{$i}"};
if (strlen($this->arrParam[$keyname]) > 0) {
$cnt++;
}
}
// 全ての項目が満たされていない場合を判定(一部だけ入力されている状態)
if ($cnt > 0 && $cnt < 3) {
$this->arrErr[$keyname1] .=
"※ {$disp_name}は全ての項目を入力してください。
";
}
$total_count = 0;
for ($i = 1; $i <= 3; $i++) {
$keyname = ${"keyname{$i}"};
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) > 0 && strlen($input_var) > $telItemLen) {
$this->arrErr[$keyname] .= sprintf(
'※ %sは%d字以内で入力してください。
',
$disp_name . $i,
$telItemLen
);
} elseif ($this->numelicCheck($input_var)) {
$this->arrErr[$keyname] .=
"※ {$disp_name}{$i}は数字で入力してください。
";
}
$total_count += strlen($input_var);
}
// 合計値チェック
if ($total_count > $telLen) {
$this->arrErr[$keyname3] .=
"※ {$disp_name}は{$telLen}文字以内で入力してください。
";
}
}
/* 関連項目が完全に満たされているか判定
value[0] : 項目名
value[1] : 判定対象要素名
*/
public function FULL_EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$this->createParam($value);
// 既に該当項目にエラーがある場合は、判定しない。
$max = count($value);
for ($i = 1; $i < $max; $i++) {
if (isset($this->arrErr[$value[$i]])) {
return;
}
}
// 全ての項目が入力されていない場合はエラーとする。
$blank = false;
for ($i = 1; $i < $max; $i++) {
if (strlen($this->arrParam[$value[$i]]) <= 0) {
$blank = true;
}
}
if ($blank) {
$this->arrErr[$keyname] =
"※ {$disp_name}が入力されていません。
";
}
}
/* 関連項目が全て満たされているか判定
value[0] : 項目名
value[1] : 判定対象要素名
*/
public function ALL_EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
// 既に該当項目にエラーがある場合は、判定しない。
$max = count($value);
for ($i = 1; $i < $max; $i++) {
if (isset($this->arrErr[$value[$i]])) {
return;
}
}
$blank = false;
$input = false;
// 全ての項目がブランクでないか、全ての項目が入力されていない場合はエラーとする。
for ($i = 1; $i < $max; $i++) {
if (strlen($this->arrParam[$value[$i]]) <= 0) {
$blank = true;
} else {
$input = true;
}
}
if ($blank && $input) {
$this->arrErr[$keyname] =
"※ {$disp_name}は全ての項目を入力して下さい。
";
}
}
/* 関連項目がどれか一つ満たされているか判定
value[0] : 項目名
value[1] : 判定対象要素名
*/
public function ONE_EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$this->createParam($value);
// 既に該当項目にエラーがある場合は、判定しない。
$max = count($value);
for ($i = 1; $i < $max; $i++) {
if (isset($this->arrErr[$value[$i]])) {
return;
}
}
$input = false;
// 全ての項目がブランクでないか、全ての項目が入力されていない場合はエラーとする。
for ($i = 1; $i < $max; $i++) {
if (strlen($this->arrParam[$value[$i]]) > 0) {
$input = true;
}
}
if (!$input) {
$this->arrErr[$keyname] =
"※ {$disp_name}が入力されていません。
";
}
}
/* 上位の項目が満たされているか判定
value[0] : 項目名
value[1] : 判定対象要素名
*/
public function TOP_EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$this->createParam($value);
// 既に該当項目にエラーがある場合は、判定しない。
$max = count($value);
for ($i = 1; $i < $max; $i++) {
if (isset($this->arrErr[$value[$i]])) {
return;
}
}
$blank = false;
$error = false;
// 全ての項目がブランクでないか、全ての項目が入力されていない場合はエラーとする。
for ($i = 1; $i < $max; $i++) {
if (strlen($this->arrParam[$value[$i]]) <= 0) {
$blank = true;
} else {
if ($blank) {
$error = true;
}
}
}
if ($error) {
$this->arrErr[$keyname] =
"※ {$disp_name}は先頭の項目から順番に入力して下さい。
";
}
}
/* カタカナの判定 */
// 入力文字がカナ以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function KANA_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
$pattern = "/^[ァ-ヶヲ-゚ー]+$/u";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}はカタカナで入力してください。
";
}
}
/* カタカナの判定2 (タブ、スペースは許可する) */
// 入力文字がカナ以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function KANABLANK_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
$pattern = "/^([ \t\r\n]|[ァ-ヶ]|[ー])+$/u";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}はカタカナで入力してください。
";
}
}
/* 英数字の判定 */
// 入力文字が英数字以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function ALNUM_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) > 0 && !ctype_alnum($input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は英数字で入力してください。
";
}
}
/* 英数記号の判定 */
// 入力文字が英数記号以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function GRAPH_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
$pattern = "/^[[:graph:][:space:]]+$/i";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は英数記号で入力してください。
";
}
}
/* 必須選択の判定 */
// 入力値で0が許されない場合エラーを返す
// value[0] = 項目名 value[1] = 判定対象
public function ZERO_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$this->createParam($value);
if ($this->arrParam[$keyname] == '0') {
$this->arrErr[$keyname] =
"※ {$disp_name}は1以上を入力してください。
";
}
}
/* 桁数の判定 (最小最大)*/
// 入力文字の桁数判定 → 最小桁数<入力文字列<最大桁数
// value[0] = 項目名 value[1] = 判定対象文字列 value[2] = 最小桁数 value[3] = 最大桁数
public function NUM_RANGE_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$min_digit = $value[2];
$max_digit = $value[3];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// $this->arrParam[$keyname] = mb_convert_kana($this->arrParam[$keyname], 'n');
$count = strlen($this->arrParam[$keyname]);
if (($count > 0) && $min_digit > $count || $max_digit < $count) {
$this->arrErr[$keyname] = sprintf(
'※ %sは%d桁~%d桁で入力して下さい。
',
$disp_name,
$min_digit,
$max_digit
);
}
}
/* 桁数の判定 */
// 入力文字の桁数判定 → 入力文字列 = 桁数 以外はNGの場合
// value[0] = 項目名 value[1] = 判定対象文字列 value[2] = 桁数
public function NUM_COUNT_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$digit = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$count = strlen($this->arrParam[$keyname]);
if (($count > 0) && $count != $digit) {
$this->arrErr[$keyname] =
"※ {$disp_name}は{$digit}桁で入力して下さい。
";
}
}
/**
* メールアドレス形式の判定
*
* @param array $value 各要素は以下の通り。
* [0]: 項目名
* [1]: 判定対象を格納している配列キー
* @return void
*/
public function EMAIL_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// 入力がない場合処理しない
if (strlen($this->arrParam[$keyname]) === 0) {
return;
}
$wsp = '[\x20\x09]';
$vchar = '[\x21-\x7e]';
$quoted_pair = "\\\\(?:$vchar|$wsp)";
$qtext = '[\x21\x23-\x5b\x5d-\x7e]';
$qcontent = "(?:$qtext|$quoted_pair)";
$quoted_string = "\"$qcontent*\"";
$atext = '[a-zA-Z0-9!#$%&\'*+\-\/\=?^_`{|}~]';
$dot_atom = "$atext+(?:[.]$atext+)*";
$local_part = "(?:$dot_atom|$quoted_string)";
$domain = $dot_atom;
$addr_spec = "{$local_part}[@]$domain";
$dot_atom_loose = "$atext+(?:[.]|$atext)*";
$local_part_loose = "(?:$dot_atom_loose|$quoted_string)";
$addr_spec_loose = "{$local_part_loose}[@]$domain";
if (RFC_COMPLIANT_EMAIL_CHECK) {
$regexp = "/\A{$addr_spec}\z/";
} else {
// 携帯メールアドレス用に、..や.@を許容する。
$regexp = "/\A{$addr_spec_loose}\z/";
}
if (!preg_match($regexp, $this->arrParam[$keyname])) {
$this->arrErr[$keyname] = "※ {$disp_name}の形式が不正です。
";
return;
}
// 最大文字数制限の判定 (#871)
$arrValueTemp = $value;
$arrValueTemp[2] = 256;
$this->MAX_LENGTH_CHECK($arrValueTemp);
}
/* メールアドレスに使用できる文字の判定 */
// メールアドレスに使用する文字を正規表現で判定する
// value[0] = 項目名 value[1] = 判定対象メールアドレス
public function EMAIL_CHAR_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_var = $this->arrParam[$keyname];
$pattern = "/^[a-zA-Z0-9_\.@\+\?-]+$/i";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}に使用する文字を正しく入力してください。
";
}
}
/* URL形式の判定 */
// URLを正規表現で判定する。デフォルトでhttp://があってもOK
// value[0] = 項目名 value[1] = 判定対象URL
public function URL_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$input_var = $this->arrParam[$keyname];
$pattern = "@^https?://+($|[a-zA-Z0-9_~=:&\?\.\/-])+$@i";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] =
"※ {$disp_name}を正しく入力してください。
";
}
}
/* IPアドレスの判定 */
// value[0] = 項目名 value[1] = 判定対象IPアドレス文字列
public function IP_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
//改行コードが含まれている場合には配列に変換
$params = str_replace("\r", '', $this->arrParam[$keyname]);
if (!empty($params)) {
if (strpos($params, "\n") === false) {
$params .= "\n";
}
$params = explode("\n", $params);
foreach ($params as $param) {
$param = trim($param);
if (long2ip(ip2long($param)) != trim($param) && !empty($param)) {
$this->arrErr[$keyname] =
"※ {$disp_name}に正しい形式のIPアドレスを入力してください。
";
}
}
}
}
/* 拡張子の判定 */
// 受け取りがない場合エラーを返す
// value[0] = 項目名 value[1] = 判定対象 value[2]=array(拡張子)
public function FILE_EXT_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$arrExtension = $value[2];
if (isset($this->arrErr[$keyname]) || count($arrExtension) == 0) {
return;
}
$this->createParam($value);
$match = false;
$filename = $_FILES[$keyname]['name'];
if (strlen($filename) >= 1) {
foreach ($arrExtension as $check_ext) {
$pattern = '/' . preg_quote('.' . $check_ext) . '$/i';
$match = preg_match($pattern, $filename) >= 1;
if ($match === true) {
break 1;
}
}
}
if ($match === false) {
$str_ext = implode('・', $arrExtension);
$this->arrErr[$keyname] =
"※ {$disp_name}で許可されている形式は、{$str_ext}です。
";
}
}
/* ファイルが存在するかチェックする */
// 受け取りがない場合エラーを返す
// value[0] = 項目名 value[1] = 判定対象 value[2] = 指定ディレクトリ
public function FIND_FILE($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$target_dir = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
// $this->createParam($value);
if ($target_dir != '') {
$dir = $target_dir;
} else {
$dir = IMAGE_SAVE_REALDIR;
}
$path = $dir . '/' . $this->arrParam[$keyname];
$path = str_replace('//', '/', $path);
if ($this->arrParam[$keyname] != '' && !file_exists($path)) {
$this->arrErr[$keyname] = "※ {$path}が見つかりません。
";
}
}
/* ファイルが上げられたか確認 */
// 受け取りがない場合エラーを返す
// value[0] = 項目名 value[1] = 判定対象 value[2] = 指定サイズ(KB)
public function FILE_EXIST_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$file_size = $_FILES[$keyname]['size'];
if ($file_size == '' || !($file_size > 0)) {
$this->arrErr[$keyname] =
"※ {$disp_name}をアップロードして下さい。
";
}
}
/* ファイルサイズの判定 */
// 受け取りがない場合エラーを返す
// value[0] = 項目名 value[1] = 判定対象 value[2] = 指定サイズ(KB)
public function FILE_SIZE_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$max_file_size = $value[2];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if ($_FILES[$keyname]['size'] > $max_file_size * 1024) {
$byte = 'KB';
if ($max_file_size >= 1000) {
$max_file_size = $max_file_size / 1000;
$byte = 'MB';
}
$this->arrErr[$keyname] = sprintf(
'※ %sのファイルサイズは%d%s以下のものを使用してください。
',
$disp_name,
$max_file_size,
$byte
);
}
}
/* ファイル名の判定 */
// 入力文字が英数字,'_','-','.'以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function FILE_NAME_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$filename = $_FILES[$keyname]['name'];
$pattern = "/^[[:alnum:]_\.-]+$/i";
if (strlen($filename) > 0 && !preg_match($pattern, $filename)) {
$this->arrErr[$keyname] =
"※ {$disp_name}のファイル名には、英数字、記号(_ - .)のみを入力して下さい。
";
}
}
/* ファイル名の判定(アップロード以外の時) */
// 入力文字が英数字,'_','-','.'以外ならエラーを返す
// value[0] = 項目名 value[1] = 判定対象文字列
public function FILE_NAME_CHECK_BY_NOUPLOAD($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$filename = $this->arrParam[$keyname];
$pattern = "/[^[:alnum:]_.\\-]/";
if (strlen($filename) > 0 && preg_match($pattern, $filename)) {
$this->arrErr[$keyname] =
"※ {$disp_name}のファイル名には、英数字、記号(_ - .)のみを入力して下さい。
";
}
}
//日付チェック
// value[0] = 項目名
// value[1] = YYYY
// value[2] = MM
// value[3] = DD
public function CHECK_DATE($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_year = $this->arrParam[$value[1]];
$input_month = $this->arrParam[$value[2]];
$input_day = $this->arrParam[$value[3]];
// 少なくともどれか一つが入力されている。
if ($input_year > 0 || $input_month > 0 || $input_day > 0) {
// 年月日のどれかが入力されていない。
if (!(strlen($input_year) > 0 && strlen($input_month) > 0 && strlen($input_day) > 0)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は全ての項目を入力して下さい。
";
} elseif (!checkdate($input_month, $input_day, $input_year)) {
$this->arrErr[$keyname] =
"※ {$disp_name}が正しくありません。
";
}
}
}
//日付チェック
// value[0] = 項目名
// value[1] = YYYY
// value[2] = MM
// value[3] = DD
// value[4] = HH
// value[5] = mm
public function CHECK_DATE2($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_year = $this->arrParam[$value[1]];
$input_month = $this->arrParam[$value[2]];
$input_day = $this->arrParam[$value[3]];
$input_hour = $this->arrParam[$value[4]];
$input_minute = $this->arrParam[$value[5]];
// 少なくともどれか一つが入力されている。
if ($input_year > 0 || $input_month > 0 || $input_day > 0
|| $input_hour >= 0 || $input_minute >= 0
) {
// 年月日時のどれかが入力されていない。
if (!(strlen($input_year) > 0 && strlen($input_month) > 0 && strlen($input_day) > 0 && strlen($input_hour) > 0 && strlen($input_minute) > 0)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は全ての項目を入力して下さい。
";
} elseif (! checkdate($input_month, $input_day, $input_year)) {
$this->arrErr[$keyname] =
"※ {$disp_name}が正しくありません。
";
}
}
}
//日付チェック
// value[0] = 項目名
// value[1] = YYYY
// value[2] = MM
public function CHECK_DATE3($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$input_year = $this->arrParam[$value[1]];
$input_month = $this->arrParam[$value[2]];
// 少なくともどれか一つが入力されている。
if ($input_year > 0 || $input_month > 0) {
// 年月日時のどれかが入力されていない。
if (!(strlen($input_year) > 0 && strlen($input_month) > 0)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は全ての項目を入力して下さい。
";
} elseif (! checkdate($input_month, 1, $input_year)) {
$this->arrErr[$keyname] =
"※ {$disp_name}が正しくありません。
";
}
}
}
//誕生日チェック
// value[0] = 項目名
// value[1] = YYYY
// value[2] = MM
// value[3] = DD
public function CHECK_BIRTHDAY($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
// 年が入力されている。
if (strlen($this->arrParam[$keyname]) >= 1) {
// 年の数字チェック、最小数値制限チェック
$this->doFunc(array("{$disp_name}(年)", $keyname, BIRTH_YEAR),
array('NUM_CHECK', 'MIN_CHECK'));
// 上のチェックでエラーある場合、中断する。
if (isset($this->arrErr[$keyname])) {
return;
}
// 年の最大数値制限チェック
$current_year = date('Y');
$this->doFunc(array("{$disp_name}(年)", $keyname, $current_year),
array('MAX_CHECK'));
// 上のチェックでエラーある場合、中断する。
if (isset($this->arrErr[$keyname])) {
return;
}
}
// XXX createParam() が二重に呼ばれる問題を抱える
$this->CHECK_DATE($value);
}
/*-----------------------------------------------------------------*/
/* CHECK_SET_TERM
/* 年月日に別れた2つの期間の妥当性をチェックし、整合性と期間を返す
/* 引数 (開始年,開始月,開始日,終了年,終了月,終了日)
/* 戻値 array(1,2,3)
/* 1.開始年月日 (YYYYMMDD 000000)
/* 2.終了年月日 (YYYYMMDD 235959)
/* 3.エラー (0 = OK, 1 = NG)
/*-----------------------------------------------------------------*/
// value[0] = 項目名1
// value[1] = 項目名2
// value[2] = start_year
// value[3] = start_month
// value[4] = start_day
// value[5] = end_year
// value[6] = end_month
// value[7] = end_day
public function CHECK_SET_TERM($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[5];
// 期間指定
if (isset($this->arrErr[$keyname1]) || isset($this->arrErr[$keyname2])) {
return;
}
// $this->createParam($value);
$start_year = $this->arrParam[$value[2]];
$start_month = $this->arrParam[$value[3]];
$start_day = $this->arrParam[$value[4]];
$end_year = $this->arrParam[$value[5]];
$end_month = $this->arrParam[$value[6]];
$end_day = $this->arrParam[$value[7]];
if ((strlen($start_year) > 0 || strlen($start_month) > 0 || strlen($start_day) > 0)
&& ! checkdate($start_month, $start_day, $start_year)
) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}を正しく指定してください。
";
}
if ((strlen($end_year) > 0 || strlen($end_month) > 0 || strlen($end_day) > 0)
&& ! checkdate($end_month, $end_day, $end_year)
) {
$this->arrErr[$keyname2] =
"※ {$disp_name2}を正しく指定してください。
";
}
if ((strlen($start_year) > 0 && strlen($start_month) > 0 && strlen($start_day) > 0)
&& (strlen($end_year) > 0 || strlen($end_month) > 0 || strlen($end_day) > 0)
) {
$date1 = sprintf('%d%02d%02d000000', $start_year, $start_month, $start_day);
$date2 = sprintf('%d%02d%02d235959', $end_year, $end_month, $end_day);
if (($this->arrErr[$keyname1] == '' && $this->arrErr[$keyname2] == '') && $date1 > $date2) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}と{$disp_name2}の期間指定が不正です。
";
}
}
}
/*-----------------------------------------------------------------*/
/* CHECK_SET_TERM2
/* 年月日時に別れた2つの期間の妥当性をチェックし、整合性と期間を返す
/* 引数 (開始年,開始月,開始日,開始時間,開始分,開始秒,
/* 終了年,終了月,終了日,終了時間,終了分,終了秒)
/* 戻値 array(1,2,3)
/* 1.開始年月日 (YYYYMMDDHHmmss)
/* 2.終了年月日 (YYYYMMDDHHmmss)
/* 3.エラー (0 = OK, 1 = NG)
/*-----------------------------------------------------------------*/
// value[0] = 項目名1
// value[1] = 項目名2
// value[2] = start_year
// value[3] = start_month
// value[4] = start_day
// value[5] = start_hour
// value[6] = start_minute
// value[7] = start_second
// value[8] = end_year
// value[9] = end_month
// value[10] = end_day
// value[11] = end_hour
// value[12] = end_minute
// value[13] = end_second
/*-----------------------------------------------------------------*/
public function CHECK_SET_TERM2($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[8];
// 期間指定
if (isset($this->arrErr[$keyname1]) || isset($this->arrErr[$keyname2])) {
return;
}
// $this->createParam($value);
$start_year = $this->arrParam[$value[2]];
$start_month = $this->arrParam[$value[3]];
$start_day = $this->arrParam[$value[4]];
$start_hour = $this->arrParam[$value[5]];
$start_minute = $this->arrParam[$value[6]];
$start_second = $this->arrParam[$value[7]];
$end_year = $this->arrParam[$value[8]];
$end_month = $this->arrParam[$value[9]];
$end_day = $this->arrParam[$value[10]];
$end_hour = $this->arrParam[$value[11]];
$end_minute = $this->arrParam[$value[12]];
$end_second = $this->arrParam[$value[13]];
if ((strlen($start_year) > 0 || strlen($start_month) > 0 || strlen($start_day) > 0 || strlen($start_hour) > 0)
&& ! checkdate($start_month, $start_day, $start_year)
) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}を正しく指定してください。
";
}
if ((strlen($end_year) > 0 || strlen($end_month) > 0 || strlen($end_day) > 0 || strlen($end_hour) > 0)
&& ! checkdate($end_month, $end_day, $end_year)
) {
$this->arrErr[$keyname2] =
"※ {$disp_name2}を正しく指定してください。
";
}
if ((strlen($start_year) > 0 && strlen($start_month) > 0 && strlen($start_day) > 0 && strlen($start_hour) > 0)
&& (strlen($end_year) > 0 || strlen($end_month) > 0 || strlen($end_day) > 0 || strlen($end_hour) > 0)
) {
$date1 = sprintf('%d%02d%02d%02d%02d%02d',
$start_year, $start_month, $start_day,
$start_hour, $start_minute, $start_second);
$date2 = sprintf('%d%02d%02d%02d%02d%02d',
$end_year, $end_month, $end_day,
$end_hour, $end_minute, $end_second);
if (($this->arrErr[$keyname1] == '' && $this->arrErr[$keyname2] == '') && $date1 > $date2) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}と{$disp_name2}の期間指定が不正です。
";
}
if ($date1 == $date2) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}と{$disp_name2}の期間指定が不正です。
";
}
}
}
/*-----------------------------------------------------------------*/
/* CHECK_SET_TERM3
/* 年月に別れた2つの期間の妥当性をチェックし、整合性と期間を返す
/* 引数 (開始年,開始月,終了年,終了月)
/* 戻値 array(1,2,3)
/* 1.開始年月日 (YYYYMMDD 000000)
/* 2.終了年月日 (YYYYMMDD 235959)
/* 3.エラー (0 = OK, 1 = NG)
/*-----------------------------------------------------------------*/
// value[0] = 項目名1
// value[1] = 項目名2
// value[2] = start_year
// value[3] = start_month
// value[4] = end_year
// value[5] = end_month
public function CHECK_SET_TERM3($value)
{
$disp_name1 = $value[0];
$disp_name2 = $value[1];
$keyname1 = $value[2];
$keyname2 = $value[4];
// 期間指定
if (isset($this->arrErr[$keyname1]) || isset($this->arrErr[$keyname2])) {
return;
}
// $this->createParam($value);
$start_year = $this->arrParam[$value[2]];
$start_month = $this->arrParam[$value[3]];
$end_year = $this->arrParam[$value[4]];
$end_month = $this->arrParam[$value[5]];
if ((strlen($start_year) > 0 || strlen($start_month) > 0)
&& ! checkdate($start_month, 1, $start_year)
) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}を正しく指定してください。
";
}
if ((strlen($end_year) > 0 || strlen($end_month) > 0)
&& ! checkdate($end_month, 1, $end_year)
) {
$this->arrErr[$keyname2] =
"※ {$disp_name2}を正しく指定してください。
";
}
if ((strlen($start_year) > 0 && strlen($start_month) > 0 && (strlen($end_year) > 0 || strlen($end_month) > 0))) {
$date1 = sprintf('%d%02d', $start_year, $start_month);
$date2 = sprintf('%d%02d', $end_year, $end_month);
if (($this->arrErr[$keyname1] == '' && $this->arrErr[$keyname2] == '') && $date1 > $date2) {
$this->arrErr[$keyname1] =
"※ {$disp_name1}と{$disp_name2}の期間指定が不正です。
";
}
}
}
//ディレクトリ存在チェック
public function DIR_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
if (!is_dir($this->arrParam[$keyname])) {
$this->arrErr[$keyname] =
"※ 指定した{$disp_name}は存在しません。
";
}
}
// ドメインチェック
public function DOMAIN_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$input_var = $this->arrParam[$keyname];
$pattern = "/^\.[^.]+\..+/i";
if (strlen($input_var) > 0 && !preg_match($pattern, $input_var)) {
$this->arrErr[$keyname] = "※ {$disp_name}の形式が不正です。
";
}
}
/* 携帯メールアドレスの判定 */
// メールアドレスを正規表現で判定する
// value[0] = 項目名 value[1] = 判定対象メールアドレス
public function MOBILE_EMAIL_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$objMobile = new SC_Helper_Mobile_Ex();
$input_var = $this->arrParam[$keyname];
if (strlen($input_var) > 0
&&!$objMobile->gfIsMobileMailAddress($input_var)
) {
$this->arrErr[$keyname] =
"※ {$disp_name}は携帯電話のものではありません。
";
}
}
/**
* CHECK_REGIST_CUSTOMER_EMAIL
*
* メールアドレスが会員登録されているか調べる
* @param array $value value[0] = 項目名 value[1] = 判定対象メールアドレス
* @access public
* @return void
*/
public function CHECK_REGIST_CUSTOMER_EMAIL($value)
{
$disp_name = $value[0];
$keyname = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
$this->createParam($value);
$register_user_flg = SC_Helper_Customer_Ex::sfCheckRegisterUserFromEmail($this->arrParam[$keyname]);
switch ($register_user_flg) {
case 1:
$this->arrErr[$keyname] .=
"※ すでに会員登録で使用されている{$disp_name}です。
";
break;
case 2:
$this->arrErr[$keyname] .=
"※ 退会から一定期間の間は、同じ{$disp_name}を使用することはできません。
";
break;
default:
break;
}
}
/**
* 禁止文字列のチェック
* value[0] = 項目名 value[1] = 判定対象文字列
* value[2] = 入力を禁止する文字列(配列)
*
* @example $objErr->doFunc(array('URL', 'contents', $arrReviewDenyURL), array('PROHIBITED_STR_CHECK'));
*/
public function PROHIBITED_STR_CHECK($value)
{
$disp_name = $value[0];
$keyname = $value[1];
$arrProhibitedStr = $value[2];
if (isset($this->arrErr[$keyname]) || empty($this->arrParam[$keyname])) {
return;
}
$this->createParam($value);
$targetStr = $this->arrParam[$keyname];
$prohibitedStr = str_replace(array('|', '/'), array('\|', '\/'), $arrProhibitedStr);
$pattern = '/' . join('|', $prohibitedStr) . '/i';
if (preg_match_all($pattern, $targetStr, $matches)) {
$this->arrErr[$keyname] =
"※ {$disp_name}は入力できません。
";
}
}
/**
* パラメーターとして適切な文字列かチェックする.
*
* @access private
* @param array $value [0] => 項目名, [1] => 評価する文字列
* @return void
*/
public function EVAL_CHECK($value)
{
$keyname = $value[0];
$input_var = $value[1];
if (isset($this->arrErr[$keyname])) {
return;
}
// $this->createParam($value);
if ($this->evalCheck($input_var) === false) {
$this->arrErr[$keyname] =
"※ {$keyname} の形式が不正です。
";
}
}
/**
* パラメーターとして適切な文字列かチェックする.(サブルーチン)
*
* 下記を満たす場合を真とする。
* ・PHPコードとして評価可能であること。
* ・評価した結果がスカラデータ(定数に指定できる値)であること。
* 本メソッドの利用や改訂にあたっては、eval 関数の危険性を意識する必要がある。
* @access private
* @param string 評価する文字列
* @return bool パラメーターとして適切な文字列か
*/
public function evalCheck($value)
{
return @eval('return is_scalar(' . $value . ');');
}
/**
* 未定義の $this->arrParam に空要素を代入する.
*
* @access private
* @param array $value 配列
* @return void
*/
public function createParam($value)
{
foreach ($value as $val_key => $key) {
if ($val_key != 0 && (is_string($key) || is_int($key))) {
if (!is_numeric($key) && preg_match('/^[a-z0-9_]+$/i', $key)) {
if (!isset($this->arrParam[$key])) $this->arrParam[$key] = '';
if (strlen($this->arrParam[$key]) > 0
&& (preg_match('/^[[:alnum:]\-\_]*[\.\/\\\\]*\.\.(\/|\\\\)/', $this->arrParam[$key]) || !preg_match('/\A[^\x00-\x08\x0b\x0c\x0e-\x1f\x7f]+\z/u', $this->arrParam[$key]))) {
$this->arrErr[$value[1]] = '※ ' . $value[0] . 'に禁止された記号の並びまたは制御文字が入っています。
';
}
} elseif (preg_match('/[^a-z0-9_]/i', $key)) {
trigger_error('', E_USER_ERROR);
}
}
}
}
/**
* 値が数字だけかどうかチェックする
*
* @access private
* @param string $string チェックする文字列
* @return boolean 値が10進数の数値表現のみの場合 true
*/
public function numelicCheck($string)
{
/*
* XXX 10進数の数値表現か否かを調べたいだけだが,
* ctype_digit() は文字列以外 false を返す.
* string ではなく int 型の数値が入る場合がある.
*/
$string = (string) $string;
return strlen($string) > 0 && !ctype_digit($string);
}
}