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

source: OpenPNE/branches/2.8.x/webapp/lib/db/file.php @ 2659

Last change on this file since 2659 was 2659, checked in by ogawa, 16 years ago

#650:Webサーバ分散環境でファイルアップロードができない

File size: 3.8 KB
Line 
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/**
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/**
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();
34    foreach ($id_list as $i => $c_file_id) {
35        $sql = 'SELECT c_file_id, filename, original_filename, r_datetime, bin FROM c_file WHERE c_file_id = ?';
36        $params = array(intval($c_file_id));
37        $c_file_list[$i] = db_get_row($sql, $params);
38        $c_file_list[$i]['size'] = strlen($c_file_list[$i]['bin']);
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
49/**
50 * ファイル情報をDBに挿入する
51 *
52 * @param string $filename
53 * @param string $bin
54 * @param string $original_filename
55 * @return mixed
56 */
57function db_file_insert_c_file($filename, $bin, $original_filename)
58{
59    $data = array(
60        'filename'   => $filename,
61        'bin'        => $bin,
62        'original_filename' => $original_filename,
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
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}
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
107/**
108 * 管理画面用に一時ファイル情報をDBに挿入する
109 *
110 * @param string $filename
111 * @param string $filepath
112 * @param string $original_filename
113 */
114function db_file_insert_c_tmp_file($filename, $filepath, $original_filename)
115{
116    if (!is_readable($filepath)) {
117        return false;
118    }
119
120    $fp = fopen($filepath, 'rb');
121    $file_data = fread($fp, filesize($filepath));
122    fclose($fp);
123
124    $sql = 'DELETE FROM c_tmp_file WHERE filename = ?';
125    $params = array($filename);
126    db_query($sql, $params);
127
128    $data = array(
129        'filename'   => $filename,
130        'bin'        => $file_data,
131        'original_filename' => $original_filename,
132        'r_datetime' => db_now(),
133    );
134    return db_insert('c_tmp_file', $data);
135}
136
137/**
138 * DBから管理画面用の一時ファイル情報を削除する
139 */
140function db_file_clear_tmp_db($uid)
141{
142    $sql = 'DELETE FROM c_tmp_file WHERE filename LIKE ?';
143    $params = array('%_' . $uid . '.%');
144    db_query($sql, $params);
145}
146
147/**
148 * ファイル名から一時保存ファイルを取得
149 */
150function db_file_c_tmp_file4filename($filename)
151{
152    $sql = 'SELECT * FROM c_tmp_file WHERE filename = ?';
153    $params = array($filename);
154    return db_get_row($sql, $params);
155}
156?>
Note: See TracBrowser for help on using the repository browser.