JSP单页面网站文件管理器

80酷酷网    80kuku.com

  js|页面

这个文件的开发的设计思想是这样的。有的web 网站,或者B/S 软件的客户,在软件的安装调试阶段,往往对某些细节有特殊要求,也许,是字体的调整,也许是界面方面的小改动意见。面对这样的情况,如果用户没有开放FTP 功能,则开发和维护人员往往就必须亲临现场做一些很小的调试工作。

即浪费了时间,也浪费了人力物力。

在这样的情况下,我开发了这个具有文件管理功能的 JSP 单页面文件。它提供了文件夹的新增,更名,删除;文件的修改,更名,删除和上传的功能。基本能满足在软件的安装调试阶段,小的修改工作。

为了安全原因,该JSP 页面提供了简单的用户登陆功能。

使用前,把该文件置于网站文件,或者B/S 产品的任意目录下。开放文件安装目录的 读写 操作权限。用户远程登陆该JSP 页面,就可以行使管理功能。当安装维护阶段结束以后,请修改文件安装目录的 读写 权限,并删除该文件,以免留下安全隐患。

缺省,登陆用户名为:admin 密码为:oddworld

开发环境 jakarta-tomcat-4.0.3.exe

注意:因为本软件的上传文件功能必须有 smartupload 组件支持。请把smartupload 置于tomcat 对应文件夹web-inf 下。如果你支持上传的组件有所不同,请自行调整。

简要开发说明:因为本文件并不复杂,加上本人自我感觉,文档说明虽然不规范,却也详细,所以只打算简要的关于一些小细节上做说明。

1. 本文件进行文件目录操作的时候,直接把目录当参数来传递,没有进行相应的转换。这是因为在 java 中, “\英文字符”有可能会被认为是转意字符,而引起在字符处理过程中出现无法预期的问题,所以我认为直接把目录来作为参数,在操作上比较合理。

2. 本文件在一些表单的提交方面,使用连接,而不是按钮,是因为 javascript 处理带 “\”的字符串时,也会有处理转意字符的可能,所以,为了防止这样的情况,所以传递目录参数的提交,都使用连接形式。

3. strStat,strErr 两个字符串,贯穿文件始终,前者为页面进行何种操作的判断命令,后者为在所有操作中出错的信息提示。

4. 本文件有可能引起的安全或者其它方面的纠纷,本人不做任何解释。我只是把该文件作为一个免费的工具提供给大家参考,使用。

----------------------------------------------------------------

文件内容 admin.jsp

<%--  oddWorld 网站文件管理系统(简体中文版) 2003年10月10日
 copy right by joard Ast 
 
 admin.jsp 功能:网站文件后台管理页面。
 --%>
 <% page contentType="text/html;charset=gb2312" %>
 <% page import="java.io.*" %>
 <% page import="java.util.Date" %>
 <% page import="com.jspsmart.upload.SmartUpload" %>
 <% page import="javax.servlet.http.HttpSession" %>
 <% page import="javax.servlet.http.HttpServletRequest" %>
 <% page import="java.lang.reflect.*" %>
 
<% //中文字符转换%>
<%!

public static String UnicodeToChinese(String s){
   try{
       if(s==null||s.equals("")) return "";
       String newstring=null;
       newstring=new String(s.getBytes("ISO8859_1"),"gb2312");
       return newstring;
     }
   catch(UnsupportedEncodingException e)
   {
    return s;
   }
  }

public static String ChineseToUnicode(String s){
   try{
    if(s==null||s.equals("")) return "";
     String newstring=null;
     newstring=new String(s.getBytes("gb2312"),"ISO8859_1");
       return newstring;
   }
   catch(UnsupportedEncodingException e)
   {
    return s;
  }
}
%>
 
 <%
 //刷新问题
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);

//自定义登陆用密码和用户名
//正确的用户名
String username="admin" 
//正确的密码
String userpass="oddworld";

//得到系统路径
ServletContext app=(ServletContext)pageContext.getServletContext();
String strSysPath = app.getRealPath("/");

//处理对象物理路径
String strDealPath="";

//显示错误信息
String strErr="";
//代表页面的显示状态,login 是显示登陆页面;show 是正常的显示文件信息;edit 是显示编辑文件的页面;editDo 是编辑文件的写入操作

;createF 是显示创建文件夹的页面;createFDo 是创建文件夹的操作;renameFold 是显示更改文件夹名称的页面;renameFoldDo 是更改文

件夹名称的操作;delFoldDo 是删除文件夹的操作;renameFile 是显示更改文件名称的页面;renameFileDo 是更改文件名称的操作;

