日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

dll注入工具_UnmanagedPowerShell工具分析

發布時間:2023/12/19 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dll注入工具_UnmanagedPowerShell工具分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

簡單介紹:從非托管進程執行PowerShell。通過一些修改,可以在將這些相同的技術注入到不同的進程時使用(例如,如果需要,可以讓任何進程執行PowerShell)

下面借用網上的一張圖來說明這個流程,上面說了可以讓任何進程執行powershell其實也就是說使用具有注入功能的程序將一個非托管的C++DLL注入到目標進程中,然后該非托管DLL啟動CLR,并加載要執行的托管DLL,最后調用CLR執行托管代碼。

而我們下面的工具實現的是非托管進程啟動CLR,并加載要執行的托管的程序集,最后調用CLR執行托管代碼

下面就對UnmanagedPowerShell工具源碼來解釋下整個流程的工作運轉

關于PowerShellRunner.cs的部分

相關類的定義:

CustomPSHostUserInterface:可以替換我們要輸出的內容

CustomPSRHostRawUserInterface:配置用戶的界面

PSHost:為了讓Write-Host工作,我必須實現一個自定義PSHost。如果所有的PowerShell腳本都使用Write-Output而不是Write-Host,那么這就不是問題,但是如果使用了足夠多的Write-Host,那么實現一個定制PSHost是值得的

在C#中調用PowerShell會用到這個程序集,System.Management.Automation.dll,所以下面就是在適配調用時需要產生的類

using System;

using System.Collections.Generic;

using System.Text;

using System.Threading;

using System.Management.Automation;

using System.Globalization;

using System.Management.Automation.Host;

using System.Management.Automation.Runspaces;

namespace PowerShellRunner

