-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathform-filter.html
109 lines (104 loc) · 4.59 KB
/
form-filter.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>Ethnamドキュメント</title>
<link href="css/style.css" media="all" rel="stylesheet" />
<link href="css/github.css" media="all" rel="stylesheet" />
</head>
<body>
<p><a href=".">目次</a></p>
<div class="blob instapaper_body">
<article class="markdown-body entry-content">
<h1>フォーム値の自動検証を行う(フィルタ編)</h1>
<ul>
<li>サンプル </li>
<li>フィルタの利用方法 </li>
</ul>
<h2>フォーム値の自動検証を行う(フィルタ編)</h2>
<p>フォーム値の自動検証フレームワークには、値の検証だけではなく変換処理も組み込まれています。この機能を利用することで、フォーム値に含まれる半角カナを自動的に全角に変換したり、受け取りたくない文字列を削除することが出来ます。</p>
<h3>サンプル</h3>
<p>機能としてはとっても分かりやすいものなので、まずは例を挙げてみます。アクションフォームクラスの$formメンバに、'filter'属性を追加します(その他の属性については <a href="form-validate.html">フォーム値の自動検証を行う(基本編)</a>を御覧下さい)。</p>
<pre><code>/**
* @access private
* @var array フォーム値定義
*/
var $form = array(
'sample' => array(
'name' => 'サンプル',
'required' => true,
'filter' => 'sample',
'type' => VAR_TYPE_STRING,
),
);</code></pre>
<p>次に、同じくアクションフォームクラスに'_filter_sample'というメソッドを定義します。</p>
<pre><code>/**
* フォーム値変換フィルタ: サンプル
*
* @access protected
* @param mixed $value フォーム値
* @return mixed 変換結果
*/
function _filter_sample($value)
{
return strtoupper($value);
}</code></pre>
<p>以上で準備は完了です。あとは対応するアクションクラスでvalidate()メソッドを呼び出します。</p>
<pre><code>/**
* indexアクションの前処理
*
* @access public
* @return string Forward先(正常終了ならnull)
*/
function prepare()
{
if ($this->af->validate() > 0) {
return 'error';
}
return null;
}</code></pre>
<p>ここでperform()メソッドでフォーム値「sample」にアクセスすると、値が大文字に変換されていると思います。なお、 <strong>validate()メソッドを呼び出さないとfilter処理は実行されません</strong> のでご注意下さい。というか、validate()しないでフォーム値にアクセスしないで下さい。</p>
<pre><code>/**
* indexアクションの実装
*
* @access public
* @return string 遷移名
*/
function perform()
{
var_dump($this->af->get('sample'));
return 'index';
}
/index.php?sample=stringにアクセス:
string(6) "STRING"</code></pre>
<h3>フィルタの利用方法</h3>
<p>以上の通り、フィルタの利用方法は簡単で:</p>
<ol>
<li>フォーム値のfilter属性に、フィルタ名をカンマで区切って列挙する</li>
<li>フィルタメソッドをアクションフォームクラスに"<em>filter</em>[フィルタ名]"という名前で定義する</li>
<li>validate()を実行する</li>
</ol>
<p>という形になります。なお、Ethna_ActionFormには予め以下のようなフィルタメソッドが定義されていますので、基本的な変換についてはフィルタメソッドの定義は必要ありません。</p>
<ul>
<li>numeric_zentohan: 全角数字→半角数字</li>
<li>alphabet_zentohan: 全角英字→半角英字</li>
<li>ltrim: 左空白削除</li>
<li>rtrim: 右空白削除</li>
<li>ntrim: NULLバイト削除</li>
<li>kana_hantozen: 半角カナ→全角カナ</li>
</ul>
<p>ですので、例えば常に半角で値を受け取りたい場合は</p>
<pre><code>'filter' => 'numeric_zentohan,alphabet_zentohan,ltrim,rtrim,ntrim',</code></pre>
<p>とします。また、全角で値を受け取りたい場合は</p>
<pre><code>'filter' => 'kana_hantozen,ntrim',</code></pre>
<p>として半角カナを変換します。なお、上記2つについてはそれぞれFILTER_HW(Half Width)とFILTER_FW(Full Width)という定数が定義されているので、</p>
<pre><code>'filter' => FILTER_HW,</code></pre>
<p>と</p>
<pre><code>'filter' => FILTER_FW,</code></pre>
<p>と記述することが出来ます。</p> </article>
</div>
<div class="site-footer">
@2015 <a href="https://twitter.com/DQNEO">DQNEO</a>
</div>
</body>
</html>