delFileDo 是删除文件的操作;uploadFile 是显示上传文件的页面;uploadFileDo 是上传文件的操作;
String strStat="login";

//用于show 状态下显示文件的数组
File[] fileArr=null;

//根据传递的路径参数得到要处理对象的物理路径
if (request.getParameter("path")==null || request.getParameter("path").equals("")){
 strDealPath=strSysPath;
}else{
 //得到路径参数
 strDealPath=UnicodeToChinese(request.getParameter("path"));
}

//检查session 的值是否存在,如果不存在着显示错误信息
//HttpSession session = request.getSession(false);
if (session.getValue("loginIn")==null || !session.getValue("loginIn").equals("pass"))
{
 strStat="login";
 strErr="你还没有登陆或者登陆超时,请重新登陆!";
}

//创建file 对象,检查目录是否存在
File myFile=new File(strDealPath);

//检验文件夹是否存在
if(!myFile.exists()){
 strErr="你选择的文件夹不存在,请重新选择!";
}

//根据参数的不同,进行对应的操作
if(request.getParameter("act")==null || request.getParameter("act").equals("") ||

request.getParameter("act").equals("login"))
{
 if(request.getParameter("username")!=null && request.getParameter("userpass")!=null)
 {
 
  //正确的经过MD5 加密的密码
  //String userpass="OEEO99107DC8C1EE2E06666B965601EF";
 
  if(request.getParameter("username").equals(username) && (request.getParameter("userpass")).equals(userpass))
  {
   session.putValue("loginIn","pass");
   response.sendRedirect(request.getRequestURI()+"?act=show");
  }
 }
 else {
  strStat="login";
  strErr="你还没有登陆或者登陆超时,请重新登陆!";
 }
}else if(request.getParameter("act").equals("show")){
 //缺省,页面正常显示文件的信息 statStat="show"
 strStat="show";
 
 //创建文件列表数组
 fileArr=myFile.listFiles();
 
}else if(request.getParameter("act").equals("edit"))
{
 //编辑文件内容的页面
 //根据是否有request.getParameter("file"),以及相应文件是否存在,如果有,则进行编辑操作,如果没有,则显示错误提示信息
 if (!(request.getParameter("file")==null || request.getParameter("file").equals(""))){
 
  File fileEdit=new

File(UnicodeToChinese(request.getParameter("path"))+UnicodeToChinese(request.getParameter("file")));
   
  if(fileEdit.exists())
   //文件编辑操作,实际就是更改页面的显示,用一个textarea 显示文件的信息,来做编辑
   strStat="edit";
  else
   //显示错误信息
   strErr="你选择的文件不存在,请重新选择!";
  
 }else{
  strErr="你没有选择要编辑的文件,请重新选择!";
 }
}else if(request.getParameter("act").equals("editDo"))
{
 //把修改的内容写入文件,并且返回修改页面
 if (!(request.getParameter("file")==null || request.getParameter("file").equals("")))
 { 
  File fileEdit=new

File(UnicodeToChinese(request.getParameter("path"))+UnicodeToChinese(request.getParameter("file")));
 
  if(fileEdit.exists())
  { 
   //文件编辑操作,实际就是在修改文件内容以后,再于页面上用一个textarea 显示文件的内容,继续来做编辑或者

查看修改的效果
   if(!(request.getParameter("fileData")==null))
   {
  
    try{
     PrintWriter pwEdit =null;
     pwEdit=new PrintWriter(new

FileOutputStream(UnicodeToChinese(request.getParameter("path"))+UnicodeToChinese(request.getParameter("file"))));
     pwEdit.println(UnicodeToChinese(request.getParameter("fileData")));
     pwEdit.close();
   
     response.sendRedirect(request.getRequestURI()+"?path="+

UnicodeToChinese(request.getParameter("path")) +"&file="+ UnicodeToChinese(request.getParameter("file")) +"&act=edit"); 
     return;
    }catch(Exception e){
     strErr="文件写入错误,请重新选择!";
    }
   }else{
    strErr="缺少修改文件内容的参数,请重新选择!";
   }
  }else
   //显示错误信息
   strErr="你选择的文件不存在,请重新选择!";
 }else{
  strErr="你没有选择要编辑的文件,请重新选择!";
 }
}else if(request.getParameter("act").equals("createF"))
{
 //创建新的文件夹的页面显示
 strStat="createF";
}else if(request.getParameter("act").equals("createFDo"))
{
 //创建新的文件夹
 String strFoldName=strDealPath+UnicodeToChinese(request.getParameter("foldName")).trim()+"\\";

 //out.println(strFoldName);
 //out.close();

 File fileCreateF=new File(strFoldName);
 
 if(!fileCreateF.exists())
 {
  try{
   fileCreateF.mkdir();
   response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
   return;
  }catch(Exception e){
   strErr="创建新文件夹失败!";
  }
 }
 else
 
 {
  strErr="指定的文件夹名称和现有的文件夹名称重复,请重新指定一个新的文件夹名称!";
 }
}else if(request.getParameter("act").equals("delFoldDo"))
{
 //删除操作
 try{
  String strFileDelF=strDealPath+UnicodeToChinese(request.getParameter("fold"))+"\\";
  File fileDelF=new File(strFileDelF);
 
  if(fileDelF.exists()){
   File[] fileArrCheck=fileDelF.listFiles();
   if(!(fileArrCheck.length>0))
   {
    fileDelF.delete();
    response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
    return;
   }else
   {
    strErr="文件夹下面还包含着文件,请把文件都删除,再删除文件夹";
   }
  }else{
   strErr="要删除的文件夹不存在,请重新选择";
  }
 
 }catch(Exception e)
 {
  strErr="文件夹删除操作错误!";
 }
}else if(request.getParameter("act").equals("renameFold"))
{
 strStat="renameFold";
}else if(request.getParameter("act").equals("renameFoldDo"))
{
 //文件夹更名操作
 //根据参数判断是否对于文件夹名称有更改动作发生
 if(request.getParameter("changeDo").equals("true"))
 {
  //有文件名,更名发生
  try{
   String strFileRenameF=strDealPath+UnicodeToChinese(request.getParameter("fold"))+"\\";
   File fileRenameF=new File(strFileRenameF);
  
   String strFileRenameToF=strDealPath+UnicodeToChinese(request.getParameter("newFoldName"))+"\\";
   File fileRenameToF=new File(strFileRenameToF);
 
   //判断更名的文件夹是否存在
   if(fileRenameF.exists()){
    //判断新的文件夹名称是否与现存的文件夹重名
    if(!fileRenameToF.exists())
    {
     fileRenameF.renameTo(fileRenameToF);
     response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
     return;
    }else
    {
     strErr="指定的文件夹名称和现有的文件夹名称重复,请重新指定一个文件夹名称!";
    }
   }else{
    strErr="要更名的文件夹不存在,请重新选择";
   }
 
  }catch(Exception e)
  {
   strErr="文件夹更名操作错误!";
  }
 }
}else if(request.getParameter("act").equals("renameFile"))
{
 strStat="renameFile";
}else if(request.getParameter("act").equals("renameFileDo"))
{
 //文件更名操作
 //根据参数判断是否对于文件名称有更改动作发生
 if(request.getParameter("changeDo").equals("true"))
 {
  //有文件名,更名发生
  try{
   String strFileRenameFi=strDealPath+UnicodeToChinese(request.getParameter("file"));
   File fileRenameFi=new File(strFileRenameFi);
  
   String strFileRenameToFi=strDealPath+UnicodeToChinese(request.getParameter("newFileName"));
   File fileRenameToFi=new File(strFileRenameToFi);
  
   //判断更名的文件是否存在
   if(fileRenameFi.exists()){
    //判断新的文件名称是否与现存的文件重名
    if(!fileRenameToFi.exists())
    {
     fileRenameFi.renameTo(fileRenameToFi);
     response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
     return;
    }else
    {
     strErr="指定的文件名称和现有的文件名称重复,请重新指定一个文件名称!";
    }
   }else{
    strErr="要更名的文件不存在,请重新选择";
   }
 
  }catch(Exception e)
  {
   strErr="文件更名操作错误!";
  }
 }
}else if(request.getParameter("act").equals("delFileDo"))
{
 //删除操作
 try{
  String strFileDelFi=strDealPath+UnicodeToChinese(request.getParameter("file"));
  File fileDelFi=new File(strFileDelFi);
 
  if(fileDelFi.exists())
  {
   fileDelFi.delete();
   response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
   return;
  }else{
   strErr="要删除的文件不存在,请重新选择";
  }
 
 }catch(Exception e)
 {
  strErr="文件删除操作错误!";
 }
}else if(request.getParameter("act").equals("uploadFile"))
{
 strStat="uploadFile";
}else if(request.getParameter("act").equals("uploadFileDo"))
{
%>
 <jsp:useBean id="mySmartUpload" scope="page" class="com.jspsmart.upload.SmartUpload" />
<%
 //上传文件操作
 mySmartUpload.initialize(pageContext);
 mySmartUpload.setTotalMaxFileSize(1000000);

 try {
  mySmartUpload.upload();
  mySmartUpload.save(strDealPath);
 
  response.sendRedirect(request.getRequestURI()+"?path="+strDealPath+"&act=show"); 
  return; 
 } catch (Exception e) {
  strErr="文件上传出错,请检查是否超过1M 的文件大小限制!";
 }

}

