कोई बेहतर तरीका नहीं है, लेकिन चूंकि यह एक ऑपरेशन है जो आप आमतौर पर अक्सर करते हैं, आप बेहतर प्रक्रिया को स्वचालित करेंगे।
अधिकांश चौखटे तर्कों को आसान कार्य बनाने का एक तरीका प्रदान करते हैं। आप उसके लिए अपनी वस्तु का निर्माण कर सकते हैं। त्वरित और गंदे उदाहरण:
class Request
{
// This is the spirit but you may want to make that cleaner :-)
function get($key, $default=null, $from=null)
{
if ($from) :
if (isset(${'_'.$from}[$key]));
return sanitize(${'_'.strtoupper($from)}[$key]); // didn't test that but it should work
else
if isset($_REQUEST[$key])
return sanitize($_REQUEST[$key]);
return $default;
}
// basics. Enforce it with filters according to your needs
function sanitize($data)
{
return addslashes(trim($data));
}
// your rules here
function isEmptyString($data)
{
return (trim($data) === "" or $data === null);
}
function exists($key) {}
function setFlash($name, $value) {}
[...]
}
$request = new Request();
$question= $request->get('question', '', 'post');
print $request->isEmptyString($question);
सिम्फनी उस तरह की चीनी का बड़े पैमाने पर उपयोग करती है।
लेकिन आप इससे अधिक की बात कर रहे हैं, आपके "// हैंडल एरर" के साथ। आप 2 कार्य कर रहे हैं: डेटा प्राप्त करना और उसे संसाधित करना। ऐसा बिल्कुल नहीं है।
ऐसे अन्य तंत्र हैं जिनका उपयोग आप डेटा को मान्य करने के लिए कर सकते हैं। फिर से, चौखटे आपको सबसे अच्छा दिखा सकते हैं।
ऐसी वस्तुओं का निर्माण करें जो आपके फॉर्म के डेटा का प्रतिनिधित्व करती हैं, फिर प्रक्रियाएं संलग्न करें और इसे वापस करें। यह कहीं अधिक काम लगता है जो एक त्वरित PHP स्क्रिप्ट को हैक कर रहा है (और यह पहली बार है), लेकिन यह पुन: प्रयोज्य, लचीला और बहुत कम त्रुटि वाला है क्योंकि सामान्य PHP के साथ फार्म सत्यापन जल्दी से स्पेगेटी कोड बन जाता है।