在数据库中插入唯一的ipaddress

时间:2014-11-09 19:40:20

标签: php laravel laravel-4 php-5.3 php-5.4

我有问题。我想在我的数据库中插入每个访问者的ipaddress和访问日期,但每次刷新页面或打开新闻时都会插入ip。 我的代码: NewsController:

public function __construct(){
     $this->beforeFilter('csrf', array('on'=>'post'));
     $sIpAddress = Visitors_lib::getIp();
     $dDateVisit = time("Y/m/d H:i:s");
     $oVisitor = new \Visitors();
     $bInsert = $oVisitor->addVisitor($sIpAddress,$dDateVisit);
}

VisitorsModel:

public function addVisitor($sIpAdress,$dDate){
    $oVisitor = new Visitors();
    $oVisitor->ipaddress = $sIpAdress;
    $oVisitor->date = $dDate;
    $oVisitor->save();
}

所以我想只插入一个ip。在这种情况下,当我点击新闻时,ip被插入到数据库中,因此对于访问者1单击= 1插入。

1 个答案:

答案 0 :(得分:0)

在输入之前检查它是否已存在:

public function addVisitor($ipaddresse, $date)
{
    if ( ! $this->where(compact('ipaddresse'))->first())
    {
        static::create(compact('ipaddresse', 'date'));
    }
}