%>
<%
out.println(strStat);
%>

<HTML><HEAD><TITLE>Directory Listing For /</TITLE>
<META content="text/html; charset=utf-8" http-equiv=Content-Type>
<META content="MSHTML 5.00.2920.0" name=GENERATOR></HEAD>
<BODY bgColor=white>
<div align="center">
  <table border=0 cellpadding=5 cellspacing=0 width="90%">
    <tbody>
    <tr>
      <td align=left bgcolor=#000066 valign=bottom><font color=#ffffff face=宋体
      size=4 Roman? New ,?times><b> 网站文件管理器</b></font></td>
      <td align=right bgcolor=#000066 valign=bottom><font color=#ffffff face=宋体
      size=4 Roman? New ,?times><b> <strong><%=request.getContextPath()%></strong></b></font></td>
    </tr>
    </tbody>
  </table>
  <table width="90%" border="0" cellspacing="0" cellpadding="5">
    <tr>
      <td><font size="2"><b>物理路径:</b><%=strDealPath%></font></td>
    </tr>
 </table>
 

  <% if (strStat.equals("login")){%>
  <table width="300" border="0" cellspacing="1" cellpadding="0" >
    <tr>
    <td height="200" valign="top" align="center">
      <p align="center">
        <table width="100%" border="0" cellspacing="1" cellpadding="5" bgcolor=#999999 class=a9px>
          <tr>
            <td bgcolor="#cccccc"><font size=+2>登录</font></td>
        </tr>
        <tr>
            <td bgcolor="#FFFFFF" valign="top" align="center">
              <table width="100%" border="0" cellspacing="0" cellpadding="0">
                <form name=dataform method=post action='<%=request.getRequestURI()%>?act=login'>
                  <tr>
                    <td width="100"><b><font size="-1">登录名:</font></b></td>
                    <td>
                      <input maxlength=16
              name="username" value="">
                    </td>
                  </tr>
                  <tr>
                    <td width="100"><b><font size="-1">密码:</font></b></td>
                    <td>
                      <input  class=stedit  maxlength=16
                  name="userpass" value="">
                    </td>
                  </tr>
                </form>
              </table>
           

              <table border=0 cellpadding=0 cellspacing=0>
                <tbody>
                <tr>
                  <td>
                    <input  name=update type=button value="登    录">
                  </td>
                  <td> </td>
                  <td> </td>
                </tr>
                </tbody>
              </table>
             

            </td>
        </tr>
      </table>
    </td>
  </tr>
</table>
  <%  //错误信息显示
}else if(strErr!=""){
 %>
  <table width="90%" border="0" cellspacing="0" cellpadding="5">
    <tr>
      <td><font size=+2><strong>操作错误</strong></font></td>
    </tr>
  </table>
  <table align=center cellpadding=5 cellspacing=0 width="90%">
    <form name=dataForm2

action="<%=request.getRequestURI()%>?path=<%=UnicodeToChinese(request.getParameter("path"))%>&fold=<%=UnicodeToChinese(reques

t.getParameter("fold"))%>&act=renameFoldDo" method="post">
      <tbody>
      <tr bgcolor=#cccccc>
        <td align=left bgcolor="#cccccc"><strong><font size="-1">错误原因:</font></strong></td>
      </tr>
      <tr>
        <td align=left><TT><font color="red"><%=strErr%></font></TT>
        </td>
      </tr>
      <tr>
        <td bgcolor=#cccccc align="center"><TT>[ <a ]</TT>  <tt>[ <a

