阻止Codeigniter Cron Job的会话

时间:2015-11-26 23:35:31

标签: php mysql codeigniter cron

我是创建cron工作的新手。刚刚开始涉足昨天。

我为当地房地产经纪人设计了一个网站,我的数据库中有一个字段,用于“状态”和“状态”。 (待售,待售,已售),' SoldDate' (如果没有出售,则为NULL),'可见' (布尔)。我正在尝试创建一个cron作业,每天检查一次出售的物业,这些物品是“销售日期”。过去时间超过30天,如果为真,则更改“可见”字样。字段为0(假)。

现在我只有一个测试脚本,它将一个值添加到名为' CRON'的虚拟数据库中。和时间戳。

我使用Codeigniter构建我的网站。以下是我的代码:

Cron控制器

class Cron extends MY_Controller {

    public function __construct()
    {
        parent::__construct();
        $this->load->model('cron_m');
    }

    public function index()
    {
        if(!$this->input->is_cli_request())
        {
            echo "This script can only be accessed via the command line" . PHP_EOL;
            return;
        }

        $data = array('value' => 'test');
        $this->cron_m->save($data);
        echo 'saved!';

    }

}

Frontend_Controller

class Frontend_Controller extends MY_Controller {

    function __construct()
    {
        parent::__construct();
        $this->load->helper('form');
        $this->load->library('form_validation');        
     }

    public function lock()
    {
        $this->load->library('session');        
        $this->load->model('user_m');   

        // Login check
        $exception_uris = array(
            'admin/user/login',
            'admin/user/logout'
        );

        if (in_array(uri_string(), $exception_uris) == FALSE)
        {
            if ($this->user_m->loggedin() == FALSE)
            {
                $uri = $this->uri->uri_string();
                $this->session->set_tempdata('uri', $uri);

                redirect('admin/user/login');
            }
        }
    }

}

MY_Controller

class MY_Controller extends CI_Controller {

    public $data = array();

    function __construct() {

        parent::__construct();

        $this->data['errors'] = array();

    }

}

Cron_m模型

class Cron_m extends MY_Model {

    public $_table_name = 'CRON';
    protected $_order_by = 'id';

    public function __construct()
    {
        parent::__construct();
    }

}

MY_Model

class MY_Model extends CI_Model {

    public $_table_name = '';
    protected $_primary_key = 'id';
    protected $_primary_filter = 'intval';
    protected $_order_by = 'order';

    function __construct()
    {
        parent::__construct();
    }

    public function save($data, $id = NULL)
    {

        //INSERT
        if ($id === NULL)
        {           
            !isset($data[$this->_primary_key]) || $data[$this->_primary_key] = NULL;
            $this->db->set($data);
            $this->db->insert($this->_table_name);
            $id = $this->db->insert_id();
        }

        //UPDATE
        else
        {
            $filter = $this->_primary_filter;
            $id = $filter($id);
            $this->db->set($data);
            $this->db->where($this->_primary_key, $id);
            $this->db->update($this->_table_name);
        }

        return $id;

    }

}

的.htaccess

RewriteEngine on
RewriteCond $1 !^(index\.php|robots\.txt|assets|uploads|podcast\.xml)
RewriteRule ^(.*)$ /index.php/$1 [L]

我的本​​地机器上的一切正常,但是当我在我的网络服务器终端上运行代码时(php /home4/server_name/public_html/site_name/index.php cron)它没有运行并且给了我有关会话数据库发生数据库错误的错误。 " ip_address不能为空"

我不确定为什么要尝试创建会话数据。我还没有在我的Fronted_Controller中创建一个会话。

以下是我得到的错误:

Status: 500 Internal Server Error
Set-Cookie: ci_session=e9e9c8120a392b9009cd80196ce2fa2cabda516e; expires=Fri, 27-Nov-2015 01:42:33 GMT; path=/; HttpOnly
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-type: text/html; charset=UTF-8


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Database Error</title>
<style type="text/css">

::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }

body {
        background-color: #fff;
        margin: 40px;
        font: 13px/20px normal Helvetica, Arial, sans-serif;
        color: #4F5155;
}

a {
        color: #003399;
        background-color: transparent;
        font-weight: normal;
}

h1 {
        color: #444;
        background-color: transparent;
        border-bottom: 1px solid #D0D0D0;
        font-size: 19px;
        font-weight: normal;
        margin: 0 0 14px 0;
        padding: 14px 15px 10px 15px;
}

code {
        font-family: Consolas, Monaco, Courier New, Courier, monospace;
        font-size: 12px;
        background-color: #f9f9f9;
        border: 1px solid #D0D0D0;
        color: #002166;
        display: block;
        margin: 14px 0 14px 0;
        padding: 12px 10px 12px 10px;
}

#container {
        margin: 10px;
        border: 1px solid #D0D0D0;
        box-shadow: 0 0 8px #D0D0D0;
}

p {
        margin: 12px 15px 12px 15px;
}
</style>
</head>
<body>
        <div id="container">
                <h1>A Database Error Occurred</h1>
                <p>Error Number: 1048</p><p>Column 'ip_address' cannot be null</p>
                <p>INSERT INTO `CI_SESSIONS` (`id`, `ip_address`, `timestamp`, `data`) VALUES ('e9e9c8120a392b9009cd80196ce2fa2cabda516e', NULL, 1448581353, '__ci_last_regenerate|i:1448581353;')</p>
                <p>Filename: libraries/Session/drivers/Session_database_driver.php</p><p>Line Number: 220</p> 
        </div>
</body>

我不知道我哪里出错了。如果您需要任何其他信息,请告诉我们。我会喜欢任何帮助或建议。

谢谢。

1 个答案:

答案 0 :(得分:1)

这里的问题是您的安装已配置为使用数据库进行会话...并且由于您是从终端访问您的脚本,因此由于某种原因没有获得IP地址...出路将是不要将数据库用于会话数据(如果你的项目不需要它)。为此,请转到application/config/config.php并将$config['sess_use_database'] = TRUE;更改为$config['sess_use_database'] = FALSE; 那应该解决它。