root/trunk/install/php/foltialib.php

リビジョン 128, 19.5 kB (コミッタ: sorshi, コミット時期: 14 年 前)

short open tag利用箇所を一括修正

Line 
1 <?php
2         
3 include("./foltia_config2.php");
4
5 /*
6 こちらのモジュールは
7 Apache + PHP + PostgreSQL 実験室
8 http://www.hizlab.net/app/
9 のサンプルを使わせていただいております。
10 ありがとうございます。
11 */
12
13     /* エラー表示の抑制 */
14     //error_reporting(0);
15
16     
17     //GET用フォームデコード
18       function getgetform($key) {
19     if ($_GET["{$key}"] != "") {
20         $value = $_GET["{$key}"];
21         $value = escape_string($value);
22         $value = htmlspecialchars($value);
23     return ($value);
24     }
25   }
26     //GET用数字フォームデコード
27       function getgetnumform($key) {
28 //    if ($_GET["{$key}"] != "") {
29     if (isset($_GET["{$key}"] )) {
30         $value = $_GET["{$key}"];
31         $value = ereg_replace("[^-0-9]", "", $value);
32         $value = escape_numeric($value);
33     return ($value);
34     }
35   }
36     
37     //フォームデコード
38       function getform($key) {
39     if ($_POST["{$key}"] != "") {
40         $value = $_POST["{$key}"];
41         $value = escape_string($value);
42         $value = htmlspecialchars($value);
43     return ($value);
44     }
45   }
46     //数字専用フォームデコード
47       function getnumform($key) {
48     if ($_POST["{$key}"] != "") {
49         $value = $_POST["{$key}"];
50         $value = escape_string($value);
51         $value = htmlspecialchars($value);
52         $value = ereg_replace("[^0-9]", "", $value);
53         $value = escape_numeric($value);
54     return ($value);
55     }
56   }
57
58     /* 全角カタカナ化してスペースを削除してインデックス用にする */
59     function name2read($name) {
60     $name = mb_convert_kana($name, "KVC", "EUC-JP");
61     $name = mb_convert_kana($name, "s", "EUC-JP");
62     $name = ereg_replace(" ", "", $name);
63
64         return $name;
65     }
66
67     /* 数字を半角化して数字化してインデックス用にする */
68     function pnum2dnum($num) {
69     $num = mb_convert_kana($num, "a", "EUC-JP");
70     $num = ereg_replace("[^0-9]", "", $num);
71
72         return $num;
73     }
74     
75     /* 終了関数の定義 */
76     function die_exit($message) {
77         ?>
78         <p class="error"><?php print "$message"; ?></p>
79         <div class="index"><a href="./">トップ</a></div>
80     </body>
81 </html><?php
82         exit;
83     }
84     
85     /* 入力した値のサイズをチェック */
86     function check_length($str, $maxlen, $must, $name) {
87         $len = strlen($str);
88         if ($must && $len == 0) {
89             die_exit("$name が入力されてません。必須項目です。");
90         }
91         if ($len > $maxlen) {
92             die_exit("$name は $len 文字以下で入力して下さい。全角文字は、一文字で二文字分と計算されます。");
93         }
94     }
95
96     /* SQL 文字列のエスケープ */
97     function escape_string($sql, $quote = FALSE) {
98         if ($quote && strlen($sql) == 0) {
99             return "null";
100         }
101         if (preg_match("/^pgsql/", DSN)){
102         return ($quote ? "'" : "") .
103                pg_escape_string($sql) .
104                ($quote ? "'" : "");
105         }else if (preg_match("/^sqlite/", DSN)){
106         /*    return ($quote ? "'" : "") .
107                 sqlite_escape_string($sql) .
108                 ($quote ? "'" : "");
109         */
110         return($sql);
111         }else{
112             return "null";
113         }
114     }
115     
116     /* SQL 数値のエスケープ */
117     function escape_numeric($sql) {
118         if (strlen($sql) == 0) {
119             return "null";
120         }
121         if (!is_numeric($sql)) {
122             die_exit("$sql は数値ではありません。");
123         }
124         return $sql;
125     }
126     
127     /* DBに接続 */
128     function m_connect() {
129     try {
130         $dbh = new PDO(DSN);
131         $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
132         return($dbh);
133     } catch (PDOException $e) {
134         die_exit($e->getMessage() . ": データベースに接続出来ませんでした。");
135         }
136         /* データベースと、PHP の内部文字コードが違う場合 */
137     }
138
139     /* データベースとの接続を切り離す */
140 function m_close($dbh) {
141     return null;
142     }
143
144 //旧関数 sql_queryに置き換え
145 function m_query($dbh, $query, $errmessage) {
146     try {
147         $rtn = $dbh->query($query);
148         return($rtn);
149     } catch (PDOException $e) {
150             /* エラーメッセージに SQL 文を出すのはセキュリティ上良くない!! */
151             $msg = $errmessage . "<br>\n" .
152             $e->getMessage() . "<br>\n" .
153             var_export($e->errorInfo, true) . "<br>\n" .
154                    "<small><code>" . htmlspecialchars($query) .
155                    "</code></small>\n";
156 //        $dbh->rollBack();
157         $dbh = null;
158             die_exit($msg);
159         }
160     }
161 /* SQL 文を実行 */
162 function sql_query($dbh, $query, $errmessage,$paramarray=null) {
163     try {
164         $rtn = $dbh->prepare("$query");
165         $rtn->execute($paramarray);
166         return($rtn);
167     } catch (PDOException $e) {
168             /* エラーメッセージに SQL 文を出すのはセキュリティ上良くない!! */
169             $msg = $errmessage . "<br>\n" .
170             $e->getMessage() . "<br>\n" .
171             var_export($e->errorInfo, true) . "<br>\n" .
172                    "<small><code>" . htmlspecialchars($query) .
173                    "</code></small>\n";
174 //        $dbh->rollBack();
175         $dbh = null;
176             die_exit($msg);
177         }
178     }
179
180     /* select した結果をテーブルで表示 */
181     function m_showtable($rs) {
182         /* 検索件数 */
183     $maxrows = 0;
184         
185     $rowdata = $rs->fetch();
186     if (! $rowdata) {
187             echo("<p class=\"msg\">データが存在しません</p>\n");
188             return 0;
189         }
190         
191         /* フィールド数 */
192     $maxcols = $rs->columnCount();
193         ?>
194 <table class="list" summary="データ検索結果を表示" border="1">
195     <thead>
196         <tr>
197             <?php
198                 /* テーブルのヘッダーを出力 */
199                 for ($col = 1; $col < $maxcols; $col++) {
200                     /* pg_field_name() はフィールド名を返す */
201              $meta = $rs->getColumnMeta($col);
202              $f_name = htmlspecialchars($meta["name"]);
203                     echo("<th abbr=\"$f_name\">$f_name</th>\n");
204                 }
205             ?>
206         </tr>
207     </thead>
208     <tbody>
209         <?php
210             /* テーブルのデータを出力 */
211           do {
212               $maxrows++;
213
214                 echo("<tr>\n");
215                 /* 1列目にリンクを張る */
216                 echo("<td><a href=\"edit.php?q_code=" .
217                      urlencode($rowdata[0]) . "\">" .
218                      htmlspecialchars($rowdata[1]) . "</a></td>\n");
219                 for ($col = 2; $col < $maxcols; $col++) { /* 列に対応 */
220                     echo("<td>".htmlspecialchars($rowdata[$col])."<br></td>\n");
221                 }
222                 echo("</tr>\n");
223           } while ($rowdata = $rs->fetch());
224         ?>
225     </tbody>
226 </table>
227         <?php
228         return $maxrows;
229     }
230
231
232 function m_viewdata($dbh, $code) {
233
234 /*これ使ってないよね?*/
235     }
236     
237
238 function printhtmlpageheader(){
239
240 global $useenvironmentpolicy;
241
242 $serveruri = getserveruri();
243 $username = $_SERVER['PHP_AUTH_USER'];
244
245 print "<p align='left'><font color='#494949'><A HREF = 'http://www.dcc-jpl.com/soft/foltia/' target=\"_blank\">foltia</A> | <A HREF = './index.php'>放映予定</A> | <A HREF = './index.php?mode=new'>新番組</A> | <A HREF = './listreserve.php'>予約一覧</A> | <A HREF = './titlelist.php'>番組一覧</A> | <A HREF = './viewepg.php'>番組表</A> | 録画一覧(<A HREF = './showplaylist.php'>録画順</A>・<A HREF = './showplaylist.php?list=title'>番組順</A>・<A HREF = './showplaylist.php?list=raw'>全</A>) | <A HREF = './showlib.php'>録画ライブラリ</A> |  <A HREF = './folcast.php'>Folcast</A>[<a href=\"itpc://$serveruri/folcast.php\">iTunesに登録</a>] | ";
246 if ($useenvironmentpolicy == 1){
247     print "【 $username 】";
248 }
249
250 print "</font></p>\n";
251
252 }
253
254
255 function renderepgstation($con,$stationname,$start){ //戻り値 なし EPGの局表示
256
257 $now = date("YmdHi");
258 $today = date("Ymd");   
259 $tomorrow = date ("Ymd",mktime(0, 0, 0, date("m")  , date("d")+1, date("Y")));
260 //$today = "20051013";   
261 //$tomorrow = "20051014";
262 //$epgstart = $today . "2000";
263 $epgstart = $start ;
264 //$epgend = $tomorrow . "0400";
265 $epgend = calcendtime($start , (8*60));
266 $query = "
267 SELECT startdatetime , enddatetime , lengthmin , epgtitle , epgdesc , epgcategory  ,ontvchannel  ,epgid
268 FROM foltia_epg
269 WHERE foltia_epg.ontvchannel = '$stationname' AND
270 enddatetime  > $epgstart  AND
271 startdatetime  < $epgend 
272 ORDER BY foltia_epg.startdatetime  ASC
273     ";
274     $rs = m_query($con, $query, "DBクエリに失敗しました");
275     $rowdata = $rs->fetch();
276     if (! $rowdata) {
277         print("番組データがありません<BR>");           
278 }else{
279 print "<table width=\"100%\"  border=\"0\">\n";
280 //print "<ul><!-- ($maxrows) $query -->\n";
281
282         do {
283 $printstarttime = substr($rowdata[0],8,2) . ":" substr($rowdata[0],10,2);
284 $tdclass = "t".substr($rowdata[0],8,2) .  substr($rowdata[0],10,2);
285 $title = htmlspecialchars($rowdata[3]);
286 $title = z2h($title);
287 $desc = htmlspecialchars($rowdata[4]);
288 $desc = z2h($desc);
289 $height htmlspecialchars($rowdata[2]) * 3;
290 $epgid htmlspecialchars($rowdata[7]);
291
292 print"
293       <tr>
294         <td height = \"$height\" >$printstarttime  <A HREF=\"./reserveepg.php?epgid=$epgid\">$title</A> $desc <!-- $rowdata[0] - $rowdata[1] --></td>
295       </tr>
296 ";
297 /*print"<li style=\"height:" . $height ."px;\" class=\"$tdclass\">
298 $printstarttime  <A HREF=\"./reserveepg.php?epgid=$epgid\">$title</A> $desc($rowdata[0] - $rowdata[1])
299 </li>\n";
300 */
301         } while ($rowdata = $rs->fetch());//do
302 //print "</ul>\n";
303 print "</table>\n";
304
305 }//if
306 }//end function
307
308 function calcendtime($start,$lengthmin){//戻り値 終了時刻(Ex:200510170130)
309 $startyear =   substr($start,0,4);
310 $startmonth =   substr($start,4,2);
311 $startday =   substr($start,6,2);
312 $starthour =   substr($start,8,2);
313 $startmin =   substr($start,10,2);
314 //int mktime ( [int hour [, int minute [, int second [, int month [, int day [, int year [, int is_dst]]]]]]] )
315 $endtime = date ("YmdHi",mktime($starthour  , $startmin + $lengthmin , 0, $startmonth  , $startday, $startyear));
316
317 return ($endtime );
318 }//end function
319
320
321 function z2h($string){ //戻り値 半角化した文字
322     $stringh = mb_convert_kana($string, "a", "EUC-JP");
323  return ($stringh );
324 }
325
326 function foldate2rfc822($start){//戻り値 RFC822スタイルの時刻表記
327     $startyear =   substr($start,0,4);
328     $startmonth =   substr($start,4,2);
329     $startday =   substr($start,6,2);
330     $starthour =   substr($start,8,2);
331     $startmin =   substr($start,10,2);
332
333     $rfc822 = date ("r",mktime($starthour  , $startmin , 0, $startmonth  , $startday, $startyear));
334     
335     return ($rfc822);
336 }//end sub
337
338 function foldate2print($start){//戻り値 日本語風時刻表記
339     $startyear =   substr($start,0,4);
340     $startmonth =   substr($start,4,2);
341     $startday =   substr($start,6,2);
342     $starthour =   substr($start,8,2);
343     $startmin =   substr($start,10,2);
344
345     $printabledate = date ("Y/m/d H:i",mktime($starthour  , $startmin , 0, $startmonth  , $startday, $startyear));   
346     return ($printabledate);
347 }//end sub
348
349 function getserveruri(){//戻り値 サーバアドレス Ex.www.dcc-jpl.com:8800/soft/foltia/
350
351 //リンクURI組み立て
352 $sv6 = $_SERVER['SCRIPT_NAME'];///dameNews/sarasorjyu/archives.php
353 $sv8 = $_SERVER['SERVER_NAME'];//sync.dcc-jpl.com
354 $sv9 = $_SERVER['SERVER_PORT'];
355 if ($sv9 == 80){
356     $port = "";
357 }else{
358     $port = ":$sv9";
359 }
360 $a = split("/", $sv6);
361 array_pop($a);
362
363 $scriptpath = implode("/", $a);
364
365 $serveruri = "$sv8$port$scriptpath";
366 return ($serveruri );
367 }//end sub
368
369
370 function getserverfqdn(){//戻り値 サーバアドレス Ex.www.dcc-jpl.com:8800
371
372 //リンクURI組み立て
373 $sv6 = $_SERVER['SCRIPT_NAME'];///dameNews/sarasorjyu/archives.php
374 $sv8 = $_SERVER['SERVER_NAME'];//sync.dcc-jpl.com
375 $sv9 = $_SERVER['SERVER_PORT'];
376 if ($sv9 == 80){
377     $port = "";
378 }else{
379     $port = ":$sv9";
380 }
381 $a = split("/", $sv6);
382 array_pop($a);
383
384 $scriptpath = implode("/", $a);
385
386 $serveruri = "$sv8$port";
387 return ($serveruri );
388 }//end sub
389
390
391 function printdiskusage(){//戻り値 なし
392 list (, $all, $use , $free, $usepercent) =  getdiskusage();
393
394 print "
395 <div style=\"width:100%;border:1px solid black;text-align:left;\"><span style=\"float:right;\">$free</span>
396 <div style=\"width:$usepercent;border:1px solid black;background:white;\">$use/$all($usepercent)</div>
397 </div>
398 ";
399 //exec('ps ax | grep ffmpeg |grep MP4 ' ,$ffmpegprocesses);
400 }//end sub
401
402
403 function getdiskusage(){//戻り値 配列 [,全体容量, 使用容量 , 空き容量, 利用割合]
404
405 global $recfolderpath,$recfolderpath;
406
407 //    exec ( "df -h  $recfolderpath | grep $recfolderpath", $hdfreearea);
408 //    $freearea = preg_split ("/[\s,]+/", $hdfreearea[0]);
409     exec ( "df -hP  $recfolderpath", $hdfreearea);
410     $freearea = preg_split ("/[\s,]+/", $hdfreearea[count($hdfreearea)-1]);
411
412     return $freearea;
413     
414 }//endsub
415
416
417 function printtrcnprocesses(){
418
419 $ffmpegprocesses = `ps ax | grep ffmpeg | grep -v grep |  wc -l `;
420 $uptime = exec('uptime');
421
422 print "<div style=\"text-align:left;\">";
423 print "$uptime<br>\n";
424 print "トラコン稼働数:$ffmpegprocesses<br>\n";
425 print "</div>";
426
427 }//endsub
428
429
430 function warndiskfreearea(){
431
432 global $demomode;
433
434 if ($demomode){
435 print "<!-- demo mode -->";
436 }else{
437
438 global $recfolderpath,$hdfreearea ;
439
440     exec ( "df   $recfolderpath | grep $recfolderpath", $hdfreearea);
441     $freearea = preg_split ("/[\s,]+/", $hdfreearea[0]);
442 $freebytes = $freearea[3];
443 if ($freebytes == "" ){
444 //
445 //print "<!-- err:\$freebytes is null -->";
446 }elseif($freebytes > 1024*1024*100 ){// 100GB以上あいてれば
447 //なにもしない
448 print "<style type=\"text/css\"><!-- --></style>";
449 }elseif($freebytes > 1024*1024*50 ){// 100GB以下
450 print "<style type=\"text/css\"><!--
451     body {
452     background-color: #CCCC99;
453      }
454 -->
455 </style>
456 ";
457 }elseif($freebytes > 1024*1024*30 ){// 50GB以下
458 print "<style type=\"text/css\"><!--
459     body {
460     background-color:#CC6666;
461      }
462 -->
463 </style>
464 ";
465 }elseif($freebytes > 0 ){// 30GB以下
466 print "<style type=\"text/css\"><!--
467     body {
468     background-color:#FF0000;
469      }
470 -->
471 </style>
472 ";
473 }else{ //空き容量 0バイト
474 print "<style type=\"text/css\"><!--
475     body {
476     background-color:#000000;
477      }
478 -->
479 </style>
480 ";
481 }//endif freebytess
482
483 }//endif demomode
484
485 }//endsub
486
487
488
489 function foldatevalidation($foldate){
490
491 if (strlen($foldate) == 12 ){
492
493     $startyear =   substr($foldate,0,4);
494     $startmonth =   substr($foldate,4,2);
495     $startday =   substr($foldate,6,2);
496     $starthour =   substr($foldate,8,2);
497     $startmin =   substr($foldate,10,2);
498
499     $startepoch = date ("U",mktime($starthour  , $startmin , 0, $startmonth  , $startday, $startyear));   
500     $nowe = time();
501     if ($startepoch > $nowe){
502     //print "$foldate:$startepoch:$nowe";
503         return TRUE;
504     }else{
505         return FALSE;
506     }    //end if $startepoch > $nowe
507 }else{
508     return FALSE;
509 }//end if ($foldate) == 12
510
511 }//end function
512
513
514
515 function login($con,$name,$passwd){
516 global $environmentpolicytoken;
517
518 //入力内容確認
519  if (((mb_ereg('[^0-9a-zA-Z]', $name)) ||(mb_ereg('[^0-9a-zA-Z]', $passwd) ))){
520     
521     //print "エラー処理\n";
522     //print "<!-- DEBUG name/passwd format error-->";
523     redirectlogin();
524     
525 }else{
526 //print "正常処理\n";
527 //db検索
528 escape_string($name);
529 escape_string($passwd);
530
531 $query = "
532 SELECT memberid ,userclass,name,passwd1
533 FROM foltia_envpolicy
534 WHERE foltia_envpolicy.name  = '$name' 
535     ";
536     $useraccount = m_query($con, $query, "DBクエリに失敗しました");
537         $rowdata = $useraccount->fetch();
538         if (! $rowdata) {
539             header("HTTP/1.0 401 Unauthorized");
540             redirectlogin();
541         }
542     
543         $memberid = $rowdata[0];
544         $userclass = $rowdata[1];
545         $username $rowdata[2];
546         $dbpasswd = $rowdata[3];
547
548         $rowdata = $useraccount->fetch();
549         if ($rowdata) {
550         header("HTTP/1.0 401 Unauthorized");
551         redirectlogin();
552         }
553
554 // passwdをdbから取りだし
555 if ($userclass == 0){
556 $dbpasswd = "$dbpasswd";
557 }else{
558 // db passwdとトークンを連結し
559 $dbpasswd = "$dbpasswd"."$environmentpolicytoken";
560 }
561 //それが入力と一致すれば認証
562 if ($passwd == $dbpasswd) {
563 //print "認証成功<br>$dbpasswd  $passwd\n";
564 }else{
565 //print "認証失敗<br>$dbpasswd  $passwd\n";
566         header("HTTP/1.0 401 Unauthorized");
567         //print "<!-- DEBUG passwd unmatch error>";
568         redirectlogin();
569 }
570 }//end if mb_ereg
571 }//end function login
572
573
574
575
576 function redirectlogin(){
577 global $environmentpolicytoken;
578
579 print "<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML 2.0//EN\">\n";
580 print "<html><head>\n";
581 print "<title>foltia:Invalid login</title>\n";
582 print "</head><body>\n";
583 print "<h1>Invalid login</h1>";
584 print "<p>foltiaヘのアクセスにはログインが必要です。再ログインはリロードやブラウザ再起動で、新規アカウント登録は<a href=\"./accountregist.php\">こちらから。</a></p>";
585 if ($environmentpolicytoken == ""){
586 }else{
587     print "<p>突然この画面が表示された場合にはセキュリティコードが変更されたかも知れません。</p>";
588 }
589 print "</p><hr>\n";
590 print "<address>foltia by DCC-JPL Japan/foltia Project.  <a href = \"http://www.dcc-jpl.com/soft/foltia/\">http://www.dcc-jpl.com/soft/foltia/</a></address>\n";
591 print "</body></html>\n";
592
593
594
595 exit;
596 }//end function redirectlogin
597
598 function getuserclass($con){
599 global $useenvironmentpolicy;
600 $username = $_SERVER['PHP_AUTH_USER'];
601
602 if ($useenvironmentpolicy == 1){
603 $query = "
604 SELECT memberid ,userclass,name,passwd1
605 FROM foltia_envpolicy
606 WHERE foltia_envpolicy.name  = '$username' 
607     ";
608         $useraccount = m_query($con, $query, "DBクエリに失敗しました");
609         $rowdata = $useraccount->fetch();
610         if (! $rowdata) {
611             return (99);
612         }
613     
614         $userclass = $rowdata[1];
615
616         $rowdata = $useraccount->fetch();
617         if ($rowdata) {
618             return (99);
619         }
620
621         return ($userclass);
622     
623 }else{
624     return (0);//環境ポリシー使わないときはつねに特権モード
625 }//end if
626 }//end function getuserclass
627
628
629
630 function getmymemberid($con){
631 global $useenvironmentpolicy;
632 $username = $_SERVER['PHP_AUTH_USER'];
633
634 if ($useenvironmentpolicy == 1){
635 $query = "
636 SELECT memberid ,userclass,name,passwd1
637 FROM foltia_envpolicy
638 WHERE foltia_envpolicy.name  = '$username' 
639     ";
640         $useraccount = m_query($con, $query, "DBクエリに失敗しました");
641         $rowdata = $useraccount->fetch();
642         if (! $rowdata) {
643     return (-1);//エラー
644         }
645
646         $memberid = $rowdata[0];
647
648         $rowdata = $useraccount->fetch();
649         if ($rowdata) {
650             return (-1);
651         }
652
653         return ($memberid);
654     
655 }else{
656     return (0);//環境ポリシー使わないときはつねに特権モード
657 }//end if
658 }//end function getuserclass
659
660
661 function getmemberid2name($con,$memberid){
662 global $useenvironmentpolicy;
663 //$username = $_SERVER['PHP_AUTH_USER'];
664
665 if ($useenvironmentpolicy == 1){
666 $query = "
667 SELECT memberid ,userclass,name,passwd1
668 FROM foltia_envpolicy
669 WHERE foltia_envpolicy.memberid  = '$memberid' 
670     ";
671         $useraccount = m_query($con, $query, "DBクエリに失敗しました");
672         $rowdata = $useraccount->fetch();
673         if (! $rowdata) {
674     return ("");//エラー
675         }
676     
677         $name = $rowdata[2];
678
679         $rowdata = $useraccount->fetch();
680         if ($rowdata) {
681     return ("");
682         }
683
684         return ($name);
685
686     }else{
687         return ("");
688     }//end if
689
690 }//end function getmemberid2name
691
692
693
694 function number_page($p,$lim){
695 //Autopager・ページリンクで使用している関数
696 //下記は関数をしているファイル名
697 //index.php  showplaylist.php  titlelist.php  showlib.php  showlibc.php
698 ///////////////////////////////////////////////////////////////////////////
699 // ページ数の計算関係
700 // 第1引数 : $p       : 現在のページ数
701 // 第2引数 : $lim     : 1ページあたりに表示するレコード数
702 ///////////////////////////////////////////////////////////////////////////
703
704     if($p == 0){
705         $p2 = 2;        //$p2の初期値設定
706     }else{
707         $p2 = $p;       //次のページ数の値を$p2に代入する
708         $p2++;
709     }
710
711     if($p < 1){
712         $p = 1;
713     }
714     //表示するページの値を取得
715     $st = ($p -1) * $lim;
716
717     //
718     return array($st,$p,$p2);
719 }//end number_page
720
721
722 function page_display($query_st,$p,$p2,$lim,$dtcnt,$mode){
723 //Autopager・ページリンクで使用している関数
724 //下記は関数を使用しているファイル名
725 //index.php showplaylist.php titlelist.php showlib.php showlibc.php
726 /////////////////////////////////////////////////////////////////////////////
727 // Autopager処理とページのリンクの表示
728 // 第1引数 : $query_st        : クエリの値
729 // 第2引数 : $p            : 現在のページ数の値
730 // 第3引数 : $p2           : 次のページ数の値
731 // 第4引数 : $lim          : 1ページあたりに表示するレコード数
732 // 第5引数 : $dtcnt        : レコードの総数
733 // 第6引数 : $mode         :【新番組】mode=newのときにリンクページを表示させないフラグ(index.phpのみで使用)
734 ////////////////////////////////////////////////////////////////////////////
735     if($query_st == ""){
736         //ページ総数取得
737         $page = ceil($dtcnt / $lim);
738         //$modeのif文は【新番組】の画面のみで使用
739         if($mode == ''){
740             echo "$p/$page";         //  現在のページ数/ページ総数
741         }
742         //ページのリンク表示
743         for($i=1;$i <= $page; $i++){
744             print("<a href=\"".$_SERVER["PHP_SELF"]."?p=$i\" > $i </a>");
745         }
746         //Autopageingの処理
747         if($page >= $p2 ){
748             print("<a rel=next href=\"".$_SERVER["PHP_SELF"]."?p=$p2\" > </a>");
749         }
750     }else{      //query_stに値が入っていれば
751         $query_st = $_SERVER['QUERY_STRING'];
752         $page = ceil($dtcnt / $lim);
753         echo "$p/$page";
754         //ページのリンク表示
755         for($i=1;$i <= $page; $i++){
756             $query_st preg_replace('/p=[0-9]+&/','',$query_st);    //p=0〜9&を空欄にする正規表現
757             print("<a href=\"".$_SERVER["PHP_SELF"]."?p=$i&$query_st\" > $i </a>");
758         }
759         //Autopageingの処理
760         if($page >= $p2 ){
761             $query_st preg_replace('/p=[0-9]+&/','',$query_st);
762             print("<a rel=next href=\"".$_SERVER["PHP_SELF"]."?p=$p2&$query_st\" > </a>");
763         }
764     }
765     return array($p2,$page);
766 }// end page_display
767
768 ?>
769
Note: リポジトリブラウザについてのヘルプは TracBrowser を参照してください。
track feed