</tr>
    <% }
  } %>
    <tr align="center">
      <td bgcolor=#cccccc colspan=4><TT>[ <a </TR>
    <%  }
   }
}else {%>
    <TR>
      <TD align=left >   <TT>没有文件</TT></TD>
      <TD align=right> </TD>
      <TD align=right> </TD>
      <TD align=center> </TD>
      <TD align=center> </TD>
    </TR>
    <%}%>
    <TR align="center">
      <TD bgColor=#cccccc colSpan=5><TT>[ <a ]</TT>  <TT>[ <a

(checkForm()==false);">提交内容</a>
          ]</tt>  <tt>[ <a

(checkForm2()==false);">提交内容</a>
          ]</tt>  <tt>[ <a

(checkForm3()==false);">提交内容</a>
          ]</tt>  <tt>[ <a

(checkForm4()==false);">提交内容</a>
          ]</tt>  <tt>[ <a

LANGUAGE=javascript>
<!--

<%
//根据参数不同,显示不同的检测参数的函数
if(strStat.equals("login")) {%>
function checkform()
{
 var Checkblank = /^(\s*|(\ )|(\.))*$/;

 if (Checkblank.test(dataform.username.value))   
{
          alert("登录名不能为空!");
   return false;
         }
        
         if (Checkblank.test(dataform.userpass.value))   
{
          alert("密码不能为空!");
   return false;
         }

      window.dataform.submit();

   }
<%}else if(strStat.equals("createFold")) {%>
  function checkForm()

 var Checkblank = /^(\s*|(\ )|(\.))*$/;
 if (Checkblank.test(dataForm.foldName.value))
 {
          alert("新建文件夹名称不能为空!");
          dataForm.foldName.focus();
   return false;
         }
        
 var SPECIAL_STR = "\\/:*?\"><|";
 for(i=0;i<(dataForm.foldName.value).length;i++)
 {
  if (SPECIAL_STR.indexOf((dataForm.foldName.value).charAt(i)) !=-1)
  {
   alert("文件夹名称不能含有如下字符\\/:*?\"><|");
   dataForm.foldName.focus();
   return false;
  }
 }
        
        window.dataForm.submit();
  }
 
  <%}else if(strStat.equals("renameFold")) {%>
    function checkForm2()

 var Checkblank = /^(\s*|(\ )|(\.))*$/;
 if (Checkblank.test(dataForm2.newFoldName.value))
 {
          alert("重命名的文件夹名称不能为空!");
          dataForm2.newFoldName.focus();
   return false;
         }
        
 var SPECIAL_STR = "\\/:*?\"><|";
 for(i=0;i<(dataForm2.newFoldName.value).length;i++)
 {
  if (SPECIAL_STR.indexOf((dataForm2.newFoldName.value).charAt(i)) !=-1)
  {
   alert("文件夹名称不能含有如下字符\\/:*?\"><|");
   dataForm2.newFoldName.focus();
   return false;
  }
 }
 //如果文件更名后和原文件名不同,则标示一个参数,表明确实有更名动作发生
 if(dataForm2.newFoldName.value!="<%=UnicodeToChinese(request.getParameter("fold"))%>")
 {
  window.dataForm2.changeDo.value="true";
 }
 else
 {
  alert("请输入一个新的文件夹名称!");
  dataForm2.newFoldName.focus();
  return false;
 }
 
        window.dataForm2.submit();

}
<%}else if(strStat.equals("renameFile"))
{%>
    function checkForm3()

 var Checkblank = /^(\s*|(\ )|(\.))*$/;
 if (Checkblank.test(dataForm3.newFileName.value))
 {
          alert("重命名的文件夹名称不能为空!");
          dataForm3.newFileName.focus();
   return false;
         }
        
 var SPECIAL_STR = "\\/:*?\"><|";
 for(i=0;i<(dataForm3.newFileName.value).length;i++)
 {
  if (SPECIAL_STR.indexOf((dataForm3.newFileName.value).charAt(i)) !=-1)
  {
   alert("文件名称不能含有如下字符\\/:*?\"><|");
   dataForm3.newFileName.focus();
   return false;
  }
 }
 //如果文件更名后和原文件名不同,则标示一个参数,表明确实有更名动作发生
 if(dataForm3.newFileName.value!="<%=UnicodeToChinese(request.getParameter("file"))%>")
 {
  window.dataForm3.changeDo.value="true";
 }
 else
 {
  alert("请输入一个新的文件名称!");
  dataForm3.newFileName.focus();
  return false;
 }
 
        window.dataForm3.submit();

}

<%}else if(strStat.equals("uploadFile")){%>
    function checkForm4()

 var Checkblank = /^(\s*|(\ )|(\.))*$/;
 if (Checkblank.test(dataForm4.fileName.value))
 {
          alert("重命名的文件夹名称不能为空!");
          dataForm4.fileName.focus();
   return false;
         }
 
        window.dataForm4.submit();

}

<%}%>
//-->
</SCRIPT>





分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: