在这个PHP应用程序中实现用户首选项的最佳方法是什么?

时间:2009-07-22 13:39:45

标签: php optimization

我有一个较小的网络应用程序,可以将内容从一个社交源重新发布到另一个社交源。用户可以说有5个选项来过滤该内容。它们的首选项作为1或0标记存储在我的用户数据库中。

当我每小时执行主要的“发布”操作时,分解我的代码以实现这些首选项的最佳方法是什么?为了更清楚,我目前的实现是这样的:

mysql_query(SELECT * FROM users);
foreach ($user as $row){
    get_json_data($userID);
    if ($pref1 == 1){
        /code that enacts preference 1, adds results to array $filtereddata
    }
    if ($pre2 == 1 ){
        /code that filters out preference 2, adds results to $filtereddata
    {   
    postfinalarray($filtereddata);
}

显然这是模拟代码,但这是我一直在使用的一般流程。有没有更好的方法来实现用户的偏好定制功能?我应该设计函数来接受这些首选项作为参数吗?这会节省处理时间还是更易于维护?

很抱歉,如果这种情况过于笼统,请提出问题,以便澄清。

2 个答案:

答案 0 :(得分:1)

当然,有很多可能性来改进这种代码。试想一下,如果要添加其他首选项,则必须重写整个代码。 我总是尝试使用面向对象的方式,因此创建用户类总是有意义的:

<?php

class User
{
    private $_data;

    public function __construct($userdata, $preferences)
    {
        $this->_data = $userdata;
    }

    public function getPreferencesData($preferences)
    {
        $result = array();
        $prefs = $this->_data['preferences'];
        foreach($preferences as $key => $value)
        {
            if($value == "1")
                $result[] = $this->_data[$key];
        }
        return $result;
    }
}

$mypreferences = array("name" => 1, "birthdate" => 0); // show e.g. name and birthdate
$mydata = array("name" => "Gaius Julius Caesar", "birthdate" => "July 13th -100");
$testuser = new User($mydata);
print_r($test->getPreferencesData($mypreferences));

?>

然后,您可以轻松适应用户选择的whatefer首选项,而无需更改代码。

答案 1 :(得分:0)

根据您提供的有限信息,您的方法似乎很好。

我可能会做一些稍微不同的事情。我会有一个你的5个prefs的表(或者如果它们不太可能改变的话就会硬编码)。我将创建一个链接prefs和用户的交叉引用表。然后你可以做类似的事情:

foreach($users as $user)
{
    $filtereddata = array();
    foreach($user->getPreferences() as $pref)
    {
        $filtereddata += $this->getFilteredData($user, $pref);
    }
}

这比您正在使用的开销更大,但是如果/当您添加首选项/功能时更容易扩展。