gpt4 book ai didi

php - 阻止 Codeigniter Cron 作业的 session

转载 作者:行者123 更新时间:2023-11-28 23:43:55 27 4
gpt4 key购买 nike

我对创建 cron 作业还很陌生。昨天才开始涉猎。

我为本地房地产经纪人设计了一个网站,我的数据库中有一个字段用于“状态”(待售、待售、已售出)、“售出日期”(如果未售出则为 NULL)和“可见”( bool 值)。我正在尝试创建一个 cron 作业,每天检查一次“SoldDate”过去超过 30 天的任何已售特性,如果为 TRUE,则将“Visible”字段更改为 0(假)。

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

我正在使用 Codeigniter 来构建我的网站。下面是我的代码:

Cron Controller

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!';

}

}

前端 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');
}
}
}

}

我的 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();
}

}

我的模型

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)它没有运行并给我一个错误关于 session 数据库发生数据库错误。 “ip_address 不能为空”

我不确定它为什么要尝试创建 session 数据。我还没有在 Fronted_Controller 中创建 session 。

下面是我得到的错误:

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>

我不确定我哪里出错了。如果您需要任何其他信息,请告诉我。我希望得到任何帮助或建议。

谢谢。

最佳答案

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

关于php - 阻止 Codeigniter Cron 作业的 session ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33948458/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com