Codeigniter传递数据以查看并返回控制器

时间:2014-06-11 12:18:45

标签: php codeigniter

我有一个有效的CSV上传功能,可以将数据弹出到数据库中,然后打开一个包含数据表的视图供用户查看。

我想要做的是在视图上有一个按钮,然后开始处理数据,并且只处理添加的新数据。如果表有100个旧行但我在上传时添加了50个新行,我只想处理它们。听起来很简单,但我想不出一种方法将数据(要处理的行)传递回将要进行处理的新控制器。数据是一个数组(id的数组),因为数组最多可能有400个条目,所以在url的末尾放置太多的变量

我认为这样做的唯一方法似乎很糟糕。我可以使用json编码将数组放入数据库表的单个单元格中,并为此表行提供一个id。然后我可以将视图中的id传递给新控制器并检索数组。必须有更好的方法吗?

1 个答案:

答案 0 :(得分:1)

移动解析CSV的代码并将数组构建到自己的函数中。我们假设您正在创建一个_parse_csv()方法,该方法将接受$filename作为参数,然后读取csv,处理数据并返回数组。您可以使用var_export并将已处理的数组写入磁盘并加载到_parse_csv方法而不是重新处理。

private function _parse_csv($filename) {
    // do some stuff with the uploaded csv here
    // return an array of data from the csv
    return $csv_array;
}

在csv upload上调用此方法并将上传的文件名传递给它。

您的process data按钮可以将$filename传递给将CSV解析为数组以进行处理的控制器/方法。

使用class属性定义上传文件夹。处理时不要传递上传文件夹,只传递文件名。

警告:此选项如上所述不安全。您需要采取额外的预防措施,以确保用户无法通过猜测文件名参数来启动csv处理。