ここの情報は古いです。ご理解頂いた上でお取り扱いください。

source: OpenPNE/branches/2_8/webapp/lib/db/file.php @ 2296

Last change on this file since 2296 was 2296, checked in by takanashi, 13 years ago

#558:ファイルアップロード関連の改善。管理画面からのファイル削除、トピック削除契機のファイル削除など

File size: 2.6 KB
RevLine 
[2105]1<?php
2/**
3 * @copyright 2005-2007 OpenPNE Project
4 * @license   http://www.php.net/license/3_01.txt PHP License 3.01
5 */
6
7/**
[2296]8 * IDからファイルの情報を取得する
9 *
10 * @param int $c_file_id
11 */
12function db_file_c_file4c_file_id($c_file_id)
13{
14    $sql = 'SELECT * FROM c_file WHERE c_file_id = ?';
15    $params = array(intval($c_file_id));
16    $file = db_get_row($sql, $params);
17    $file['size'] = strlen($file['bin']);
18    return $file;
19}
20
21/**
[2105]22 * 登録されているファイルをリストアップする
23 *
24 * @param int $page
25 * @param int $page_size
26 * @param int &$pager
27 */
28function db_file_c_file_list($page, $page_size, &$pager)
29{
30    $sql = 'SELECT c_file_id FROM c_file ORDER BY c_file_id DESC';
31    $id_list = db_get_col_page($sql, $page, $page_size);
32
33    $c_file_list = array();
[2188]34    foreach ($id_list as $i => $c_file_id) {
[2294]35        $sql = 'SELECT c_file_id, filename, original_filename, r_datetime, bin FROM c_file WHERE c_file_id = ?';
[2105]36        $params = array(intval($c_file_id));
[2188]37        $c_file_list[$i] = db_get_row($sql, $params);
38        $c_file_list[$i]['size'] = strlen($c_file_list[$i]['bin']);
[2105]39    }
40
41    $sql = 'SELECT COUNT(*) FROM c_file';
42    $total_num = db_get_one($sql);
43
44    $pager = admin_make_pager($page, $page_size, $total_num);
45
46    return $c_file_list;
47}
48
[2109]49/**
50 * ファイル情報をDBに挿入する
51 *
52 * @param string $filename
53 * @param string $bin
[2286]54 * @param string $original_filename
[2109]55 * @return mixed
56 */
[2286]57function db_file_insert_c_file($filename, $bin, $original_filename)
[2109]58{
59    $data = array(
60        'filename'   => $filename,
61        'bin'        => $bin,
[2286]62        'original_filename' => $original_filename,
[2109]63        'r_datetime' => db_now(),
64    );
65    return db_insert('c_file', $data, 'c_file_id');
66}
67
68/**
69 * ファイル名からファイル実体を取得
70 *
71 * @param string $filename
72 * @return mixed
73 */
74function db_file_c_file4filename($filename)
75{
76    $sql = 'SELECT * FROM c_file WHERE filename = ?';
77    $params = array($filename);
78    return db_get_row($sql, $params);
79}
80
[2286]81/**
82 * ファイル名からオリジナルのファイル名を取得
83 *
84 * @param string $filename
85 * @return string
86 */
87function db_file_original_filename4filename($filename)
88{
89    $sql = 'SELECT original_filename FROM c_file WHERE filename = ?';
90    $params = array($filename);
91    return db_get_one($sql, $params);
92}
[2295]93
94/**
95 * アップロードされたファイルを削除する
96 *
97 * @param string $filename  削除したいファイル名
98 * @return mixed
99 */
100function db_file_delete_c_file($filename)
101{
102    $sql = 'DELETE FROM c_file WHERE filename = ?';
103    $params = array($filename);
104    return db_query($sql, $params);
105}
106
[2105]107?>
Note: See TracBrowser for help on using the repository browser.