{

public class PowerShellRunner

{

public static string InvokePS(string command)

{

// I had to implement a custom PSHost in order to get Write-Host to work.

// This wouldn't be an issue if all PowerShell scripts used Write-Output

// instead of Write-Host, but enough use Write-Host that it's worth it

// to implement a custom PSHost

//Write-Output返回的輸出被傳遞給管道,因此管道之后的函數/cmdlet可以讀取該輸出以進行進一步處理。如果您使用Write-Host,這是不可能的。

//為了讓Write-Host工作,我必須實現一個自定義PSHost。如果所有的PowerShell腳本都使用Write-Output而不是Write-Host,那么這就不是問題,但是如果使用了足夠多的Write-Host,那么實現一個定制PSHost是值得的

CustomPSHost host = new CustomPSHost();

//允許您定義在創建會話狀態時應該出現的元素集

//使用默認的cmdlet、提供程序等創建默認的PowerShell。內置函數,別名需要通過默認的InitialSessionstate構造函數可用。還需要對包裝進行討論。

var state = InitialSessionState.CreateDefault();

//指定此會話狀態實例使用的授權管理器。如果沒有指定授權管理器,那么將使用PowerShell的缺省授權管理器,它在運行命令之前檢查ExecutionPolicy

state.AuthorizationManager = null; // Bypass PowerShell execution policy?繞過PowerShell執行策略?

//RunspaceFactory--定義用于創建Runspace對象的工廠類

//使用指定的PSHost和InitialSessionState創建運行空間

using (Runspace runspace = RunspaceFactory.CreateRunspace(host, state))

{

//同步打開運行空間。運行空間在使用之前必須打開。

runspace.Open();

//Create an empty pipeline

using (Pipeline pipeline = runspace.CreatePipeline())

{

//Commands--獲取此管道的命令集合

//AddScript(String)????Adds a new script command ?添加一個新的腳本命令

pipeline.Commands.AddScript(command);

//合并此命令結果

//myResult:PipelineResultTypes:要重定向的管道流

//toResult:PipelineResultTypes:將myResult合并到的管道流

pipeline.Commands[0].MergeMyResults(PipelineResultTypes.Error, PipelineResultTypes.Output);

//將輸出發送到默認格式化程序和默認輸出cmdlet。

pipeline.Commands.Add("out-default");

//同步調用管道,以對象數組的形式返回結果

pipeline.Invoke();

}

}

//獲取托管應用程序的PSHostUserInterface抽象基類的實現。不希望支持用戶交互的主機應該返回null。

string output = ((CustomPSHostUserInterface)host.UI).Output;

return output;

}

//定義承載MSH運行空間的應用程序提供的屬性和功能

//System.Management.Automation.Runspaces到Msh運行時的公共接口。提供用于創建管道、訪問會話狀態等的api。

//GUID數據類型是表示類標識符(ID)的文本字符串

//托管應用程序派生自此類,并重寫抽象方法和屬性。托管應用程序將創建其派生類的實例,然后將其傳遞給RunspaceFactory CreateRunspace方法。

class CustomPSHost : PSHost

{

//初始化Guid結構的新實例

private Guid _hostId = Guid.NewGuid();

//設置PSHostUserInterface抽象基類的宿主應用程序的實現 。不想支持用戶交互的主機應返回null

private CustomPSHostUserInterface _ui = new CustomPSHostUserInterface();

//獲取唯一標識此主機實例的GUID。該值應在此實例的生命周期內保持不變

public override Guid InstanceId

{

get { return _hostId; }

}

//以某種用戶友好的方式獲取托管應用程序的標識。腳本和cmdlet可以引用這個名稱來標識執行它們的主機。值的格式沒有定義,但建議使用簡短的字符串。

public override string Name

{

get { return "ConsoleHost"; }

}

//獲取宿主應用程序的版本。對于主機的特定構建,此值應該保持不變。此值可由腳本和cmdlet引用。?

public override Version Version

{

get { return new Version(1, 0); }

}

//獲取托管應用程序的PSHostUserInterface抽象基類的實現。不希望支持用戶交互的主機應該返回null。?

public override PSHostUserInterface UI

{

get { return _ui; }

}

//獲取主機的區域性:運行空間應使用該區域性在新線程上設置CurrentCulture

public override CultureInfo CurrentCulture

{

get { return Thread.CurrentThread.CurrentCulture; }

}

//獲取主機的UI區域性:運行空間和cmdlet應該用來加載資源的區域性。

//每次啟動管道時,運行空間都會將線程當前ui區域性設置為這個值。

public override CultureInfo CurrentUICulture

{

get { return Thread.CurrentThread.CurrentUICulture; }

}

//指示主機中斷當前正在運行的管道并啟動一個新的“嵌套”輸入循環,其中輸入循環是提示、輸入和執行的循環。

public override void EnterNestedPrompt()

{

throw new NotImplementedException("EnterNestedPrompt is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//導致主機結束當前運行的輸入循環。如果先前調用EnterNestedPrompt創建了輸入循環,則封閉管道將恢復。如果當前輸入循環是最上面的循環,那么主機將執行SetShouldExit調用。

public override void ExitNestedPrompt()

{

throw new NotImplementedException("ExitNestedPrompt is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//由引擎調用,通知主機它將執行“遺留”命令行應用程序。遺留應用程序被定義為控制臺模式的可執行文件,它可以執行以下一個或多個操作:。讀stdin。寫信給stdout。寫信給stderr。使用任何win32控制臺api

public override void NotifyBeginApplication()

{

return;

}

//由引擎調用,通知主機遺留命令的執行已經完成

public override void NotifyEndApplication()

{

return;

}

//引擎請求結束當前引擎運行空間(關閉并終止主機的根運行空間)

public override void SetShouldExit(int exitCode)

{

return;

}

}

//提供一個對話框,允許用戶從一組選項中選擇一個選項

//定義由PSHost派生的托管應用程序提供的屬性和功能,該托管應用程序 提供了面向對話框和面向行的交互功能

class CustomPSHostUserInterface : PSHostUserInterface

{

// Replace StringBuilder with whatever your preferred output method is (e.g. a socket or a named pipe)

private StringBuilder _sb;

//將StringBuilder替換為您首選的輸出方法(例如,套接字或命名管道);

//獲取實現該類的--PSHostRawUserInterface抽象基類的托管應用程序實現。

private CustomPSRHostRawUserInterface _rawUi = new CustomPSRHostRawUserInterface();

public CustomPSHostUserInterface()?

{

_sb = new StringBuilder();

}

//將字符寫入屏幕緩沖區。不附加回車。

public override void Write(ConsoleColor foregroundColor, ConsoleColor backgroundColor, string value)

{

_sb.Append(value);

}

//默認實現將回車寫入屏幕緩沖區

public override void WriteLine()

{

_sb.Append("\n");

}

//與WriteLine(String)相同,只是可以指定顏色。

public override void WriteLine(ConsoleColor foregroundColor, ConsoleColor backgroundColor, string value)

{

_sb.Append(value + "\n");

}

//Writes characters to the screen buffer. Does not append a carriage return.

public override void Write(string value)

{

_sb.Append(value);

}

//由WriteDebug(String)調用,向用戶顯示調試消息。

public override void WriteDebugLine(string message)

{

_sb.AppendLine("DEBUG: " + message);

}

//向主機的“錯誤顯示”寫入一行,而不是由and的變體寫入的“輸出顯示”

public override void WriteErrorLine(string value)

{

_sb.AppendLine("ERROR: " + value);

}

//將字符寫入屏幕緩沖區,并附加回車

public override void WriteLine(string value)

{

_sb.AppendLine(value);

}

//由WriteVerbose(String)調用,向用戶顯示詳細的處理消息

public override void WriteVerboseLine(string message)

{

_sb.AppendLine("VERBOSE: " + message);

}

//由WriteWarning(String)調用,向用戶顯示警告處理消息。

public override void WriteWarningLine(string message)

{

_sb.AppendLine("WARNING: " + message);

}

//Invoked by System.Management.Automation.Cmdlet.WriteProgress(System.Int64,System.Management.Automation.ProgressRecord) to display a progress record.

public override void WriteProgress(long sourceId, ProgressRecord record)

{

return;

}

public string Output

{

get { return _sb.ToString(); }

}

//構造一個“對話框”,其中向用戶顯示許多要為其提供值的字段。

public override Dictionary Prompt(string caption, string message, System.Collections.ObjectModel.Collection descriptions)

{

throw new NotImplementedException("Prompt is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//提供一個對話框,允許用戶從一組選項中選擇一個選項

public override int PromptForChoice(string caption, string message, System.Collections.ObjectModel.Collection choices, int defaultChoice)

{

throw new NotImplementedException("PromptForChoice is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//Prompt for credentials.

public override PSCredential PromptForCredential(string caption, string message, string userName, string targetName, PSCredentialTypes allowedCredentialTypes, PSCredentialUIOptions options)

{

throw new NotImplementedException("PromptForCredential1 is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//提示輸入憑證

public override PSCredential PromptForCredential(string caption, string message, string userName, string targetName)

{

throw new NotImplementedException("PromptForCredential2 is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

public override PSHostRawUserInterface RawUI

{

get { return _rawUi; }

}

//從控制臺讀取字符,直到遇到換行(回車)。

public override string ReadLine()

{

throw new NotImplementedException("ReadLine is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

//與ReadLine相同,只是結果是SecureString,并且在收集輸入時不會回顯給用戶(或者以某種模糊的方式回顯,比如為每個字符顯示一個點)。

public override System.Security.SecureString ReadLineAsSecureString()

{

throw new NotImplementedException("ReadLineAsSecureString is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

}

//PSHostRawUserInterface 讀取用戶操作的界面

//可以提供Shell窗口物理操作方法的途徑,包括字符標記,屬性,以及文字前景和背景顏色等

class CustomPSRHostRawUserInterface : PSHostRawUserInterface

{

// Warning: Setting _outputWindowSize too high will cause OutOfMemory execeptions. I assume this will happen with other properties as well

//警告:設置_outputWindowSize過高將導致OutOfMemory執行。我想這也會發生在其他性質上

private Size _windowSize = new Size { Width = 120, Height = 100 };

private Coordinates _cursorPosition = new Coordinates { X = 0, Y = 0 };

private int _cursorSize = 1;

private ConsoleColor _foregroundColor = ConsoleColor.White;

private ConsoleColor _backgroundColor = ConsoleColor.Black;

private Size _maxPhysicalWindowSize = new Size

{

Width = int.MaxValue,

Height = int.MaxValue

};

private Size _maxWindowSize = new Size { Width = 100, Height = 100 };

private Size _bufferSize = new Size { Width = 100, Height = 1000 };

private Coordinates _windowPosition = new Coordinates { X = 0, Y = 0 };

private String _windowTitle = "";

public override ConsoleColor BackgroundColor

{

get { return _backgroundColor; }

set { _backgroundColor = value; }

}

public override Size BufferSize

{

get { return _bufferSize; }

set { _bufferSize = value; }

}

public override Coordinates CursorPosition

{

get { return _cursorPosition; }

set { _cursorPosition = value; }

}

public override int CursorSize

{

get { return _cursorSize; }

set { _cursorSize = value; }

}

//重置鍵盤輸入緩沖區

public override void FlushInputBuffer()

{

throw new NotImplementedException("FlushInputBuffer is not implemented.");

}

//獲取或設置用于在屏幕緩沖區上呈現字符的顏色。屏幕緩沖區中的每個字符單元可以具有單獨的前景色

public override ConsoleColor ForegroundColor

{

get { return _foregroundColor; }

set { _foregroundColor = value; }

}

//提取屏幕緩沖區的矩形區域

public override BufferCell[,] GetBufferContents(Rectangle rectangle)

{

throw new NotImplementedException("GetBufferContents is not implemented.");

}

//一個非阻塞調用,用于檢查擊鍵是否在輸入緩沖區中等待

public override bool KeyAvailable

{

get { throw new NotImplementedException("KeyAvailable is not implemented."); }

}

public override Size MaxPhysicalWindowSize

{

get { return _maxPhysicalWindowSize; }

}

public override Size MaxWindowSize

{

get { return _maxWindowSize; }

}

public override KeyInfo ReadKey(ReadKeyOptions options)

{

throw new NotImplementedException("ReadKey is not implemented. The script is asking for input, which is a problem since there's no console. Make sure the script can execute without prompting the user for input.");

}

public override void ScrollBufferContents(Rectangle source, Coordinates destination, Rectangle clip, BufferCell fill)

{

throw new NotImplementedException("ScrollBufferContents is not implemented");

}

public override void SetBufferContents(Rectangle rectangle, BufferCell fill)

{

throw new NotImplementedException("SetBufferContents is not implemented.");

}

public override void SetBufferContents(Coordinates origin, BufferCell[,] contents)

{

throw new NotImplementedException("SetBufferContents is not implemented");

}

public override Coordinates WindowPosition

{

get { return _windowPosition; }

set { _windowPosition = value; }

}

public override Size WindowSize

{

get { return _windowSize; }

set { _windowSize = value; }

}

public override string WindowTitle

{

get { return _windowTitle; }

set { _windowTitle = value; }

}

}

}

}

關于

UnmanagedPowerShell/UnmanagedPowerShell/UnmanagedPowerShell.cpp的部分

運行托管與非托管代碼根本區別在于托管代碼是進程首先加載CLR然后通過CLR運行托管程序,而非托管代碼則是操作系統直接根據其PE Header加載程序分配內存從而運行。因此如果需要通過托管代碼來擴展非托管程序,首先要加載CLR來使非托管程序獲得運行托管代碼的能力。所以下面代碼做的就是這個事情

// UnmanagedPowerShell.cpp : Defines the entry point for the console application.

//

#include "stdafx.h"

#pragma region Includes and Imports

#include

#include

#include

#include "PowerShellRunnerDll.h"

#include

#pragma comment(lib, "mscoree.lib")

// Import mscorlib.tlb (Microsoft Common Language Runtime Class Library).

//?微軟公共語言運行時類庫

//raw_interface_only:僅使用原始接口

//Foo([out, retval] long * pVal);這個函數,缺省時調用:long val = obj->Foo();

//如果用了raw_interface_only就要:

//long val;

//xx->Foo(&val);

#import "mscorlib.tlb" raw_interfaces_only \

//high_property_prefixes屬性

//high_property_prefixes("GetPrefix,""PutPrefix,""PutRefPrefix")

//GetPrefix

//用于propget方法的前綴

//PutPrefix

//用于propput方法的前綴

//PutRefPrefix

//用于propputref方法的前綴

//在缺省情況下,高級錯誤處理方法,如propget、propput和propputref,分別采用以前綴Get、Put和PutRef命名的成員函數來說明。high_property_prefixes屬性用于分別說明這三種屬性方法的前綴。

high_property_prefixes("_get","_put","_putref") \

//rename屬性

//rename("OldName,""NewName")

//OldName

//類型庫中的舊名

//NewName

//用于替換舊名的名稱

//rename屬性用于解決名稱沖突的問題。若該屬性被指定,編譯器將在類型庫中的OldName的所有出現處用結果頭文件中用戶提供的NewName替換。

//此屬性用于類型庫中

rename("ReportEvent", "InteropServices_ReportEvent")

using namespace mscorlib;

#pragma endregion

//創建接口實例,返回接口指針

//

typedef HRESULT(WINAPI *funcCLRCreateInstance)(

REFCLSID clsid,

REFIID riid,

LPVOID * ppInterface

);

//使非托管主機可以將公共語言運行庫(CLR)加載到進程中。該CorBindToRuntime和CorBindToRuntimeEx功能執行相同的操作,但該CorBindToRuntimeEx功能允許您設置標志來指定CLR的行為

typedef HRESULT (WINAPI *funcCorBindToRuntime)(

LPCWSTR pwszVersion,

LPCWSTR pwszBuildFlavor,

REFCLSID rclsid,

REFIID riid,

LPVOID* ppv);

extern const unsigned int PowerShellRunner_dll_len;

extern unsigned char PowerShellRunner_dll[];

void InvokeMethod(_TypePtr spType, wchar_t* method, wchar_t* command);

//適配.Net4

bool createDotNetFourHost(HMODULE* hMscoree, const wchar_t* version, ICorRuntimeHost** ppCorRuntimeHost)

{

HRESULT hr = NULL;

funcCLRCreateInstance pCLRCreateInstance = NULL;

ICLRMetaHost *pMetaHost = NULL;

ICLRRuntimeInfo *pRuntimeInfo = NULL;

bool hostCreated = false;

//尋找CLRCreateInstance函數的地址

pCLRCreateInstance = (funcCLRCreateInstance)GetProcAddress(*hMscoree, "CLRCreateInstance");

if (pCLRCreateInstance == NULL)

{

wprintf(L"Could not find .NET 4.0 API CLRCreateInstance");

goto Cleanup;

}

//若要獲取此接口的實例的唯一方法是通過調用CLRCreateInstance函數,如下所示:

//ICLRMetaHost *pMetaHost = NULL; HRESULT hr = CLRCreateInstance(CLSID_CLRMetaHost, IID_ICLRMetaHost, (LPVOID*)&pMetaHost);

hr = pCLRCreateInstance(CLSID_CLRMetaHost, IID_PPV_ARGS(&pMetaHost));

if (FAILED(hr))

{

// Potentially fails on .NET 2.0/3.5 machines with E_NOTIMPL

wprintf(L"CLRCreateInstance failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

//獲取與特定版本的公共語言運行時 (CLR) 相對應的ICLRRuntimeInfo接口

hr = pMetaHost->GetRuntime(L"v2.0.50727", IID_PPV_ARGS(&pRuntimeInfo));

if (FAILED(hr))

{

wprintf(L"ICLRMetaHost::GetRuntime failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

//檢查指定的運行時是否可以加載到流程中

// Check if the specified runtime can be loaded into the process.

BOOL loadable;

//指示與此接口關聯的運行時是否可以加載到當前進程中,考慮到可能已加載到進程的其他運行時。

hr = pRuntimeInfo->IsLoadable(&loadable);

if (FAILED(hr))

{

wprintf(L"ICLRRuntimeInfo::IsLoadable failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

if (!loadable)

{

wprintf(L".NET runtime v2.0.50727 cannot be loaded\n");

goto Cleanup;

}

// Load the CLR into the current process and return a runtime interface

//?將CLR加載到當前進程并返回運行時接口

hr = pRuntimeInfo->GetInterface(CLSID_CorRuntimeHost, IID_PPV_ARGS(ppCorRuntimeHost));

if (FAILED(hr))

{

wprintf(L"ICLRRuntimeInfo::GetInterface failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

hostCreated = true;

Cleanup:

if (pMetaHost)

{

pMetaHost->Release();

pMetaHost = NULL;

}

if (pRuntimeInfo)

{

pRuntimeInfo->Release();

pRuntimeInfo = NULL;

}

return hostCreated;

}

//適配.Net2

HRESULT createDotNetTwoHost(HMODULE* hMscoree, const wchar_t* version, ICorRuntimeHost** ppCorRuntimeHost)

{

HRESULT hr = NULL;

bool hostCreated = false;

funcCorBindToRuntime pCorBindToRuntime = NULL;

//CorBindToRuntime--使非托管的宿主能夠將公共語言運行時 (CLR) 加載到進程中,.NET Framework 4 中已棄用此函數

pCorBindToRuntime = (funcCorBindToRuntime)GetProcAddress(*hMscoree, "CorBindToRuntime");

if (!pCorBindToRuntime)

{

wprintf(L"Could not find API CorBindToRuntime");

goto Cleanup;

}

//HRESULT CorBindToRuntime (??

// ? ?[in]??LPCWSTR?????pwszVersion, ? ?想要加載的 CLR 版本描述的字符串,.NET Framework 中的版本號用句點分隔的四個部分組成:major.minor.build.revision。將字符串作為傳遞pwszVersion必須以字符"v"跟版本號 (例如,"v1.0.1529") 的前三個部分開頭,如果調用方指定為 null pwszVersion,加載的運行時的最新版本。

// ? ?[in]??LPCWSTR?????pwszBuildFlavor, ? ?一個字符串,指定是否加載在服務器或工作站的 clr 版本。有效值為 svr 和 wks。服務器生成經過優化,可充分利用多個處理器,用于垃圾回收和工作站生成優化的單處理器計算機上運行的客戶端應用程序,如果pwszBuildFlavor設置為 null,則將加載工作站版本。在單處理器計算機上運行時,工作站生成始終處于加載狀態,即使pwszBuildFlavor設置為svr。但是,如果pwszBuildFlavor設置為svr,并且指定并發垃圾回收 (請參閱的說明flags參數),將加載服務器版本。

// ? ?[in]??REFCLSID????rclsid,???CLSID的實現的組件類ICorRuntimeHost或ICLRRuntimeHost接口。支持的值為 CLSID_CorRuntimeHost 或 CLSID_CLRRuntimeHost

// ? ?[in]??REFIID??????riid,???IID從所請求的接口的rclsid。支持的值為 IID_ICorRuntimeHost 或 IID_ICLRRuntimeHost

// ? ?[out] LPVOID FAR??*ppv??指向返回的接口指針riid

//);??

hr = pCorBindToRuntime(version, L"wks", CLSID_CorRuntimeHost, IID_PPV_ARGS(ppCorRuntimeHost));

if (FAILED(hr))

{

wprintf(L"CorBindToRuntime failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

hostCreated = true;

Cleanup:

return hostCreated;

}

HRESULT createHost(const wchar_t* version, ICorRuntimeHost** ppCorRuntimeHost)

{

bool hostCreated = false;

HMODULE hMscoree = LoadLibrary(L"mscoree.dll");

if (hMscoree)

{

if (createDotNetFourHost(&hMscoree, version, ppCorRuntimeHost) || createDotNetTwoHost(&hMscoree, version, ppCorRuntimeHost))

{

hostCreated = true;

}

}

return hostCreated;

}

int _tmain(int argc, _TCHAR* argv[])

{

HRESULT hr;

ICorRuntimeHost *pCorRuntimeHost = NULL;

IUnknownPtr spAppDomainThunk = NULL;

_AppDomainPtr spDefaultAppDomain = NULL;

// The .NET assembly to load.

bstr_t bstrAssemblyName("PowerShellRunner");

_AssemblyPtr spAssembly = NULL;

// The .NET class to instantiate.

bstr_t bstrClassName("PowerShellRunner.PowerShellRunner");

_TypePtr spType = NULL;

// Create the runtime host

if (!createHost(L"v2.0.50727", &pCorRuntimeHost))

{

wprintf(L"Failed to create the runtime host\n");

goto Cleanup;

}

// Start the CLR

hr = pCorRuntimeHost->Start();

if (FAILED(hr))

{

wprintf(L"CLR failed to start w/hr 0x%08lx\n", hr);

goto Cleanup;

}

DWORD appDomainId = NULL;

//獲取類型的接口指針System._AppDomain,表示當前進程的默認域

//[out]類型的接口指針System._AppDomain到AppDomain表示進程的默認應用程序域的實例

hr = pCorRuntimeHost->GetDefaultDomain(&spAppDomainThunk);

if (FAILED(hr))

{

wprintf(L"RuntimeClrHost::GetCurrentAppDomainId failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

// Get a pointer to the default AppDomain in the CLR.

//獲取類型的接口指針System._AppDomain,表示當前進程的默認域

hr = pCorRuntimeHost->GetDefaultDomain(&spAppDomainThunk);

if (FAILED(hr))

{

wprintf(L"ICorRuntimeHost::GetDefaultDomain failed w/hr 0x%08lx\n", hr);

goto Cleanup;

}

//此指針被類型化為IUnknown,因此調用方通常應調用QueryInterface若要獲取類型的接口指針System._AppDomain。

hr = spAppDomainThunk->QueryInterface(IID_PPV_ARGS(&spDefaultAppDomain));?

if (FAILED(hr))

{

wprintf(L"Failed to get default AppDomain w/hr 0x%08lx\n", hr);

goto Cleanup;

}

// Load the .NET assembly.

// (Option 1) Load it from disk - usefully when debugging the PowerShellRunner app (you'll have to copy the DLL into the same directory as the exe)

加載.net程序集。

//(選項1)從磁盤加載它—在調試PowerShellRunner應用程序時非常有用(您必須將DLL復制到與exe相同的目錄中)

//參數

//assemblyString

//String

//程序集的顯示名稱。請參閱 FullName。

//assemblySecurity

//Evidence

//用于加載程序集的證據。

// hr = spDefaultAppDomain->Load_2(bstrAssemblyName, &spAssembly);

// (Option 2) Load the assembly from memory

SAFEARRAYBOUND bounds[1];

bounds[0].cElements = PowerShellRunner_dll_len;

bounds[0].lLbound = 0;

//創建一個新的數組描述符,分配和初始化該數組的數據,并返回一個指向新數組描述符的指針

//VT_UI1 type property MUST be a 1-byte unsigned integer

SAFEARRAY* arr = SafeArrayCreate(VT_UI1, 1, bounds);

//vt

//數組的基本類型(數組每個元素的VARTYPE)。VARTYPE僅限于變體類型的子集。VT_ARRAY和VT_BYREF標志都不能設置。VT_EMPTY和VT_NULL是該數組的無效基本類型。所有其他類型都是合法的。

//cDims

//數組中的維數。創建陣列后不能更改該數字。

//rgsabound

//為數組分配的邊界向量(每個維度一個)。

//遞增數組的鎖計數,并將指向數組數據的指針放在數組描述符的pvData中

SafeArrayLock(arr);

//memcpy指的是C和C ++使用的內存拷貝函數,函數原型為void * memcpy(void * destin,void * source,unsigned n)

memcpy(arr->pvData, PowerShellRunner_dll, PowerShellRunner_dll_len);

SafeArrayUnlock(arr);

hr = spDefaultAppDomain->Load_3(arr, &spAssembly);

if (FAILED(hr))

{

wprintf(L"Failed to load the assembly w/hr 0x%08lx\n", hr);

goto Cleanup;

}

// Get the Type of PowerShellRunner.

//spType表示類型聲明:類類型、接口類型、數組類型、值類型、枚舉類型、類型參數、泛型類型定義,以及開放或封閉構造的泛型類型。

hr = spAssembly->GetType_2(bstrClassName, &spType);

if (FAILED(hr))

{

wprintf(L"Failed to get the Type interface w/hr 0x%08lx\n", hr);

goto Cleanup;

}

// Call the static method of the class

wchar_t* argument = L"Get-Process\n\

#This is a PowerShell Comment\n\

Write-Host \"`n`n******* The next command is going to throw an exception. This is planned *********`n`n\"\n\

Read-Host\n";

InvokeMethod(spType, L"InvokePS", argument);

Cleanup:

if (pCorRuntimeHost)

{

pCorRuntimeHost->Release();

pCorRuntimeHost = NULL;

}

return 0;

}

void InvokeMethod(_TypePtr spType, wchar_t* method, wchar_t* command)

{

HRESULT hr;

bstr_t bstrStaticMethodName(method);

SAFEARRAY *psaStaticMethodArgs = NULL;

variant_t vtStringArg(command);

variant_t vtPSInvokeReturnVal;

variant_t vtEmpty;

//SAFEARRAY* SafeArrayCreateVector(???//用于建立一維普通數組。

// ?VARTYPE vt,??????????????????????????????????????????//數組類型

// ?long lLbound,??????????????????????????????????????????//數組的最小下標(可以取負數)

// ?unsigned int cElements???????????????????????????//數組的長度

//);

//創建方法參數

psaStaticMethodArgs = SafeArrayCreateVector(VT_VARIANT, 0, 1);

LONG index = 0;

//放元素到數組當中

hr = SafeArrayPutElement(psaStaticMethodArgs, &index, &vtStringArg);

if (FAILED(hr))

{

wprintf(L"SafeArrayPutElement failed w/hr 0x%08lx\n", hr);

return;

}

// Invoke the method from the Type interface.

//使用指定的綁定約束和匹配的指定參數列表及區域性來調用指定成員。

hr = spType->InvokeMember_3(

bstrStaticMethodName, //字符串,它包含要調用的構造函數、方法、屬性或字段成員的名稱

static_cast(BindingFlags_InvokeMethod | BindingFlags_Static | BindingFlags_Public),

invokeAttr

BindingFlags

枚舉值的按位組合,這些值指定如何進行搜索。 訪問可以是 BindingFlags 之一,如 Public、NonPublic、Private、InvokeMethod 和 GetField 等。查找類型無需指定。如果省略查找的類型,則將使用 BindingFlags.Public | BindingFlags.Instance | BindingFlags.Static。

NULL,?一個對象,該對象定義一組屬性并啟用綁定,而綁定可能涉及選擇重載方法、強制參數類型和通過反射調用成員。

vtEmpty,?對其調用指定成員的對象

psaStaticMethodArgs,?包含傳遞給要調用的成員的參數的數組

&vtPSInvokeReturnVal); ?表示要使用的全局化區域設置的對象,它對區域設置特定的轉換可能是必需的,比如將數字 String 轉換為 Double。

if (FAILED(hr))

{

wprintf(L"Failed to invoke InvokePS w/hr 0x%08lx\n", hr);

return;

}

else

{

// Print the output of the command

wprintf(vtPSInvokeReturnVal.bstrVal);

}

SafeArrayDestroy(psaStaticMethodArgs);

psaStaticMethodArgs = NULL;

}?

總結

以上是生活随笔為你收集整理的dll注入工具_UnmanagedPowerShell工具分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

天天综合入口 | 国产成人在线免费观看 | 精品一区二区三区电影 | 婷婷丁香综合 | 在线免费观看羞羞视频 | 最近在线中文字幕 | 亚洲精品久久久久999中文字幕 | 五月天婷婷在线视频 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 亚洲精品国偷拍自产在线观看 | 手机av电影在线 | 成人在线观看你懂的 | 在线观看国产福利片 | 国产日韩精品在线观看 | 亚洲精品一区中文字幕乱码 | 国产手机在线视频 | 亚洲欧美日韩国产一区二区 | 久久av一区二区三区亚洲 | 99国内精品久久久久久久 | 日日色综合 | 日韩欧美在线观看一区二区 | 久久久久久久免费看 | www.亚洲精品视频 | 国产成人精品亚洲日本在线观看 | 日本护士三级少妇三级999 | 99久久精品无码一区二区毛片 | 免费在线观看污 | 中文字幕在线播放一区 | 日韩中文字幕国产精品 | 欧美精品国产综合久久 | 亚洲精品视频二区 | 美女网站视频色 | 五月天国产精品 | 天天插天天爱 | 国产视频精品免费播放 | 97超碰在线久草超碰在线观看 | 国产精品久久久999 国产91九色视频 | 99视频国产精品免费观看 | 99久久精品国产免费看不卡 | 99久久99久久精品国产片果冰 | 亚洲最新av网址 | 国产成人精品三级 | 制服丝袜一区二区 | 中文字幕成人在线观看 | 狠狠干天天 | 中文字幕欧美激情 | 天天操夜夜操国产精品 | 国产黄在线 | 激情视频免费在线观看 | 日韩久久久久久 | 亚洲精品综合在线观看 | 中国一级特黄毛片大片久久 | 日韩成人免费在线电影 | 国产日韩在线观看一区 | 色视频在线免费观看 | 在线观看香蕉视频 | 91精彩视频在线观看 | 91在线播 | 久久激情电影 | 久久精品一二三区 | 伊人手机在线 | 91免费试看 | 天天操天天干天天操天天干 | 白丝av在线 | 精品欧美一区二区三区久久久 | 国产精品理论片在线播放 | 国产我不卡 | www.成人精品| 久久精品电影院 | 国产精品第72页 | 91精品啪在线观看国产线免费 | av电影不卡在线 | 99精品免费久久久久久日本 | 日本成人中文字幕在线观看 | 久久精品视频4 | 夜夜爱av | 亚洲人在线 | 欧美色就是色 | 亚洲成免费 | 丁香六月网 | 天天草天天草 | 国产精品欧美精品 | 日本中文字幕高清 | 999久久国精品免费观看网站 | 欧美日韩一区二区三区免费视频 | 日韩激情片在线观看 | 国产伦精品一区二区三区无广告 | 97人人模人人爽人人喊中文字 | 国产亚洲午夜高清国产拍精品 | 国产成人a亚洲精品 | 成人免费在线看片 | 最近中文字幕 | 天天躁日日躁狠狠躁 | 最新av观看 | 欧美精品久久久久久 | 久草爱| 91亚洲精品乱码久久久久久蜜桃 | 天天草天天干天天 | 一区二区精品国产 | 91在线一区二区 | 欧美成年网站 | 国产免费一区二区三区网站免费 | 狠狠狠干 | 国产一级特黄毛片在线毛片 | 亚洲播播| 日韩视频在线不卡 | 91亚洲精品久久久中文字幕 | 91禁看片 | 久久爱综合 | 91爱在线| 欧美男男tv网站 | 精品无人国产偷自产在线 | 欧美日韩视频在线一区 | 中文字幕传媒 | 成人动图| 欧美极品xxxx | 69视频在线播放 | 久久黄色精品视频 | 国产三级视频 | 国产999精品久久久 免费a网站 | 国产精品美女视频网站 | 99久久99久久精品国产片果冰 | 视频二区在线 | 日韩精品在线观看视频 | 热久久这里只有精品 | 亚洲综合视频网 | 国产精品久久久久久高潮 | 深夜福利视频在线观看 | www.色综合.com | 一本一本久久a久久精品牛牛影视 | 国产成人精品999 | 国内外成人在线视频 | 国产午夜精品福利视频 | 色偷偷网站视频 | 久久成人在线视频 | 欧美少妇xx | 91精品国产电影 | 一区二区三区手机在线观看 | 高清不卡免费视频 | 久久精品激情 | 免费午夜av | 在线观看国产日韩 | 蜜臀av一区二区 | 欧美韩国日本在线观看 | 日韩欧美国产激情在线播放 | 欧美性一级观看 | av在线播放观看 | 黄色网址av| 天天干天天草天天爽 | 欧美日韩另类在线 | 国产视频在线免费观看 | 91视频 - x99av | 久久久久免费精品国产 | 亚洲在线精品视频 | 国产精品女 | 国产精品久久久久久久久久久久午夜 | 黄色最新网址 | 伊人五月| 91丨九色丨勾搭 | 一区二区三区四区不卡 | 91在线永久 | 天天操天天摸天天干 | 少妇搡bbb| 久久久久成人精品免费播放动漫 | 国产亚洲精品电影 | 最近av在线| av噜噜噜在线播放 | 婷婷五天天在线视频 | 激情久久久久 | 三级黄色免费片 | 亚洲欧美婷婷六月色综合 | 久久精品国产免费看久久精品 | 国产精品片 | 亚洲成人av一区二区 | 国产91免费在线观看 | 日韩在线视 | www免费| 国产一级二级在线播放 | 激情六月婷婷久久 | 成人免费视频在线观看 | 国产精品一区欧美 | 手机av网站 | 激情综合网天天干 | 天天操天天操天天干 | 欧美在线资源 | 国产中文字幕大全 | 久久成人久久 | 最新在线你懂的 | 五月天电影免费在线观看一区 | 久久久亚洲国产精品麻豆综合天堂 | 热久久国产 | 日韩欧美精品在线观看视频 | 国产精品 国内视频 | 欧美日韩在线观看一区二区 | 国产高清视频网 | 日韩中文字 | 在线观看国产一区二区 | 日韩区欠美精品av视频 | 一区二区三区四区在线 | 国产色妞影院wwwxxx | 韩国av一区二区三区在线观看 | 丁香婷婷成人 | 99精品国产福利在线观看免费 | 在线a人v观看视频 | 亚洲a成人v | 成人av在线亚洲 | 日韩在线不卡av | 国产伦理一区二区 | 91热爆视频 | 91在线国产观看 | 亚洲 中文字幕av | 啪啪精品 | 天天干人人插 | 午夜精品一区二区三区在线 | 成人毛片久久 | 欧美国产日韩一区二区三区 | 韩国精品福利一区二区三区 | 欧美十八| 精品一区三区 | 欧美在线a视频 | 天天爱天天操天天干 | 夜色资源网 | 久久午夜羞羞影院 | 黄色精品久久久 | 在线观看亚洲精品 | 日韩高清www | 久久综合狠狠综合久久综合88 | 97在线免费视频 | 国产日韩欧美在线 | 97精品国产97久久久久久免费 | 国产一级视频在线 | 久久不色| 国产福利小视频在线 | 色丁香综合 | 九9热这里真品2 | 久久视频精品在线观看 | 91视频3p | 国产最新视频在线观看 | 五月激情视频 | 久久免费福利 | 九九久久精品 | 天天操天天爽天天干 | 久草在线这里只有精品 | 成人免费视频网 | 国产在线精品区 | 久久99久久99精品 | 国产91小视频 | a在线一区 | 狠狠狠综合 | 手机看国产毛片 | 天天艹天天 | 亚洲成人av影片 | 国产欧美最新羞羞视频在线观看 | 亚洲黑丝少妇 | 免费色网站 | 天天操天天添 | www五月天 | 日日夜夜骑 | wwwwww国产 | 女人18片毛片90分钟 | 欧美三级免费 | 在线免费成人 | 激情电影影院 | 波多野结衣在线视频一区 | 久久99亚洲热视 | 日本不卡一区二区 | 亚洲免费观看在线视频 | 国产精品免费观看在线 | 日批视频在线播放 | 亚洲国产精品电影 | 久久av在线 | 在线观看免费91 | 精品国产乱码久久久久久1区2匹 | 有码中文在线 | 久久99热国产 | 国产精品久久久久久久久免费 | 亚洲日本精品视频 | 在线观看岛国av | 97视频人人 | www.色婷婷 | 99免费在线播放99久久免费 | 欧美亚洲国产日韩 | 国产色女人 | av中文在线观看 | 丰满少妇一级片 | 日韩在线高清 | 91传媒激情理伦片 | 欧美性生活免费看 | 国产婷婷在线观看 | 免费午夜视频在线观看 | 综合天天久久 | 中文字幕网址 | 日韩网站视频 | 中文一区二区三区在线观看 | 日韩乱色精品一区二区 | 国产91全国探花系列在线播放 | 亚洲激色 | 人人涩 | 99久久精品国产欧美主题曲 | 欧美精品第一 | 菠萝菠萝蜜在线播放 | 国产精品99久久久久久宅男 | 久久99国产精品自在自在app | 欧美a在线免费观看 | 91av在线电影 | 亚洲精品字幕在线观看 | 欧美大片在线看免费观看 | 91.dizhi永久地址最新 | 亚洲精品成人网 | 欧美 日韩精品 | 中文字幕一区二区三区在线视频 | 国产黄色精品在线观看 | 国产精品第一页在线 | 免费在线色视频 | 狠狠色狠狠色合久久伊人 | 日韩高清精品免费观看 | 日韩欧美网址 | 久久综合九九 | 在线观看视频中文字幕 | 色婷婷五| 日韩av高清在线观看 | 狠狠操天天射 | 免费观看第二部31集 | 国产精品久久婷婷六月丁香 | 中文字幕在线中文 | 日韩国产精品一区 | 国产一级视频在线 | 天天天天天天天天操 | 精品久久免费看 | 久久久久久久久国产 | 国产美女主播精品一区二区三区 | 国产一区在线看 | 免费日韩一区 | 久久精品香蕉视频 | 奇米影视8888在线观看大全免费 | 亚洲国产中文字幕 | 久久婷婷色综合 | 天天干天天干天天干天天干天天干天天干 | 欧美九九视频 | 成人免费视频网 | 在线观看视频日韩 | 国产高清免费在线播放 | 天天色.com| 精品国产福利在线 | 国产一区二区在线播放 | 久久久精品国产免费观看一区二区 | 777视频在线观看 | a午夜电影 | 六月色丁 | 久草9视频 | 91在线看片 | 天天综合网国产 | 成人app在线播放 | 在线看国产日韩 | 久久久福利视频 | 欧美精品乱码久久久久久 | 在线观看亚洲国产 | 成人免费毛片aaaaaa片 | 激情综合网五月激情 | 奇米先锋| 欧美在线一二 | 欧美日韩18 | 日本不卡一区二区三区在线观看 | 麻豆视频免费在线播放 | www免费看片com | 亚洲精品视频网 | 国产高清专区 | 久久精品成人欧美大片古装 | 国产一区二区在线影院 | 国精产品一二三线999 | 成人a级免费视频 | 日韩h在线观看 | 日韩精品中文字幕有码 | 免费日韩一区二区三区 | 欧美午夜a| 9999国产精品 | 国产精品第二页 | 欧美日韩91 | 久影院| 免费看v片网站 | 激情片av| 亚洲天天看 | 久草视频观看 | 99精品免费在线 | 三上悠亚一区二区在线观看 | 午夜视频黄 | 国产中文欧美日韩在线 | 国产午夜精品理论片在线 | 丁香五月缴情综合网 | 日韩欧美综合在线视频 | 国产中文在线播放 | 1024手机在线看 | 国产精品久久影院 | 精品亚洲免a | 日韩大陆欧美高清视频区 | 99精品视频免费全部在线 | 免费亚洲精品 | 97超碰国产精品 | 久久免费毛片视频 | 在线有码中文字幕 | 成人教育av| 精品国产成人在线影院 | 亚洲综合色丁香婷婷六月图片 | 亚洲成aⅴ人片久久青草影院 | 在线观看免费黄视频 | 日韩精品91偷拍在线观看 | 天堂av免费在线 | 国产99久久久精品视频 | 国产精品观看视频 | 亚洲精品一区二区三区在线观看 | www.神马久久 | 五月综合在线观看 | 成人资源在线 | 黄色aa久久 | 久久电影日韩 | 亚洲精品午夜一区人人爽 | 99精品免费在线观看 | 欧美一区视频 | 国产成人久久精品 | 亚洲精品久久激情国产片 | 国产精品99久久久久久小说 | 久久99久久99精品免观看粉嫩 | 香蕉视频91 | www.天天射 | 免费黄色网止 | a视频在线播放 | 九九久久久久久久久激情 | 日日夜夜人人天天 | 亚洲天堂精品视频在线观看 | 久久免费在线观看 | 国外调教视频网站 | 黄色大全在线观看 | 亚洲综合一区二区精品导航 | 国产美女黄网站免费 | 91热在线 | 国产一区国产二区在线观看 | 成人性生交大片免费看中文网站 | 黄色午夜网站 | 中文字幕在线视频精品 | 超碰人人做 | 久久不见久久见免费影院 | 久久精品中文字幕免费mv | a级国产乱理伦片在线播放 久久久久国产精品一区 | 四虎影视精品永久在线观看 | 日韩电影中文字幕在线 | 在线黄色毛片 | 色婷婷 亚洲 | 娇妻呻吟一区二区三区 | 97品白浆高清久久久久久 | 人人澡人人爽欧一区 | 久草视频免费看 | 欧美日韩不卡在线 | 成人国产一区 | 六月天综合网 | 亚洲免费公开视频 | 天天色综合1 | 亚洲黄色免费 | 人人爱在线视频 | 亚洲视频第一页 | 福利一区二区在线 | 在线观看国产成人av片 | 91成人网在线观看 | 国产成人综合在线观看 | 黄色aa久久 | 久久国产精品久久久 | 玖玖综合网 | 九九免费在线观看视频 | 久久手机在线视频 | 韩国av一区二区三区在线观看 | 日日夜夜婷婷 | 日韩专区中文字幕 | 在线视频精品 | 最新国产精品久久精品 | 日韩成人在线免费观看 | 69视频网站| 亚洲精品视频一二三 | 亚洲精品视频在线免费播放 | 欧美电影黄色 | 日本在线观看中文字幕 | 国产福利一区二区在线 | 韩国精品在线 | 久久久国产精华液 | 伊人春色电影网 | 国产一级片在线播放 | 一区二区三区高清在线观看 | 在线观看的黄色 | 青青网视频 | 91视频传媒 | 精品1区2区| 精品一区二区综合 | 伊人狠狠色 | 免费观看一区二区 | 在线视频一二区 | 久久女教师 | 国产福利一区二区三区在线观看 | 91香蕉视频色版 | 中文字幕在线观看资源 | 久久久久人人 | 激情av五月婷婷 | 国内视频| 免费网站看v片在线a | 亚洲精品国产第一综合99久久 | 少妇高潮冒白浆 | 在线观看国产区 | 久久久国产网站 | 久久亚洲免费 | 久久精品电影院 | 亚洲国产成人av网 | 亚洲三级毛片 | 麻豆国产视频下载 | 天天色播 | 欧美999| 国产美女视频免费 | 99热在线国产精品 | 中文字幕电影高清在线观看 | 99热在线精品观看 | 日本久久久久久科技有限公司 | 精品久久久久亚洲 | 在线看国产 | 亚洲蜜桃在线 | 免费日韩精品 | www.天天操| 一区二区精品视频 | 人人干网 | 丁香av在线 | 亚州性色 | 国产精品露脸在线 | 午夜精品久久久久久中宇69 | 99久久久久成人国产免费 | 国产九九九九九 | av丁香花 | 久久色视频 | 欧美a在线看 | 在线日本看片免费人成视久网 | 国产91精品一区二区麻豆网站 | 成人精品一区二区三区电影免费 | 国内免费久久久久久久久久久 | 亚洲国产操 | 亚洲四虎在线 | 久草在线免费看视频 | 久久久96| 99精品国产99久久久久久福利 | 九九99靖品 | 国产免费黄视频在线观看 | 国产99久久久国产精品 | 免费在线观看成人 | 麻豆影视在线观看 | 免费在线观看成人 | 日韩欧美高清在线 | 91福利影院在线观看 | 最新av网址在线观看 | 久久大香线蕉app | 欧美日高清视频 | 黄色一级大片免费看 | 中文字幕在线观看一区 | 久久97久久97精品免视看 | 日韩av资源在线观看 | 精品久久久久免费极品大片 | 亚洲精品国偷拍自产在线观看 | 日韩视频图片 | 米奇影视7777 | 在线观看精品国产 | 天海翼一区二区三区免费 | 99精品免费久久久久久久久 | 伊人中文网 | 91传媒免费在线观看 | 久久久久久精 | 亚洲精品网站在线 | 欧美日韩二区在线 | 人人模人人爽 | 久久久久亚洲精品成人网小说 | 日本中文字幕影院 | 婷婷视频在线观看 | 97视频人人 | 久久久久国产精品一区二区 | 久草在线网址 | 亚洲欧美成人在线 | 亚洲一级片免费观看 | 精品福利网 | 在线日本看片免费人成视久网 | 日本黄色片一区二区 | av在线网站观看 | 精品久久1 | 色天天中文 | 2024国产在线 | 97超碰人人爱 | 综合中文字幕 | 中文av免费| www.久久色| 午夜成人免费影院 | 全久久久久久久久久久电影 | 精品在线视频一区二区三区 | 一级一级一片免费 | 91精品视频在线免费观看 | 国产成人av福利 | www五月天com | 成av在线 | 激情综合五月 | 国产录像在线观看 | 中文字幕 成人 | 91人人爽人人爽人人精88v | 在线亚洲欧美视频 | 免费看的黄色 | 国产精品扒开做爽爽的视频 | 97色国产 | 91精品91| 丁香婷婷激情五月 | 91成人免费电影 | 中文一区在线观看 | 免费观看版 | 色网站在线免费 | 亚洲免费av在线播放 | 欧美资源在线观看 | 亚洲 综合 专区 | wwwwwww色| 色婷婷综合久久久 | 91九色视频在线观看 | 成人免费毛片aaaaaa片 | 九九九视频在线 | 中文字幕一区二区三 | 日日夜夜精品免费观看 | 久久综合欧美精品亚洲一区 | 一级免费片 | 黄色大片免费播放 | 97爱| 91一区二区三区久久久久国产乱 | 看片的网址 | 激情偷乱人伦小说视频在线观看 | www·22com天天操 | 在线精品亚洲一区二区 | 不卡av在线免费观看 | 在线观看色视频 | 日韩中文字幕免费在线观看 | 久久精品福利视频 | 久久精品综合网 | 日韩1页| 日韩理论片 | 91成人免费电影 | 国产精选在线 | 国产精品久久99综合免费观看尤物 | 99久久激情视频 | 美女在线免费视频 | 美女黄网久久 | 日韩欧美一区二区在线 | 国产一区欧美日韩 | 九九热免费视频在线观看 | 国产一区精品在线 | 亚洲黄色免费观看 | 国产精品精品国产 | 丁香五月缴情综合网 | 久久九九视频 | 成年人视频在线观看免费 | 午夜视频导航 | 字幕网资源站中文字幕 | 99在线精品免费视频九九视 | 日韩av电影免费在线观看 | 香蕉视频国产在线观看 | 国产老妇av | 一级黄色片在线免费看 | 亚州精品在线视频 | 97在线观看免费观看高清 | 久久婷婷色 | 四虎永久免费 | 成年人黄色av| 日韩资源在线播放 | 欧美在线观看视频免费 | 在线观看岛国片 | 国产日韩精品一区二区 | 精品久久久久久国产偷窥 | 国产精品高清免费在线观看 | www..com黄色片| 免费看黄色大全 | 日韩在线视频一区二区三区 | 人人玩人人添人人澡超碰 | 91精品久久久久 | 韩国精品视频在线观看 | 视频1区2区 | 看片的网址 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 久久精品视频4 | 99中文字幕在线观看 | 国产麻豆电影在线观看 | 亚洲一二三久久 | 日韩电影中文字幕在线观看 | 国产精品免费一区二区三区 | 亚洲精品国产欧美在线观看 | 伊人天天狠天天添日日拍 | 中文字幕一区二区三区久久蜜桃 | 国产一区二区三区免费在线 | 婷婷久久一区 | 色资源在线| 在线a亚洲视频播放在线观看 | 91成人网页版 | 黄色大片日本免费大片 | 一级片色播影院 | 草免费视频 | 久久99精品久久久久久久久久久久 | 成人播放器 | 草久视频在线 | 国产999精品久久久久久绿帽 | 不卡av在线 | www.黄色在线 | 日日精品 | 天天操天天谢 | 精品欧美小视频在线观看 | 成人网444ppp | 天天爱天天操 | 国产高清福利在线 | 欧美日韩三级 | 久久九九视频 | 精品免费一区二区三区 | 99精品视频在线观看视频 | 精品美女久久久久久免费 | 日本公妇在线观看 | 久久久综合精品 | 日本中文一级片 | 久久字幕 | 夜夜夜夜操 | 免费亚洲黄色 | 国产亚洲一区二区三区 | 五月情婷婷 | 五月婷婷中文网 | 精品免费视频. | 日日摸日日添夜夜爽97 | 日韩欧美一区二区三区免费观看 | 欧美综合在线观看 | av理论电影 | 综合久久2023 | 涩涩网站在线看 | 欧美日韩1区2区 | 国产精品av在线免费观看 | 国产高清在线免费 | 在线观看成人小视频 | 国产高清第一页 | 日本电影黄色 | 中文字幕在线观看网 | 91av手机在线观看 | 一区二区三区免费在线观看视频 | 国产日韩在线看 | 天天爱综合 | 丝袜网站在线观看 | 天天操狠狠操网站 | 日本美女xx | 天天干天天干天天干天天干天天干天天干 | 欧美精品久久久久久久久老牛影院 | 日本精品一区二区三区在线播放视频 | 国产理伦在线 | 国产福利91精品 | 成人黄色小说视频 | 五月天最新网址 | av片一区二区 | 久久国产精品久久精品 | 久久av免费电影 | 亚洲a在线观看 | 亚洲免费公开视频 | 视频二区在线 | 久久影视一区 | 亚洲日本黄色 | 亚洲电影久久 | 天无日天天操天天干 | 久久国产精品99久久久久久进口 | 国产一区二区三区四区大秀 | 中文字幕日韩国产 | 能在线观看的日韩av | 中文字幕综合在线 | 婷婷色婷婷| 中文av字幕在线观看 | 四虎免费在线观看视频 | 91久久偷偷做嫩草影院 | 激情伊人五月天 | 国产午夜在线观看 | 右手影院亚洲欧美 | 在线小视频 | 欧美精品在线免费 | 日本中文字幕在线一区 | 国产区精品视频 | 一二三四精品 | 日韩精品黄 | 99亚洲视频 | 中文区中文字幕免费看 | 久久麻豆精品 | 日本精品久久久久影院 | 69久久久久久久 | 在线观看中文字幕一区二区 | 欧美激情精品久久久久久免费 | 日韩高清在线不卡 | 成人久久久久久久久久 | 人人要人人澡人人爽人人dvd | 久久久久网址 | 狠狠狠色丁香综合久久天下网 | 精品uu | av成人免费观看 | 高清有码中文字幕 | 天天操天天艹 | 欧美性视频网站 | 又爽又黄又刺激的视频 | 国产人成一区二区三区影院 | 亚洲成av人片在线观看香蕉 | 一本一道波多野毛片中文在线 | av成人黄色 | 欧美在线18 | 国产精品久久久久久久久久不蜜月 | 亚洲另类视频 | 天堂av免费在线 | 91精品视屏 | 欧美aⅴ在线观看 | 中文字幕一区二区在线观看 | 成人动漫一区二区 | 国产在线观看,日本 | 中文字幕久久精品一区 | 国产精品免费观看国产网曝瓜 | 国产精品自产拍在线观看蜜 | 99麻豆视频 | 国产精品久久久久久模特 | 一区二区三区在线不卡 | 东方av在线免费观看 | 91免费版在线 | 久久九九久久 | 国产在线观看你懂得 | 欧美日韩国产一区 | 蜜桃传媒一区二区 | 欧美性一级观看 | 国产麻豆视频免费观看 | 国产精品色婷婷视频 | 日本韩国中文字幕 | 国产精品入口a级 | 色网免费观看 | 久99久中文字幕在线 | 手机看片久久 | 91精品色| 久草在线资源网 | 久草在线最新 | 久久国产成人午夜av影院宅 | 欧美aaa一级 | 99精品免费| 中文字幕在线电影 | 亚洲视频www | 在线国产视频 | 欧美国产日韩一区二区 | 91视频 - x99av | 国产亚洲精品久久久久秋 | 国产视频一二三 | 亚洲午夜久久久久久久久电影网 | 久久综合色婷婷 | 婷婷色网视频在线播放 | 人人草人人草 | 久久成人国产精品一区二区 | 丁香电影小说免费视频观看 | 蜜桃视频日本 | 欧美最新大片在线看 | 精品国产伦一区二区三区观看方式 | 免费看成人av | 91成人久久| 国产青草视频在线观看 | 国产日韩视频在线 | 国产麻豆精品久久一二三 | 狠狠狠狠狠狠天天爱 | zzijzzij日本成熟少妇 | 人人爱在线视频 | 日韩在线一区二区免费 | 91精品第一页 | 中文视频在线看 | 国产一区二区精品 | 日韩视频免费观看高清 | 精品国产伦一区二区三区观看方式 | 一区二区三区四区影院 | 婷婷精品国产欧美精品亚洲人人爽 | 草久热 | 中文字幕字幕中文 | 麻豆视频在线播放 | 国产精品2018 | 中文字幕av在线不卡 | 一级片黄色片网站 | 国产精品 日韩 欧美 | 亚洲精品男人天堂 | 夜夜视频 | 国产精品一区二区在线观看 | 久久电影国产免费久久电影 | 久久精品这里精品 | 久久久久综合网 | 亚洲国产欧美一区二区三区丁香婷 | 国产在线观看 | 亚洲成人家庭影院 | 久久精精品视频 | 中文字幕免费 | 国产精品你懂的在线观看 | 日韩av网址在线 | 韩国一区二区三区在线观看 | 久久免费视频播放 | 91九色视频在线播放 | 久久精品人人做人人综合老师 | 91精品一区在线观看 | 亚洲在线色 | 欧美国产日韩一区二区 | 综合网婷婷 | 波多野结衣视频一区 | 亚洲综合在线五月 | 中文字幕文字幕一区二区 | 午夜av在线免费 | 国产亚洲婷婷免费 | 三级av网| 久久久久久久久久久高潮一区二区 | 中文字幕4 | 成年人免费观看国产 | 午夜视频在线观看一区二区 | va视频在线观看 | 国产99久久九九精品免费 | 高清av免费一区中文字幕 | 国产中文字幕在线播放 | 福利视频在线看 | 99久久毛片 | 成人午夜电影网 | 五月天婷婷在线观看视频 | www.看片网站 | 成人禁用看黄a在线 | 青草视频在线免费 | 国产91全国探花系列在线播放 | 欧美日韩国产一区二区三区 | 伊人久在线 | 欧美在线视频二区 | 天天操天天舔天天爽 | 国产午夜三级一区二区三桃花影视 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 中文字幕亚洲欧美日韩2019 | 国内偷拍精品视频 | 91av在线免费播放 | 天天噜天天色 | 国产精品色视频 | 欧美日韩在线视频免费 | 天天操天天操天天 | 久久久久久毛片精品免费不卡 | av在线不卡观看 | 欧美一区二区三区特黄 | 亚洲精品久久久久久久蜜桃 | 97视频免费在线观看 | 99久久99久久精品免费 | 在线观看免费一级片 | 天天色天天操天天爽 | 四虎影视成人永久免费观看亚洲欧美 | 这里只有精品视频在线观看 | 91福利社在线观看 | 亚洲区另类春色综合小说校园片 | 丰满少妇高潮在线观看 | 日韩中文久久 | 丁香久久婷婷 | 亚洲精品高清在线观看 | 人人舔人人爽 | 成人国产精品久久久 | 91精品国自产拍天天拍 | 久久激情精品 | 激情综合婷婷 | 久久久伦理 | 亚洲成人精品久久 | 91在线视频| 免费视频一二三区 | 免费国产黄线在线观看视频 | 天天操天天操天天操天天操天天操天天操 | 国产999精品久久久久久麻豆 | 日韩视频免费观看高清 | 日韩久久久久久久 | 999一区二区三区 | 97超碰在线资源 | 黄色毛片一级 | 欧美日韩亚洲精品在线 | 亚洲在线高清 | 久久艹国产视频 | 成人在线观看影院 | 国产大片黄色 | 久久久久看片 | 国产一区二区不卡在线 | 亚洲年轻女教师毛茸茸 | 99亚洲精品在线 | 久久精品综合一区 | 日韩精品偷拍 | 国产午夜一区 | 国产精品久久久久9999吃药 | 欧美精品亚洲精品日韩精品 | 在线观看不卡的av | 免费大片黄在线 | 激情电影影院 | 激情丁香综合 | 国产1区2 | 国产精品999久久久 久产久精国产品 | 麻豆视频免费播放 | 精品国产乱码一区二区三区在线 | www.狠狠操.com| 免费成人在线网站 | 欧美一区二区日韩一区二区 | 91久久丝袜国产露脸动漫 | 337p西西人体大胆瓣开下部 | 欧美精品天堂 | 国产日韩精品一区二区 | 99精品国产99久久久久久福利 | 午夜精品福利一区二区三区蜜桃 | 91精品国产91热久久久做人人 | 久久久精品视频网站 | 黄色亚洲在线 | 一区二区视频在线观看免费 |