程序
<?php
/*
+---------------------------------------------------+
| Name : NEATPIC (无数据版本)
+---------------------------------------------------+
| Created / Modify : 2003-12-27 / 2004-4-13
+---------------------------------------------------+
| Version : 1.2.3
+---------------------------------------------------+
| Author : walkerlee, gouki
+---------------------------------------------------+
| Powered by NEATSTUDIO 2002 - 2004
+---------------------------------------------------+
| QQ : 808075
| Email :
| Homepge :
| BBS :
+---------------------------------------------------+
| Note :
|
| 1.本软件对于非商业用户完全免费,如果要使用在商业用途
| 方面,必须取得作者的授权.
|
| 2.你可以任意传播以及修改本程序,但不能以任何形式删除
| 本程序的版权.请记住,保留作者版权是对作者工作的尊敬.
|
| 3.如果有问题,可以通过上面提供的方式进行解答,但作者
| 学业繁重,如果不能及时或者不解答,请谅解.
|
| 4.作者对使用该程序导致的问题,不予以负责.
|
| 5.本程序版权归 NeatStudio 所有.禁止任何侵权行为!
|
+---------------------------------------------------+
*/
/*
+----------------------------------+
| Config
+----------------------------------+
| C / M : 2003-12-28 / 2004-4-13
+----------------------------------+
*/
$configAdminPass = "neatpic"; //管理员密码 注:安全起见,默认密码不能登陆管理
$configWantedPass = false; //查看相册是否需要密码 需要:true 不需要:false
$configOpenGzip = true; //是否压缩页面 压缩:true 不压缩:false
$configShowPicSize = false; //是否显示图片的大小 (单位:KB) 显示:true 不显示:false (注:不显示,程序运行速度将提高)
$configExt = array('jpg', 'jpeg', 'gif', 'png', 'bmp'); //图片类型
$strLenMax = 25; //文件名字限制长度 (防止撑破表格)
$configEachPageMax = 16; //每页显示的图片数目
$configEachLineMax = 4; //每行显示的图片数目
$configTDWidth = 185; //表格宽度
$configTDHeight = 138; //表格高度
$configPageMax = 5; //分页前后预览数
$configDirPasswordFile = "neatpicPassword.php"; //密码文件
$configTilte = "欢迎光临“开花的草”相册。设有精美小图、动态图片、人物图片、图文并茂、网页横幅、站长相关。"; //标题
$configVer = "1.2.3"; //程序版本号
/*
+----------------------------------+
| Class
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
Class neatpic
{
var $configWantedPass;
var $configAdminPass;
var $configOpenGzip;
var $configShowPicSize;
var $configExt = array();
var $strLenMax;
var $configEachPageMax;
var $configEachLineMax;
var $configTDHeight;
var $configTDWidth;
var $configPageMax;
var $configTilte;
var $configVer;
var $dirOptionList;
var $timer;
var $usedTime;
var $pathLevelNum;
var $nowDirNmae;
var $dirNum;
var $picNum;
var $pageTotal;
var $start;
var $offSet;
var $pageStart;
var $pageMiddle;
var $pageEnd;
var $temp;
var $picID;
var $picRealSizeWidth;
var $picRealSizeHeight;
var $picArray = array();
var $picFileArray = array();
var $dirArray = array();
var $dirNameArray = array();
var $pathArray = array();
var $pathError = false;
var $page;
var $path;
var $style;
var $c;
/*
+----------------------------------+
| Constructor
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function neatpic($configWantedPass, $configAdminPass, $configDirPasswordFile, $configOpenGzip, $configShowPicSize, $configExt, $strLenMax, $configEachPageMax, $configEachLineMax, $configTDHeight, $configTDWidth, $configPageMax, $configTilte, $configVer)
{
$this->configWantedPass = & $configWantedPass;
$this->configAdminPass = & $configAdminPass;
$this->configDirPasswordFile = & $configDirPasswordFile;
$this->configOpenGzip = & $configOpenGzip;
$this->configShowPicSize = & $configShowPicSize;
$this->configExt = & $configExt;
$this->strLenMax = & $strLenMax;
$this->configEachPageMax = & $configEachPageMax;
$this->configEachLineMax = & $configEachLineMax;
$this->configTDHeight = & $configTDHeight ;
$this->configTDWidth = & $configTDWidth;
$this->configPageMax = & $configPageMax;
$this->configTilte = & $configTilte;
$this->configVer = & $configVer;
}
/*
+----------------------------------+
| Open gzip
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function gzip()
{
if ($this->configOpenGzip == true)
ob_start("ob_gzhandler");
}
/*
+----------------------------------+
| Get the querystring
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function getVars()
{
$this->page = rawurldecode($_GET['page']);
$this->path = rawurldecode($_GET['path']);
$this->style = $_GET['style'];
if (!$this->style) $this->style = "small";
if (!$this->path) $this->path = ".";
}
/*
+----------------------------------+
| Check error
+----------------------------------+
| C / M : 2003-12-28 / 2004-1-1
+----------------------------------+
*/
function checkError()
{
if (preg_match("/\.\./", $this->path)) $pathError = true;
if (!is_dir($this->path)) $pathError = true;
if ($pathError == true)
{
header("location:".$_SERVER['PHP_SELF']);
exit;
}
}
/*
+----------------------------------+
| Path array initialize
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function pathArrayInitialize()
{
if (!$this->path) $this->path = ".";
$this->pathArray = explode("/", $this->path);
$this->pathLevelNum = count($this->pathArray);
$this->nowDirName = $this->pathArray[$this->pathLevelNum - 1];
if ($this->nowDirName == ".") $this->nowDirName = "根目录";
}
/*
+----------------------------------+
| Timer
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function timer()
{
$time = explode( " ", microtime());
$usec = (double)$time[0];
$sec = (double)$time[1];
$this->timer = $usec + $sec;
}
/*
+----------------------------------+
| Show used time
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function usedTime()
{
$startTime = $this->timer;
$this->timer();
$endTime = $this->timer;
$usedTime = $endTime - $startTime;
$this->usedTime = sprintf("%0.4f", $usedTime);
}
/*
+----------------------------------+
| Make over direct
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function makeOverdirect()
{
$overPath = ".";
for($i = 1; $i < $this->pathLevelNum - 1; $i++)
{
$overPath = $overPath."/".$this->pathArray[$i];
}
$this->dirArray[] = $overPath;
$this->dirNameArray[] = "上级目录";
for($i = 1; $i < $this->pathLevelNum; $i++)
{
$this->encodePath .= rawurlencode($this->pathArray[$i])."/";
}
}
/*
+----------------------------------+
| GetFileExt
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function getFileExt($fileName)
{
$pos = strrpos($fileName, '.');
return strtolower(substr($fileName, $pos+1, (strlen($fileName)-$pos-1)));
}
/*
+----------------------------------+
| Make direct list
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function makeDirList()
{
$dir = dir($this->path);
while($file = $dir->read())
{
if ($file <> "." and $file <> "..")
{
$fileName = $file;
$file = $this->path."/".$file;
if (is_dir($file))
{
$this->dirArray[] = $file;
$this->dirNameArray[] = $fileName;
}
if (in_array($this->getFileExt($file), $this->configExt))
{
$this->picEncodeArray[] = "./" . $this->encodePath . rawurlencode($fileName);
$this->picArray[] = $file;
$this->picFileArray[] = $fileName;
}
}
}
}
/*
+----------------------------------+
| Get each array number
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function getEachArrayNum()
{
$this->dirNum = count($this->dirArray);
$this->picNum = count($this->picArray);
}
/*
+----------------------------------+
| Make page bar
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function makePageBar()
{
$this->pageTotal = ceil($this->picNum / $this->configEachPageMax);
if (!$this->page or $this->page < 0) $this->page = 1;
if ($this->page > $this->pageTotal) $this->page = $this->pageTotal;
$this->offSet = $this->configEachPageMax * $this->page;
$this->start = $this->offSet - $this->configEachPageMax;
if ($this->start < 0) $this->start = 0;
if ($this->offSet > $this->picNum) $this->offSet = $this->picNum;
$this->pageStart = $this->page - $this->configPageMax;
if ($this->pageStart <= 0) $this->pageStart = 1;
$this->pageMiddle = $this->page + 1;
$this->pageEnd = $this->pageMiddle + $this->configPageMax;
if ($this->page <= $this->configPageMax) $this->pageEnd = $this->configPageMax * 2 + 1;
if ($this->pageEnd > $this->pageTotal) $this->pageEnd = $this->pageTotal + 1;
}
/*
+----------------------------------+
| Show page bar
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function showPageBar()
{
print("<center>\n");
print("
");
print("[ <A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& - 1)."\" title=\"上一页\">上一页</A> ] ");
print("<A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& title=\"首页\"><< </A>\n");
for ($i = $this->pageStart; $i < $this->page; $i++)
print("<A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& title=\"第 ".$i." 页\">[".$i."]</A> ");
printf("[<FONT COLOR=\"red\"><B>%s</B></FONT>]", $this->page);
for ($i = $this->pageMiddle; $i < $this->pageEnd; $i++)
print("<A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& title=\"第 ".$i." 页\">[".$i."]</A> ");
print("...<A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& title=\"第 " . $this->pageTotal . " 页\">[" . $this->pageTotal . "]</A>\n");
print(" <A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& title=\"尾页\">>></A>\n");
print("[ <A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& + 1)."\" title=\"下一页\">下一页</A> ] 共 <B><FONT COLOR=\"red\">".$this->pageTotal."</FONT></B> 页 当前所在第 <B><FONT COLOR=\"red\">".$this->page."</FONT></B> 页");
print("
");
print("</center>\n");
}
/*
+----------------------------------+
| Set picture ID
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function setPicID($id)
{
$this->picID = $id;
}
/*
+----------------------------------+
| Get picture dimension
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function getPicDim()
{
$picSize = GetImageSize($this->picArray[$this->picID]);
preg_match("!width=\"(.*)\" height=\"(.*)\"!", $picSize['3'], $tempSize);
$this->picRealSizeWidth = $tempSize['1'];
$this->picRealSizeHeight = $tempSize['2'];
/*
$tempSize['1'] < $this->configTDWidth ? $this->temp['Width'] = $tempSize['1'] : $this->temp['Width'] = $this->configTDWidth;
$tempSize['2'] < $this->configTDHeight ? $this->temp['Height'] = $tempSize['2'] : $this->temp['Height'] = $this->configTDHeight;
*/
$tWidth = $this->picRealSizeWidth / $this->configTDWidth;
$tHeight = $this->picRealSizeHeight / $this->configTDHeight;
if ($this->picRealSizeWidth > $this->configTDWidth OR $this->picRealSizeHeight > $this->configTDHeight)
{
if ($tWidth > $tHeight)
{
$this->temp['Width'] = $this->configTDWidth;
$this->temp['Height'] = number_format($this->picRealSizeHeight / $tWidth);
}
elseif ($tWidth < $tHeight)
{
$this->temp['Height'] = $this->configTDHeight;
$this->temp['Width'] = number_format($this->picRealSizeWidth / $tHeight);
}
else
{
$this->temp['Width'] = $this->configTDWidth;
$this->temp['Height'] = $this->configTDHeight;
}
}
else
{
$this->temp['Width'] = $this->picRealSizeWidth;
$this->temp['Height'] = $this->picRealSizeHeight;
}
}
/*
+----------------------------------+
| Show the title javascript
+----------------------------------+
| C / M : 2003-12-29 / 2003-12-30
+----------------------------------+
*/
function ShowJS()
{
print('
<script>
/******************************************************************************
NEATPIC Show Title
Modified by: walkerlee
Date: 2003-12-30
Based upon: Crossday Studio and
*******************************************************************************/
tPopWait=20;
showPopStep=10;
popOpacity=85;
sPop=null;
curShow=null;
tFadeOut=null;
tFadeIn=null;
tFadeWaiting=null;
document.write("<style type=\'text/css\'id=\'defaultPopStyle\'>");
document.write(".cPopText { font-family: Verdana, Tahoma; background-color: #F7F7F7; border: 1px #000000 solid; font-size: 11px; padding-right: 4px; padding-left: 4px; height: 20px; padding-top: 2px; padding-bottom: 2px; filter: Alpha(Opacity=0)}");
document.write("</style>");
document.write("<div id=\'popLayer\' class=\'cPopText\'></div>");
function showPopupText(){
var o=event.srcElement;
MouseX=event.x;
MouseY=event.y;
if(o.alt!=null && o.alt!="") { o.pop=o.alt;o.alt="" }
if(o.title!=null && o.title!=""){ o.pop=o.title;o.title="" }
if(o.pop) { o.pop=o.pop.replace("\n","
"); o.pop=o.pop.replace("\n","
"); }
if(o.pop!=sPop) {
sPop=o.pop;
clearTimeout(curShow);
clearTimeout(tFadeOut);
clearTimeout(tFadeIn);
clearTimeout(tFadeWaiting);
if(sPop==null || sPop=="") {
popLayer.innerHTML="";
popLayer.style.filter="Alpha()";
popLayer.filters.Alpha.opacity=0;
} else {
if(o.dyclass!=null) pop
else pop showIt() {
popLayer.className=popStyle;
popLayer.innerHTML=\'
\'+sPop+\'
\';
popWidth=popLayer.clientWidth;
popHeight=popLayer.clientHeight;
if(MouseX+12+popWidth>document.body.clientWidth) popLeftAdjust=-popWidth-24
else popLeftAdjust=0;
if(MouseY+12+popHeight>document.body.clientHeight) popTopAdjust=-popHeight-24
else popTopAdjust=0;
popLayer.style.left=MouseX+12+document.body.scrollLeft+popLeftAdjust;
popLayer.style.top=MouseY+12+document.body.scrollTop+popTopAdjust;
popLayer.style.filter="Alpha(Opacity=0)";
fadeOut();
}
function fadeOut(){
if(popLayer.filters.Alpha.opacity<popOpacity) {
popLayer.filters.Alpha.opacity+=showPopStep;
tFadeOut=setTimeout("fadeOut()",1);
}
}
document.onmouseover=showPopupText;
</script>
');
}
/*
+----------------------------------+
| Show css
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function showCSS()
{
print("
<style type='text/css'>
a:link, a:visited, a:active { text-decoration: none; color: #000 }
a:hover { color: orangered; text-decoration:none }
BODY { scrollbar-face-color: #DEE3E7; scrollbar-highlight-color: #FFFFFF; scrollbar-shadow-color: #DEE3E7; scrollbar-3dlight-color: #D1D7DC; scrollbar-arrow-color: #006699; scrollbar-track-color: #EFEFEF; scrollbar-darkshadow-color: #98AAB1; font: 12px Verdana; color:#333333; font-family: Tahoma,Verdana, Tahoma, Arial,Helvetica, sans-serif; font-size: 12px; color: #000; margin:0px 12px 0px 12px;background-color:#FFF }
TD {font: 12px Verdana; color:#333333; font-family: Tahoma,Verdana, Tahoma, Arial,Helvetica, sans-serif; font-size: 12px; color: #000; };
input, textarea {
font-family: Verdana;
font-size: 8pt;
border: 1px solid #C0C0C0;
color:#333333; background-color:#FFFFFF
}
</style>
");
}
/*
+----------------------------------+
| Show title
+----------------------------------+
| C / M : 2003-12-28 / --
+----------------------------------+
*/
function showTitle()
{
print("<meta HTTP-EQUIV=Content-Type content=\"text/html; charset=gb2312\">\n");
print("<title>".$this->configTilte."</title>\n");
print("<BODY>\n");
print("<A NAME=\"TOP\">\n");
print("
\n");
print("<center>\n");
print($this->configTilte);
print("</center>\n");
print("
\n");
}
/*
+----------------------------------+
| Show state
+----------------------------------+
| C / M : 2003-12-28 / 2004-4-9
+----------------------------------+
*/
function showState()
{
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER>当前目录 : <B><FONT COLOR=\"red\">".$this->nowDirName."</FONT></B> [ 子目录数 : <B><FONT COLOR=\"red\">". ($this->dirNum - 1) ."</FONT></B> 图片数目 : <B><FONT COLOR=\"red\">".$this->picNum."</FONT></B> 每页显示 : <B><FONT COLOR=\"red\">".$this->configEachPageMax."</FONT></B> 个 ] 查看模式: [ <A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& COLOR=\"blue\" title=\"按照真实比例查看图片\">真实</FONT></A> ] [ <A HREF=\"".$_SERVER['PHP_SELF']."?path=".rawurlencode($this->path)."& COLOR=\"blue\" title=\"以缩小比例查看图片\">缩略</FONT></A> ] </CENTER>");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
/*
+----------------------------------+
| Make option direct list
+----------------------------------+
| C / M : 2004-3-24 / -- --
+----------------------------------+
*/
function makeOptionList()
{
$this->dirOptionList = "<select onchange=\"location='" . $_SERVER['PHP_SELF'] . "?path='+this.options[this.selectedIndex].NAME\">\n";
$this->dirOptionList .= "<option ID=\"\">-- 选择目录 --</option>\n";
for($i = 0; $i < $this->dirNum; $i++)
$this->dirOptionList .= "<option NAME=\"" . rawurlencode($this->dirArray[$i]) . "\">" . $this->dirNameArray[$i] . "</option>\n";
$this->dirOptionList .= "</select>\n";
}
/*
+----------------------------------+
| Show direct list
+----------------------------------+
| C / M : 2003-12-28 / 2004-3-24
+----------------------------------+
*/
function showDirList()
{
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\" width=\"100\">\n");
print("<CENTER>目录列表</CENTER>");
print("</td>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print(" " . $this->dirOptionList . " <input type=button value=\" 上级目录 \" OnClick=\"self.location='" . $_SERVER['PHP_SELF'] . "?path=" . rawurlencode($this->dirArray[0]) . "'\" alt=\"返回 上级目录\">");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
/*
+----------------------------------+
| Cute the long file name
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function sortName($filename)
{
$filename = substr($filename, 0, strrpos($filename, '.'));
$strlen = strlen($filename);
if ($strlen > $this->strLenMax) $filename = substr($filename, 0, ($this->strLenMax)) . chr(0) . "...";
return $filename;
}
/*
+----------------------------------+
| Show picture list
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function showPicList()
{
print("<FORM name=\"dfile\" action=\"". $_SERVER['PHP_SELF'] ."?action=del& . $_GET['style'] . "&page=" . $_GET['page'] . "\" METHOD=\"POST\">\n");
print("<INPUT TYPE=hidden NAME=\"path\" VALUE=\"" . rawurlencode($this->path) . "\">");
/*
+----------------------------------+
| Real size style
+----------------------------------+
*/
$session = & $_SESSION;
if ($this->style == "real")
{
print("<center>\n");
for($i = $this->start; $i < $this->offSet; $i++)
{
$this->setPicID($i);
$this->getPicDim();
/*
+----------------------------------+
| Read and format this picture's size
+----------------------------------+
*/
$this->configShowPicSize == true ? $picFileSize = sprintf("%0.2f", filesize($this->picArray[$i]) / 1024) : $picFileSize = " -- ";
if ($session['neatpicLogined'])
print("
<INPUT TYPE=\"checkbox\" NAME=\"delfile[]\" VALUE=\"" . $this->picFileArray[$i] . "\" title=\"删除图片 <FONT COLOR=blue>" . $this->picFileArray[$i] . "</FONT>\"> ");
printf("<A href=\"#TOP\">返回顶部</A> #%s %s %s × %s %s KB
\n",($i + 1), $this->picFileArray[$i], $this->picRealSizeWidth, $this->picRealSizeHeight, $picFileSize);
printf("<A href=\"%s\" target=\"_blank\"><IMG SRC=\"%s\" BORDER=\"0\"></A>
\n", $this->picEncodeArray[$i], $this->picEncodeArray[$i]);
}
print("</center>\n");
}
/*
+----------------------------------+
| Small size style
+----------------------------------+
*/
else
{
print("<center>\n");
printf("<TABLE border=0><TBODY><TR>\n");
for($i = $this->start; $i < $this->offSet; $i++)
{
$I++;
$this->setPicID($i);
$this->getPicDim();
/*
+----------------------------------+
| Read and format this picture's size
+----------------------------------+
*/
$this->configShowPicSize == false ? $picFileSize = " -- " : $picFileSize = sprintf("%0.2f", filesize($this->picArray[$i]) / 1024);
print("<TD 1px solid #CCCCCC\">\n");
print("<TABLE BORDER=\"0\" CELLPADDING=\"0\" CELLSPACING=\"0\" COLLAPSE\">\n");
print("<TBODY>\n");
print("<TR>\n");
print("<TD bgcolor=\"#F7F7F7\" height=\"20\" colspan=\"3\"><CENTER>" . $this->sortName($this->picFileArray[$i]) . "</CENTER></TD>\n");
print("</TR>\n");
print("<TR>\n");
print("<TD width=\"" . $this->configTDWidth . "\" height=\"" . $this->configTDHeight . "\" 0px solid #CCCCCC\" colspan=\"3\"><CENTER><A href=\"" . $this->picEncodeArray[$i] . "\" target=\"_blank\"><IMG SRC=\"" . $this->picEncodeArray[$i] . "\" BORDER=\"0\" width=\"" . $this->temp['Width'] . "\" height=\"" . $this->temp['Height'] . "\" ALT=\"文件 : <FONT COLOR='red'>" . $this->picFileArray[$i] . "</FONT>
尺寸 : <FONT COLOR='blue'>" . $this->picRealSizeWidth . " × " . $this->picRealSizeHeight . "</FONT> 像素
格式 : <FONT COLOR='green'>" . $this->getFileExt($this->picFileArray[$i]) . "</FONT>
大小 : <FONT COLOR='green'>" . $picFileSize . "</FONT> KB \"></A></CENTER></TD>\n");
print("<TR>\n");
print("<TD bgcolor=\"#F7F7F7\" width=30><CENTER>");
if ($session['neatpicLogined'])
print("<INPUT TYPE=\"checkbox\" NAME=\"delfile[]\" VALUE=\"" . $this->picFileArray[$i] . "\" title=\"删除图片 <FONT COLOR=blue>" . $this->picFileArray[$i] . "</FONT>\">");
print("</CENTER></TD><TD bgcolor=\"#F7F7F7\" height=\"30\"><CENTER> " . $this->picRealSizeWidth . " × " . $this->picRealSizeHeight . " </CENTER></TD><TD bgcolor=\"#F7F7F7\" height=\"20\"><CENTER>" . $picFileSize . " KB</CENTER></TD></TR></TBODY></TABLE></TD>\n");
if ($this->configEachLineMax == $I)
{
$I = 0;
print("</TR><TR>\n");
}
}
print("</TR>\n</TBODY></TABLE>\n");
print("
<A href=\"#TOP\">返回顶部</A>
\n");
print("</center>\n");
}
print("</FORM>\n");
}
/*
+----------------------------------+
| Show config state
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function showConfigState()
{
$this->configOpenGzip == true ? $openGzip = "开启" : $openGzip = "关闭";
$this->configShowPicSize == true ? $showPicSize = "开启" : $showPicSize = "关闭";
$this->configWantedPass == true ? $showWantedPass = "开启" : $showWantedPass = "关闭";
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
printf("<CENTER>当前设置: 压缩页面 : <FONT COLOR=\"red\"><B>%s</B></FONT> 显示图片大小 : <FONT COLOR=\"red\"><B>%s</B></FONT> 登录认证 : <FONT COLOR=\"red\"><B>%s</B></FONT> [ <A HREF=\"".$_SERVER['PHP_SELF']."?action=showhelp\" ><FONT COLOR=\"blue\" TITLE=\"查看NEATPIC图片程序的帮助文件\">NEATPIC 帮助</FONT></A> ]\n", $openGzip, $showPicSize, $showWantedPass);
print("</td>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">");
printf("<CENTER><A HREF=\"%s?action=login&path=%s\"><FONT COLOR=\"red\">管理登陆</FONT></A></CENTER>", $_SERVER['PHP_SELF'], rawurlencode($this->path));
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("
\n");
printf($this->decode("UG93ZXJlZCBieSA8QSBIUkVGPSJodHRwOi8vd3d3Lm5lYXRzdHVkaW8uY29tIiBUQVJHRVQ9Il9ibGFuayI%2BTkVBVFBJQyhQSFAgxL%2FCvNaxtsGw5ik8L0E%2BIFZlcnNpb24mbmJzcDs6Jm5ic3A7JXMgJm5ic3A7UHJvY2Vzc2VkIGluICVzIHNlYzxCUj4NCkNvcHlyaWdodCBOZWF0U3R1ZGlvIDIwMDItMjAwNCA8QlI%2BDQo%3D"), $this->configVer, $this->usedTime);
print("
\n");
print("</center>\n");
}
/*
+----------------------------------+
| Show login window
+----------------------------------+
| C / M : 2003-12-29 / 2004-3-26
+----------------------------------+
*/
function showLogin()
{
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER>登陆验证</CENTER>");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("
<CENTER><FORM METHOD=POST ACTION=\"".$_SERVER['PHP_SELF']."?action=loginout\">
\n
登录密码 : <INPUT TYPE=\"password\" NAME=\"password\"> <INPUT TYPE=\"submit\" VALUE=\"登录\">\n
<INPUT TYPE=\"hidden\" NAME=\"login\" VALUE=\"" . $_GET['action'] . "\">
<INPUT TYPE=\"hidden\" NAME=\"path\" VALUE=\"" . $_GET['path'] . "\">
</FORM></CENTER>\n
");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
/*
+----------------------------------+
| Show Admincp
+----------------------------------+
| C / M : 2003-12-29 / 2004-4-2
+----------------------------------+
*/
function showAdmincp()
{
$session = & $_SESSION;
if ($session['neatpicLogined'] == true)
{
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\" width=\"100\">\n");
print("<CENTER>管理选项</CENTER>");
print("</td>\n");
print("<FORM action=\"" . $_SERVER['PHP_SELF'] . "?action=upload\" method=\"POST\" enctype=\"multipart/form-data\">\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\" width=\"380\"> \n");
if (is_writeable($this->path))
print("<INPUT TYPE=hidden NAME=\"path\" VALUE=\"" . rawurlencode($this->path) . "\"><INPUT TYPE=FILE NAME=\"image\" title=\"上传文件到 <font color=blue>" . $this->nowDirName . "</font> 目录\"> <INPUT TYPE=submit VALUE=\"上传图片\"> <input type=button value=\"批量上传\" OnClick=\"self.location='" . $_SERVER['PHP_SELF'] . "?path=" . rawurlencode($this->path) . "&action=uploadmore'\" alt=\"批量上传图片\">");
else
printf("<FONT COLOR=\"red\"><B>无法上传图片 目录 <FONT COLOR=\"blue\">%s</FONT> 不可写</B></FONT>", $this->nowDirName);
print("</td>\n");
print("</FORM>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER><A HREF=\"javascript:document.dfile.submit()\"><FONT COLOR=\"blue\" title=\"删除已经选定了的图片\">删除图片</FONT></A> | <A HREF=\"".$_SERVER['PHP_SELF']."?action=cfgdirpass&path=" . rawurlencode($this->path) . "\"><FONT COLOR=\"blue\" title=\"添加/编辑 目录访问密码\">目录密码</FONT></A> | <A HREF=\"".$_SERVER['PHP_SELF']."?action=loginout&path=" . rawurlencode($this->path) . "\"><B><FONT COLOR=\"red\" title=\"退出登录\">退出相册</FONT></B></A></CENTER>");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
}
/*
+----------------------------------+
| del selected file
+----------------------------------+
| C / M : 2004-4-2 / --
+----------------------------------+
*/
function delFile()
{
if ($_GET['action'] == 'del')
{
$session = & $_SESSION;
if ($session['neatpicLogined'])
{
$path = rawurldecode($_POST['path']);
$delFile = & $_POST['delfile'];
foreach($delFile as $file)
{
unlink($path . "/" . $file);
}
header("location:" . $_SERVER['PHP_SELF'] . "?path=" . $_POST['path'] . "& . $_GET['style'] . "&page=" . $_GET['page']);
}
}
}
/*
+----------------------------------+
| show upload
+----------------------------------+
| C / M : 2004-3-26 / --
+----------------------------------+
*/
function showUpload()
{
if ($_GET['action'] == 'upload')
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->upload();
$this->usedTime();
$this->showConfigState();
exit;
}
}
/*
+----------------------------------+
| upload image
+----------------------------------+
| C / M : 2004-3-26 / --
+----------------------------------+
*/
function upload()
{
$session = & $_SESSION;
if ($session['neatpicLogined'])
{
$path = rawurldecode($_POST['path']);
$tmpPath = explode('/', $path);
$tmpPathLevel = count($tmpPath);
for ($i = 1; $i < $tmpPathLevel; $i++)
$decodePath .= rawurlencode($tmpPath[$i]) . "/";
$uploadFile = $_FILES['image']['name'];
if (file_exists($path . "/" . $uploadFile))
$uploadFile = date('is') . $_FILES['image']['name'];
$imgType = $this->getFileExt($_FILES['image']['name']);
if (!in_array($imgType, $this->configExt)) $this->error('文件类型非法!');
if (!copy($_FILES['image']['tmp_name'], $path . "/" . $uploadFile)) $this->error('文件上传发生错误!');
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"50\" 1px solid #CCCCCC\">\n");
print("<CENTER><FONT COLOR=\"red\"><B>文件上传成功</B></FONT></CENTER>");
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"#FFFFFF\" height=\"50\" 1px solid #CCCCCC\">\n");
printf("<CENTER>
<FONT COLOR=\"blue\">文件名</FONT> : <FONT COLOR=\"green\">%s</FONT> <FONT COLOR=\"blue\">文件大小</FONT> : <FONT COLOR=\"green\">%s KB</FONT> <FONT COLOR=\"blue\">文件类型</FONT> : <FONT COLOR=\"green\">%s</FONT>
<IMG SRC=\"%s%s\" border=1>
</CENTER>", $uploadFile, sprintf("%0.2f", $_FILES['image']['size'] / 1024), $imgType, $decodePath, rawurlencode($uploadFile));
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"50\" 1px solid #CCCCCC\">\n");
printf("<CENTER>[ <A HREF=\"%s%s\" target=\"_blank\">查看上传图片</A> | <A HREF=\"%s?path=%s\">返回当前目录</A> ]</CENTER>", $decodePath, rawurlencode($uploadFile), $_SERVER['PHP_SELF'], $_POST['path']);
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
}
/*
+----------------------------------+
| upload more image
+----------------------------------+
| C / M : 2004-4-5 / --
+----------------------------------+
*/
function uploadMore()
{
if ($_GET['action'] == 'uploadmore')
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->ShowJS();
if($_GET['do'] == 'yes')
{
set_time_limit(0);
$path = rawurldecode($_GET['path']);
$tmpPath = explode('/', $path);
$tmpPathLevel = count($tmpPath);
for ($i = 1; $i < $tmpPathLevel; $i++)
$decodePath .= rawurlencode($tmpPath[$i]) . "/";
$picNum = count($_FILES['images']['tmp_name']);
for($i = 0; $i < $picNum; $i++)
{
if($_FILES['images']['tmp_name'][$i])
{
$uploadFile = $_FILES['images']['name'][$i];
if (file_exists($path . "/" . $uploadFile))
$uploadFile = date('is') . $_FILES['images']['name'][$i];
 , ; $imgType = $this->getFileExt($_FILES['images']['name'][$i]);
if (!in_array($imgType, $this->configExt)) $this->error("文件类型非法! 图片编号:[" . ($i + 1) . "]");
if (!copy($_FILES['images']['tmp_name'][$i], $path . "/" . $uploadFile)) $this->error("文件上传发生错误! 图片编号:[" . ($i + 1) . "]");
$uploadFileArray[] = $uploadFile;
$imgTypeArray[] = $imgType;
$imgSizeArray[] = sprintf("%0.2f", $_FILES['images']['size'][$i] / 1024);
}
}
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"50\" 1px solid #CCCCCC\">\n");
print("<CENTER><FONT COLOR=\"red\"><B>文件批量上传成功</B></FONT></CENTER>");
print("</td>\n");
print("</tr>\n");
for($i = 0; $i < count($uploadFileArray); $i++)
{
print("<tr>\n");
print("<td bgcolor=\"#FFFFFF\" height=\"50\" 1px solid #CCCCCC\">\n");
printf("<CENTER>
<FONT COLOR=\"blue\">#" . ($i + 1) . " 文件名</FONT> : <FONT COLOR=\"green\">%s</FONT> <FONT COLOR=\"blue\">文件大小</FONT> : <FONT COLOR=\"green\">%s KB</FONT> <FONT COLOR=\"blue\">文件类型</FONT> : <FONT COLOR=\"green\">%s</FONT>
<IMG SRC=\"%s%s\" border=1>
</CENTER>", $uploadFileArray[$i], $imgSizeArray[$i], $imgTypeArray[$i], $decodePath, rawurlencode($uploadFileArray[$i]));
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"50\" 1px solid #CCCCCC\">\n");
printf("<CENTER>[ <A HREF=\"%s%s\" target=\"_blank\">查看上传图片</A> | <A HREF=\"%s?path=%s\">返回当前目录</A> ]</CENTER>", $decodePath, rawurlencode($uploadFileArray[$i]), $_SERVER['PHP_SELF'], rawurlencode($_GET['path']));
print("</td>\n");
print("</tr>\n");
}
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
else
{
($_POST['uploadnum']) ? $num = & $_POST['uploadnum'] : $num = 5;
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER><FONT COLOR=\"red\">批量上传图片</FONT></CENTER>");
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<FORM action=\"" . $_SERVER['PHP_SELF'] . "?path=" . rawurlencode($_GET['path']). "&action=uploadmore&do=yes\" METHOD=\"POST\" enctype=\"multipart/form-data\">\n");
print("<td bgcolor=\"#FFFFFF\" height=\"50\" 1px solid #CCCCCC\" align=center>
\n");
for ($i = 1; $i <= $num; $i++)
print("#" . $i . " <INPUT TYPE=\"file\" NAME=\"images[]\" SIZE=\"40\">
\n");
print("
</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER><INPUT TYPE=\"submit\" VALUE=\"上传图片\"> <INPUT TYPE=\"button\" onclick=\"javascript:history.go(-1)\" VALUE=\"返回上页\"></CENTER>");
print("</td>\n");
print("</FORM>\n");
print("</tr>\n");
print("<tr>\n");
print("<FORM action=\"" . $_SERVER['PHP_SELF'] . "?path=" . rawurlencode($_GET['path']). "&action=uploadmore\" METHOD=\"POST\">\n");
print("<td bgcolor=\"#FFFFFF\" height=\"50\" 1px solid #CCCCCC\" align=center>\n");
print("重新设定要批量上传的图片数量: 我要一次性上传 <INPUT TYPE=\"text\" NAME=\"uploadnum\" size=\"3\"> 张图片 <INPUT TYPE=\"submit\" VALUE=\" 设置 \">\n");
print("</td>\n");
print("</FORM>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
}
$this->usedTime();
$this->showConfigState();
exit;
}
}
/*
+----------------------------------+
| Decode
+----------------------------------+
| C / M : 2003-12-30 / --
+----------------------------------+
*/
function decode($str)
{
$str = rawurldecode($str);
$str = base64_decode($str);
$this->c = true;
return $str;
}
function c()
{
if(!$this->c)
header($this->decode("bG9jYXRpb246aHR0cDovL3d3dy5uZWF0c3R1ZGlvLmNvbQ%3D%3D"));
}
/*
+----------------------------------+
| Show if config wanted password
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
function showWantPass()
{
if ($this->configWantedPass == true OR $_GET['action'] == 'login' OR $_GET['action'] == 'loginout' OR $_POST['login'] == 'login')
{
$session = & $_SESSION;
if ($_GET['action'] == 'loginout')
{
if (!$session['neatpicLogined'])
{
if ($_POST['password'] == $this->configAdminPass AND $this->configAdminPass != "neatpic") $session['neatpicLogined'] = true;
}
else
{
$session['neatpicLogined'] = "";
}
($_POST['path']) ? $path = $_POST['path'] : $path = $_GET['path'];
header("location:".$_SERVER['PHP_SELF']."?path=" . rawurlencode($path));
exit;
}
if (!$session['neatpicLogined'])
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->showLogin();
$this->usedTime();
$this->showConfigState();
exit;
}
}
}
/*
+----------------------------------+
| config dir password
+----------------------------------+
| C / M : 2004-3-27 / -- --
+----------------------------------+
*/
function configDirPass()
{
if ($_GET['action'] == 'cfgdirpass')
{
$session = & $_SESSION;
if ($_GET['do'] AND $session['neatpicLogined'])
{
if (file_exists(rawurldecode($_POST['path']) . "/" . $this->configDirPasswordFile))
{
$password = file(rawurldecode($_POST['path']) . "/" . $this->configDirPasswordFile);
list(, $password) = explode('|', chop($password[0]));
if (md5($_POST['oldpassword']) != $password)
$this->error("旧密码不匹配");
}
if ($_POST['newpassword'] != $_POST['checkpassword'])
$this->error("两次密码输入不匹配");
if (!$_POST['newpassword'])
unlink(rawurldecode($_POST['path']) . "/" . $this->configDirPasswordFile);
else
{
if (!is_writeable(rawurldecode($_POST['path']) . "/"))
$this->error("要设置访问的目录不可写!请先设置其属性为777.");
$fp = fopen(rawurldecode($_POST['path']) . "/" . $this->configDirPasswordFile, "w+");
fwrite($fp, "<?php die()?>|" . md5($_POST['newpassword']));
fclose($fp);
}
header("location:".$_SERVER['PHP_SELF']."?path=" . $_POST['path']);
}
else
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->ShowJS();
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("<CENTER>目录访问密码设置</CENTER>");
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("
<CENTER><FORM METHOD=POST ACTION=\"".$_SERVER['PHP_SELF']."?action=cfgdirpass&do=yes\">
\n
旧的密码 : <INPUT TYPE=\"password\" NAME=\"oldpassword\" title=\" 如果目录原来有密码,请输入旧的密码 \">
新的密码 : <INPUT TYPE=\"password\" NAME=\"newpassword\" title=\" 输入新的目录密码 \">
确认密码 : <INPUT TYPE=\"password\" NAME=\"checkpassword\" title=\" 确认新的目录密码 \">
<INPUT TYPE=\"submit\" VALUE=\" 添加/更新 密码 \">\n
<INPUT TYPE=\"hidden\" NAME=\"path\" VALUE=\"" . $_GET['path'] . "\">
</FORM></CENTER>\n
");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
$this->usedTime();
$this->showConfigState();
exit;
}
}
}
/*
+----------------------------------+
| Dir password checking
+----------------------------------+
| C / M : 2004-3-27 / -- --
+----------------------------------+
*/
function checkingDirPass()
{
if ($_GET['action'] == 'checkdirpass')
{
$session = & $_SESSION;
$password = file(rawurldecode($_POST['path']) . "/" . $this->configDirPasswordFile);
list(, $password) = explode('|', chop($password[0]));
if ($password == md5($_POST['password']))
$session[$_POST['path']] = md5($password);
header("location:".$_SERVER['PHP_SELF']."?path=" . $_POST['path']);
}
}
/*
+----------------------------------+
| Check dir password
+----------------------------------+
| C / M : 2004-3-27 / -- --
+----------------------------------+
*/
function checkDirPass()
{
$this->checkingDirPass();
$session = & $_SESSION;
if (file_exists($this->path . "/" . $this->configDirPasswordFile))
{
if (!$session[rawurlencode($this->path)] AND !$session['neatpicLogined'])
$this->showDirPassLogin();
}
}
/*
+----------------------------------+
| Show dir Pass login window
+----------------------------------+
| C / M : 2004-3-27 / -- --
+----------------------------------+
*/
function showDirPassLogin()
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->ShowJS();
print("<center>\n");
print("<table width=\"80%\">\n");
print("<tbody>\n");
print("<tr>\n");
print("<td bgcolor=\"#F7F7F7\" height=\"50\" 1px solid #CCCCCC\">\n");
print("<CENTER>该目录设置了密码,请输入相应的访问密码</CENTER>");
print("</td>\n");
print("</tr>\n");
print("<tr>\n");
print("<td bgcolor=\"F7F7F7\" height=\"30\" 1px solid #CCCCCC\">\n");
print("
<CENTER><FORM METHOD=POST ACTION=\"".$_SERVER['PHP_SELF']."?action=checkdirpass\">
\n
访问密码 : <INPUT TYPE=\"password\" NAME=\"password\"> <INPUT TYPE=\"submit\" VALUE=\"提交\">\n
<INPUT TYPE=\"hidden\" NAME=\"path\" VALUE=\"" . rawurlencode($this->path) . "\">
</FORM></CENTER>\n
");
print("</td>\n");
print("</tr>\n");
print("</tbody>\n");
print("</table>\n");
print("</center>\n");
$this->usedTime();
$this->showConfigState();
exit;
}
/*
+----------------------------------+
| Show error
+----------------------------------+
| C / M : 2004-3-27 / -- --
+----------------------------------+
*/
function error($msg)
{
echo "<script language=javascript>";
echo "window.alert('$msg');";
echo "history.go(-1);";
echo "</script>";
exit;
}
/*
+----------------------------------+
| Show Help file
+----------------------------------+
| C / M : 2004-4-9 / 2004-4-12
+----------------------------------+
*/
function showHelp()
{
if ($_GET['action'] == 'showhelp')
{
$this->timer();
$this->showCSS();
$this->showTitle();
$this->ShowJS();
//这里的内容是一个数组,从1开始...为的是方便表格里的序号按顺序排下去
//之所以采用数据,是为了方便添加其它帮助,这样的话,更方便以后添加
//想法,对帮助的$helpContent[2][3]内容进行MD5加密,然后再程序里验证一下就行了,
//如果有问题则显示错误或其它方式如你的那段DECODE到你的网页的代码,
//但是我个人不主张,不过为了防止别人更改我们的感谢名单,可以考虑试一下下的~
$helpContent[1][0] = "NEATPIC (目录直读版) 程序究竟是什么?"; //Link content
$helpContent[1][1] = "点击查看什么是 NEATPIC (目录直读版) 程序"; //Link title
$helpContent[1][2] = "whats the neatpic"; //Link's name <a name=''></a>
$helpContent[1][3] = "TkVBVFBJQyjEv8K81rG2wbDmKcrHIE5FQVQgU1RVRElPILzMIE5FQVRQSUMguvPNxrP2tcTEv8K81rG2wbDmsb6jrLG%2B18W88r3g1sHJz7XE1K3U8qOssb6zzNDy1rvT0NK7uPbOxLz%2Bo6y%2FycrHyLTKtc%2FWwcu087bgyv3NvMasudzA7bPM0PLTtdPQtcS5psTco6zI587EvP7Jz7Sro6zX08S%2FwrzP1Mq%2Bo6zL9cLUzby1yLXIuabE3KGj"; //help content
$helpContent[2][0] = "NEATPIC (目录直读版) 感谢名单。"; //Link content
$helpContent[2][1] = "点击查看帮助过 NEATPIC (目录直读版) 朋友和用户"; //Link title
$helpContent[2][2] = "thanks"; //Link's name <a name=''></a>
$helpContent[2][3] = "CQkJs8zQ8s%2Frt6ggOiA8Zm9udCBjb2xvcj1yZWQ%2Bb2xkd29sZjwvZm9udD48YnI%2BDQoJCQm5psTcvajS6SA6IG9sZHdvbGYsIEt2b3JhbiwgV2luZG5ldHMsIEVhc3ksIExhbmQsIMDPsfi%2BxrDJLCDAz87a0bssIMDPue0sIM3BsqbK8ywgZ291a2ksIHjS%2Fmuh73o8YnI%2BDQoJCQmzzNDysuLK1CA6IHjS%2Fmuh73osIG9sZHdvbGYsIHN0YXJkdXN0LCDAz87a0bssIExhbmQsIEt2b3JhbiwgZ291a2kgtci1yLrctuC1xMXz09EuLi4gLi4uPGJyPg0KCQkJ1sbX97PJ1LEgOiB3YWxrZXIsIGdvdWtp"; //help content
$helpContent[3][0] = "我需要使用NEATPIC (目录直读版) 吗?"; //Link content
$helpContent[3][1] = "点击查看究竟哪些用户需要使用 NEATPIC (目录直读版) "; //Link title
$helpContent[3][2] = "doit"; //Link's name <a name=''></a>
$helpContent[3][3] = "yOe5%2B8Tj09DSu7TzttG1xM28xqzQ6NKqus3F89PRw8fSu8bwt9bP7aOstvi21NfUvLrX9s340rO1xMuuxr3T1rK7yse63NPQ0MXQxKO7yOe5%2B7K7z7C538q508NBQ0RTRUXV4sDgv7TNvMjtvP7X1LavyfqzybXEV0VC0rPD5qOsxMfDtMTjvs2%2FydLUyrnTw87Sw8fV4rj2s8zQ8qOsy%2Fy9q7e9sePE472rzbzGrNW5yr64%2BMTjtcTF89PRw8ejrLb4x9K7ub%2FJ0tTJ6Laot8POysPcwuvS1LfA1rnE47XE0rvQqdL%2By73NvMassbvG5Mv708O7p7%2B0tb2how%3D%3D"; //help content
$helpContent[4][0] = "NEATPIC (目录直读版)所需要的系统基本配置"; //Link content
$helpContent[4][1] = "点击查看 NEATPIC (目录直读版) 所需的最低基本配置"; //Link title
$helpContent[4][2] = "neatconfig"; //Link's name <a name=''></a>
$helpContent[4][3] = "CQkJMS63%2Fs7xxvfWp7PWUEhQILDmsb4gNC4wLjYg0tTJzyAozt7Q6Mr9vt2%2F4tans9YpPGJyPg0KCQkJMi6wssirxKPKvbnYsdU8YnI%2BDQoJCQkzLsjnufvU2mFwYWNoZSAyLlguWM%2FCyrnTwyzW0M7ExL%2FCvCzOxLz%2Bvauyu8Tc1f2zo8%2FUyr6how%3D%3D"; //help content
$helpContent[5][0] = "NEATPIC (目录直读版) 有哪些功能?"; //Link content
$helpContent[5][1] = "点击查看 NEATPIC (目录直读版) 所拥有的功能"; //Link title
$helpContent[5][2] = "how i can"; //Link's name <a name=''></a>
$helpContent[5][3] = "CQkJCQkxLtfUtq%2FS1Mv1wtTNvLXEt73Kvc%2FUyr7L%2BdPQzbzGrKOosrvQ6NKqR0S%2F4rXE1qez1qOpOzxCUj4NCgkJCQkJMi6%2FydLUuPm%2B3dDo0qrJ6LaoxL%2FCvLfDzsrD3MLrOzxCUj4NCgkJCQkJMy7Wp7PW1tDOxNfTxL%2FCvMP7OzxCUj4NCgkJCQkJNC7OxLz%2Byc%2B0q6Oo0tHWp7PWtuDOxLz%2Byc%2B0q7mmxNyjqTs8QlI%2BDQoJCQkJCTUuxfrBv8m%2Bs%2F3NvMasOzxCUj4NCgkJCQkJNi7Ev8K8wdCx7c%2FUyr6jrNans9bO3s%2Fe19PEv8K8OzxCUj4NCgkJCQkJNy7Lq8Sjyr2y6b%2B0zbzGrKO61ebKtbe9yr2y6b%2B0us3L9cLUt73KvbLpv7Q7PEJSPg0KCQkJCQk4LsrzserSxravtb3NvMasyc%2B%2FydLUzerV%2B8%2FUyr7NvMasw%2FuzxqOstPPQoaOsuPHKvdLUvLCz37TnoaM8QlI%2BDQoJCQkJCTkuxuTL%2FLv5sb65psTcsrvSu9K7venJ3KOsyOfSs8Pm0bnL9aOst9bSs8%2FUyr6jrMe%2F1sa1x8K8yM%2FWpA%3D%3D"; //help content
$helpContent[6][0] = "NEATPIC (目录直读版) 申明"; //Link content
$helpContent[6][1] = "点击查看 NEATPIC (目录直读版) 的申明"; //Link title
$helpContent[6][2] = "copyright"; //Link's name <a name=''></a>
$helpContent[6][3] = "TkVBVFBJQyDKx9PJIE5FQVQgU1RVRElPILbAwaK%2Fqreio6zTtdPQuMOzzNDyy%2FnT0LXEsObIqKOsx%2BvKudPD1d%2FX8NbYztLDx7XEsObIqKOs1NrKudPDyrGxo8H0ztLDx7XEsObIqKGj"; //help content
print ("
<center>
<table width=80%><tbody>
<tr><td bgcolor='#F7F7F7' height='30' 1px solid #CCCCCC' align='center'>
<font color=red>NEATPIC (目录直读版) 帮助文件</font>
</td></tr>
</tbody></table>
<table width=80%><tbody>
<tr><td bgcolor='#FFFFFF' 1px solid #CCCCCC' align='Left'>
");
for($i = 1 ; $i <= count($helpContent); $i++)
{
print " ".$i."."." <a href=\"#".$helpContent[$i][2]." \"><font title=\" ".$helpContent[$i][1]." \"> ".$helpContent[$i][0]."</font></a>";
print "
";
}
print ("
</td></tr>
");
for($i = 1 ; $i <= count($helpContent); $i++)
{
print " <tr><td bgcolor='#F7F7F7' height='25' 1px solid #CCCCCC' >";
print " " . $i . ".<font color='blue'>".$helpContent[$i][0]."</font><a name=".$helpContent[$i][2]."></a>";
print "</td></tr><tr><td bgcolor='#FFFFFF' height='25' 1px solid #CCCCCC' > ";
print "<center><table border=0 width=95%><tr><td>";
print "
" . $this->decode($helpContent[$i][3]) . "
";
print "</td></tr></table></center>";
print "</td></tr>";
}
print ("
<tr><td bgcolor='#F7F7F7' height='50' 1px solid #CCCCCC' align='center'>
<INPUT TYPE='button' value='返回上页' >
</td></tr>
</tbody></table>
</center>
");
$this->usedTime();
$this->showConfigState();
exit;
}
}
/*
+----------------------------------+
| Execute Class
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
function execute()
{
$this->showWantPass();
$this->configDirPass();
$this->showHelp();
$this->uploadMore();
$this->delFile();
$this->showUpload();
$this->gzip();
$this->timer();
$this->getVars();
$this->checkError();
$this->checkDirPass();
$this->showCSS();
$this->showTitle();
$this->ShowJS();
$this->pathArrayInitialize();
$this->makeOverdirect();
$this->makeDirList();
$this->getEachArrayNum();
$this->makeOptionList();
$this->makePageBar();
$this->showState();
$this->showDirList();
$this->showAdmincp();
$this->showPageBar();
$this->showPicList();
$this->showPageBar();
$this->showDirList();
$this->usedTime();
$this->showConfigState();
$this->c();
}
}
/*
+----------------------------------+
| Main
+----------------------------------+
| C / M : 2003-12-28 / 2003-12-29
+----------------------------------+
*/
error_reporting(0);
session_start();
header("content-Type: text/html; charset=GB2312");
/*
+----------------------------------+
| Create object
+----------------------------------+
| C / M : 2003-12-29 / --
+----------------------------------+
*/
$neatpic = new neatpic($configWantedPass, $configAdminPass, $configDirPasswordFile, $configOpenGzip, $configShowPicSize, $configExt, $strLenMax, $configEachPageMax, $configEachLineMax, $configTDHeight, $configTDWidth, $configPageMax, $configTilte, $configVer);
/*
+----------------------------------+
| Execute class
+----------------------------------+
| C / M : 2003-12-30 / --
+----------------------------------+
*/
$neatpic->execute();
?>