我喜欢将$_SESSION
、$_POST
、$_GET
和包装$_COOKIE
成 OOP 结构。
我使用这种方法来集中处理卫生和验证的代码、所有必要的isset ()
检查、随机数、setcookie
参数等。它还允许客户端代码更具可读性(并给我一种更易于维护的错觉)。
强制使用这种结构可能很困难,尤其是在有多个编码器的情况下。使用$_GET
、$_POST
和$_COOKIE
(我相信),您的初始化代码可以复制数据,然后销毁超全局。也许一个聪明的析构函数可以通过 $_SESSION 实现这一点(在加载时擦除 $_SESSION,将其写回到析构函数中),尽管我没有尝试过。
不过,我通常不使用任何这些强制技术。习惯了之后,$_SESSION
在会话类之外的代码中看到就显得很奇怪,而且我主要是独自工作。
编辑
这是一些示例客户端代码,以防它帮助某人。我确信查看任何主要框架都会为您提供更好的想法......
$post = Post::load ();
$post->numeric ('member_age');
$post->email ('member_email');
$post->match ('/regex/','member_field');
$post->required ('member_first_name','member_email');
$post->inSet ('member_status',array('unemployed','retired','part-time','full-time'));
$post->money ('member_salary');
$post->register ('member_last_name'); // no specific requirements, but we want access
if ($post->isValid())
{
// do good stuff
$firstName = $post->member_first_name;
}
else
{
// do error stuff
}
Post 和它的朋友都派生自一个实现核心验证代码的基类,添加了他们自己的特定功能,如表单令牌、会话 cookie 配置等。
在内部,该类包含一组在调用验证方法时从中提取的有效数据$_POST
,然后使用魔术__get
方法将它们作为属性返回。无法通过这种方式访问失败的字段。我的验证方法(除了required
)不会在空字段上失败,并且其中许多func_get_args
用于允许它们一次对多个字段进行操作。一些方法(如money
)会自动将数据转换为自定义值类型。
在错误情况下,我有一种方法可以将数据转换为可以保存在会话中并用于预填充表单并在重定向到原始表单后突出显示错误的格式。
对此进行改进的一种方法是将验证信息存储在 Form 类中,该类用于呈现表单和支持客户端验证,以及在提交后清理数据。