青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

2010年3月1日

[轉(zhuǎn)]利用Winsock模擬HTTP的GET請(qǐng)求

     摘要: 利用Winsock實(shí)現(xiàn)HTTP協(xié)議的GET請(qǐng)求,得到一個(gè)HTML文件信息。  閱讀全文

posted @ 2010-03-01 10:43 小虎無(wú)憂 閱讀(1869) | 評(píng)論 (0)編輯 收藏

2009年11月10日

CRC校驗(yàn)算法

   最近搞一個(gè)協(xié)議,以實(shí)現(xiàn)隱蔽通道,其中需要使用CRC校驗(yàn)算法,由于數(shù)據(jù)位數(shù)比較少,最后決定使用位的CRC校驗(yàn)算法。
  該算法主要就是實(shí)現(xiàn)一個(gè)模二運(yùn)算,基本原理就是異或,移位。
  模二運(yùn)算的算法如下(C語(yǔ)言描述):

模二運(yùn)算

  CrcGetCode函數(shù)獲原始數(shù)據(jù)和CRC生成多項(xiàng)式,利用模二運(yùn)算得到新的數(shù)據(jù)。算法如下:
給數(shù)據(jù)加上校驗(yàn)碼

posted @ 2009-11-10 16:06 小虎無(wú)憂 閱讀(562) | 評(píng)論 (0)編輯 收藏

2009年8月14日

Hook導(dǎo)入表 —— 實(shí)現(xiàn)掛鉤FreeLibaray和HOOK延遲加載模塊的API

     摘要: Windows上Ring3的HOOK導(dǎo)入表所用的類大同小異,本文改進(jìn)了一個(gè)HOOK導(dǎo)入表的類,實(shí)現(xiàn)了HOOK延遲加載模塊的API和FreeLibaray的HOOK的實(shí)現(xiàn)。歡迎大家批評(píng)指正!  閱讀全文

posted @ 2009-08-14 13:36 小虎無(wú)憂 閱讀(1978) | 評(píng)論 (2)編輯 收藏

2009年7月23日

[轉(zhuǎn)]自己寫程序連接視頻并可截取視頻畫面

轉(zhuǎn)載自:http://www.winu.cn/space-14160-do-blog-id-8104.html

  在許多關(guān)于視頻的軟件(如視頻會(huì)議、可視電話等)開(kāi)發(fā)中,都應(yīng)用了視頻捕獲技術(shù)。微軟為軟件開(kāi)發(fā)人員提供了一個(gè)專門用于視頻捕獲的VFW (Video for Windows) SDK。VFW SDK為在Windows系統(tǒng)中實(shí)現(xiàn)視頻捕獲提供了標(biāo)準(zhǔn)的接口,從而大大降低了程序的開(kāi)發(fā)難度。由于VFW SDK只有VC和VB版,沒(méi)有Delphi版,因此需要在Delphi中一一聲明DLL中的各個(gè)函數(shù)和變量(可以參考MSDN中的VC的函數(shù)聲明以及變量定義)。本文分3部分介紹如何利用VFW在Delphi中開(kāi)發(fā)視頻捕獲程序。

VFW簡(jiǎn)介
  VFW是微軟公司1992年推出的關(guān)于數(shù)字視頻的一個(gè)軟件包,它能使應(yīng)用程序通過(guò)數(shù)字化設(shè)備從傳統(tǒng)的模擬視頻源得到數(shù)字化的視頻剪輯。VFW的一個(gè)關(guān)鍵思想是播放時(shí)不需要專用硬件,為了解決數(shù)字視頻數(shù)據(jù)量大的問(wèn)題,需要對(duì)數(shù)據(jù)進(jìn)行壓縮。它引進(jìn)了一種叫AVI的文件標(biāo)準(zhǔn),該標(biāo)準(zhǔn)未規(guī)定如何對(duì)視頻進(jìn)行捕獲、壓縮及播放,僅規(guī)定視頻和音頻該如何存儲(chǔ)在硬盤上,以及在AVI文件中交替存儲(chǔ)視頻幀和與之相匹配的音頻數(shù)據(jù)。VFW使程序員能通過(guò)發(fā)送消息或設(shè)置屬性來(lái)捕獲、播放和編輯視頻剪輯。在Windows 9x系統(tǒng)中,當(dāng)用戶在安裝VFW時(shí),安裝程序會(huì)自動(dòng)地安裝配置視頻所需要的組件,如設(shè)備驅(qū)動(dòng)程序、視頻壓縮程序等。
VFW主要由以下6個(gè)模塊組成:
●AVICAP.DLL:包含執(zhí)行視頻捕獲的函數(shù),它給AVI文件的I/O處理和視頻、音頻設(shè)備驅(qū)動(dòng)程序提供一個(gè)高級(jí)接口;
●MSVIDEO.DLL:包含一套特殊的DrawDib函數(shù),用來(lái)處理屏幕上的視頻操作;
●MCIAVI.DRV:包括對(duì)VFW的MCI命令解釋器的驅(qū)動(dòng)程序;
●AVIFILE.DLL:包含由標(biāo)準(zhǔn)多媒體I/O(mmio)函數(shù)提供的更高的命令,用來(lái)訪問(wèn).AVI文件;
●壓縮管理器(ICM):用于管理的視頻壓縮/解壓縮的編譯碼器(Codec);
●音頻壓縮管理器ACM:提供與ICM相似的服務(wù),適用于波形音頻。
開(kāi)發(fā)步驟
AVICap窗口類支持實(shí)時(shí)的視頻流捕獲和單幀捕獲,并提供對(duì)視頻源的控制。雖然MCI也提供數(shù)字視頻服務(wù)(比如它為顯示.AVI文件的視頻提供了AVI VIDEO命令集),為視頻疊加提供了Overlay命令集,但這些命令主要是基于文件的操作,它們不能滿足實(shí)時(shí)地從視頻緩存中取數(shù)據(jù)的要求, 對(duì)于使用沒(méi)有視頻疊加能力的捕獲卡的PC機(jī)來(lái)說(shuō), 用MCI提供的命令集是無(wú)法捕獲視頻流的。而AVICap窗口類在捕獲視頻方面具有一定的優(yōu)勢(shì),它能直接訪問(wèn)視頻緩沖區(qū),不需要生成中間文件,實(shí)時(shí)性很強(qiáng),效率很高。而且,它還可將數(shù)字視頻捕獲到一個(gè)文件中。
1.創(chuàng)建“捕獲窗”
在進(jìn)行視頻捕獲之前必需要先創(chuàng)建一個(gè)“捕獲窗”,并以它為基礎(chǔ)進(jìn)行所有的捕獲及設(shè)置操作。“捕獲窗”用AVICap窗口類的“CapCreateCaptureWindow”函數(shù)來(lái)創(chuàng)建,其窗口風(fēng)格一般為WS_CHILD和WS_VISIBLE。
捕獲窗類似于標(biāo)準(zhǔn)控件(如按鈕、列表框等),并具有下列功能:
●將視頻流和音頻流捕獲到一個(gè)AVI文件中;
●動(dòng)態(tài)地同視頻和音頻輸入器件連接或斷開(kāi);
●以O(shè)verlay或Preview模式對(duì)輸入的視頻流進(jìn)行實(shí)時(shí)顯示;
●在捕獲時(shí),可指定所用的文件名并能將捕獲文件的內(nèi)容拷貝到另一個(gè)文件;
●設(shè)置捕獲速率;
●顯示控制視頻源、視頻格式、視頻壓縮的對(duì)話框;
●創(chuàng)建、保存或載入調(diào)色板;
●將圖像和相關(guān)的調(diào)色板拷貝到剪貼板;
●將捕獲的單幀圖像保存為DIB格式的文件。
2.關(guān)聯(lián)捕獲窗和驅(qū)動(dòng)程序
單獨(dú)定義的一個(gè)捕獲窗是不能工作的,它必需與一個(gè)設(shè)備相關(guān)聯(lián),這樣才能取得視頻信號(hào)。用函數(shù)CapDriverConnect可使一個(gè)捕獲窗與一個(gè)設(shè)備驅(qū)動(dòng)程序相關(guān)聯(lián)。
3.設(shè)置視頻設(shè)備的屬性
通過(guò)設(shè)置TcaptureParms結(jié)構(gòu)變量的各個(gè)成員變量,可以控制設(shè)備的采樣頻率、中斷采樣按鍵、狀態(tài)行為等等。設(shè)置好TCaptureParms結(jié)構(gòu)變量后,可以用函數(shù)CapCaptureSetSetup使設(shè)置生效。之后還可以用CapPreviewScale、CapPreviewRate來(lái)設(shè)置預(yù)覽的比例與速度,也可以直接使用設(shè)備的默認(rèn)值。
4.打開(kāi)預(yù)覽
利用函數(shù)CapOverlay選擇是否采用疊加模式預(yù)覽,這樣占用系統(tǒng)資源小,并且視頻顯示速度快。然后用CapPreview啟動(dòng)預(yù)覽功能,這時(shí)就可以在屏幕上看到來(lái)自攝像機(jī)的圖像了。
通過(guò)以上4步就可以建立一個(gè)基本的視頻捕獲程序。但如果想自已處理從設(shè)備捕獲到的視頻數(shù)據(jù),則要使用捕獲窗回調(diào)函數(shù)來(lái)處理,比如一幀一幀地獲得視頻數(shù)據(jù)或以流的方式獲得視頻數(shù)據(jù)等等。
實(shí)例編程
下面以一個(gè)一幀一幀地從視頻設(shè)備上捕獲視頻數(shù)據(jù)的Delphi程序?yàn)槔?,?lái)說(shuō)明每個(gè)函數(shù)的作用以及開(kāi)發(fā)過(guò)程。
該程序的功能是可以在屏幕上顯視捕獲到的視頻,并可以獲得每一幀的圖像數(shù)據(jù)。
新建一個(gè)工程,并將AVICAP32.PAS包含到USES中。
在Form1上放置一個(gè)TPanel控件,設(shè)Name為“gCapVideoArea”,該控件用于顯示視頻。再放置兩個(gè)TButton控件,一個(gè)Name為“Openvideo”,另一個(gè)Name為“Closevideo”。
定義全局變量:
var
//定義捕獲窗句柄
ghCapWnd: THandle;
//可以得到視頻數(shù)據(jù)指針的結(jié)構(gòu)變量,用于回調(diào)函數(shù)中
VideoStr: LPVIDEOHDR;
//用于設(shè)置設(shè)備屬性的結(jié)構(gòu)變量
CapParms: TCaptureParms;
在Name為“Openvideo”的TButton 的Click事件中寫入以下代碼:
procedure TForm1.OpenvideoClick(Sender: TObject);
begin
//使用Tpanel控件來(lái)創(chuàng)建捕獲窗口
ghCapWnd := CapCreateCaptureWindow
( PChar(‘KruwoSoft'), //捕獲窗口的名字
WS_CHILD or WS_VISIBLE,//窗口樣式
0, //X坐標(biāo)
0, //Y坐標(biāo)
gCapVideoArea.Width, //窗口寬
gCapVideoArea.Height, //窗口高
gCapVideoArea.Handle, //窗口句柄
0); //一般為0
{為了能夠捕獲視頻幀,要啟動(dòng)一個(gè)捕獲幀回調(diào)函數(shù)VideoStreamCallBack。捕獲一個(gè)視頻流或當(dāng)前設(shè)備狀態(tài)時(shí)分別使用以下函數(shù):
//捕獲一個(gè)視頻流
CapSetCallbackOnVideoStream;
//得到一個(gè)設(shè)備錯(cuò)誤
CapSetCallbackonError;
//得到一個(gè)設(shè)備狀態(tài)
CapSetCallbackOnStatus
}
//定義一個(gè)幀捕獲回調(diào)函數(shù)
CapSetCallbackOnFrame (ghCapWnd,LongInt(@VideoStreamCallBack));
//將一個(gè)捕獲窗口與一個(gè)設(shè)備驅(qū)程相關(guān)聯(lián),第二個(gè)參數(shù)是個(gè)序號(hào),當(dāng)系統(tǒng)中裝有多個(gè)顯視驅(qū)動(dòng)程序時(shí),其值分別依次為0到總個(gè)數(shù)
CapDriverConnect(ghCapWnd, 0);
//設(shè)置設(shè)備屬性的結(jié)構(gòu)變量
CapParms.dwRequestMicroSecPerFrame:=40000;
CapParms.fLimitEnabled := FALSE;
CapParms.fCaptureAudio := FALSE; // NO Audio
CapParms.fMCIControl := FALSE;
CapParms.fYield := TRUE;
CapParms.vKeyAbort := VK_ESCAPE;
CapParms.fAbortLeftMouse := FALSE;
CapParms.fAbortRightMouse := FALSE;
//使設(shè)置生效
CapCaptureSetSetup(ghCapWnd,LongInt(@CapParms),sizeof(TCAPTUREPARMS));
//設(shè)置預(yù)覽時(shí)的比例
CapPreviewScale(ghCapWnd, 1);
//設(shè)置預(yù)覽時(shí)的幀頻率
CapPreviewRate(ghCapWnd,66);
//如果要捕獲視頻流,則要使用函數(shù)指定不生成文件。否則將會(huì)自動(dòng)生成AVI文件
CapCaptureSequenceNoFile(ghCapWnd);
//指定是否使用疊加模式,使用為1,否則為0
CapOverlay(ghCapWnd, 1);
//打開(kāi)預(yù)覽
CapPreview(ghCapWnd, 1);
end;
在Name為“Closevideo”的TButton 的Click事件中寫入以下代碼:
procedure TForm1.ClosevideoClick(Sender: TObject);
begin
//停止捕獲
capCaptureAbort(ghCapWnd);
//將捕獲窗同驅(qū)動(dòng)器斷開(kāi)
capDriverDisconnect(ghCapWnd);
end;
定義捕獲幀回調(diào)函數(shù):
function FrameCallBack(hWnd:HWND; lpVHdr:LongInt) :LongInt; stdcall;
var
DataPoint:^byte;
DibLen,RectWidth,RectHeight:integer;
begin
//轉(zhuǎn)換從回調(diào)函數(shù)中得到的指針
VideoStr:=LPVIDEOHDR(lpVHdr);
//得到返回的數(shù)據(jù)大小
DibLen:=VideoStr^.dwBufferLength;
GetMem(DataPoint,64000);
//將幀數(shù)據(jù)COPY到一個(gè)內(nèi)存中,注意DATAPOINT要先分配空間
CopyMemory(DataPoint,VideoStr^.lpData,Diblen);
//一些其他處理
……
end;
靈活地使用AVICap窗口類的回調(diào)函數(shù)可以滿足各種不同的需求,但要注意從視頻卡中捕獲的視頻數(shù)據(jù)的格式和圖像的長(zhǎng)寬要參考視頻卡的參數(shù)。而且有些視頻卡通過(guò)設(shè)置可支持多種的格式和圖像長(zhǎng)寬,所以在還原圖像時(shí)要注意參考所用的視頻卡的參數(shù)。

posted @ 2009-07-23 11:26 小虎無(wú)憂 閱讀(707) | 評(píng)論 (0)編輯 收藏

2009年6月13日

《Windows via C/C++》中示例程序DIPS的問(wèn)題

  前一階段重溫了Windows中的HOOK,由此參考了《Windows via C/C++》中的示例程序——DIPS,但是我發(fā)現(xiàn)了一個(gè)有趣的問(wèn)題。
  默認(rèn)情況下,鏈接器并不會(huì)將支持XP或Vista的manifest鏈接到程序上,因此,生成的應(yīng)用程序運(yùn)行時(shí)的控件風(fēng)格是經(jīng)典Windows樣式,此時(shí),DIPS小工具運(yùn)行正常。
  但是,當(dāng)加上如下這段代碼(適用于x86 CPU),問(wèn)題就產(chǎn)生了。
#pragma comment(linker, "/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='x86' publicKeyToken='6595b64144ccf1df' language='*'\"")
  這意味著鏈接器將會(huì)把新的XP或Vista的manifest鏈接到程序上,使應(yīng)用程序具有XP或Vista的控件樣式。這時(shí),問(wèn)題產(chǎn)生了。
  這里我貼出程序的主函數(shù)代碼:
int WINAPI _tWinMain(HINSTANCE hInstExe, HINSTANCE, PTSTR pszCmdLine, int{

   
// Convert command-line character to uppercase.
   CharUpperBuff(pszCmdLine, 1);
   TCHAR cWhatToDo 
= pszCmdLine[0];

   
if ((cWhatToDo != TEXT('S')) && (cWhatToDo != TEXT('R'))) {

      
// An invalid command-line argument; prompt the user.
      cWhatToDo = 0;
   }


   
if (cWhatToDo == 0{
      
// No command-line argument was used to tell us what to
      
// do; show usage dialog box and prompt the user.
      switch (DialogBox(hInstExe, MAKEINTRESOURCE(IDD_DIPS), NULL, Dlg_Proc)) {
         
case IDC_SAVE:    
            cWhatToDo 
= TEXT('S'); 
            
break;

         
case IDC_RESTORE: 
            cWhatToDo 
= TEXT('R');
            
break;
      }

   }


   
if (cWhatToDo == 0{
      
// The user doesn't want to do anything.
      return(0);
   }

   
   
// The Desktop ListView window is the grandchild of the ProgMan window.
   HWND hWndLV = GetFirstChild(GetFirstChild(
      FindWindow(TEXT(
"ProgMan"), NULL)));
   chASSERT(IsWindow(hWndLV));

   
// Set hook that injects our DLL into the Explorer's address space. After 
   
// setting the hook, the DIPS hidden modeless dialog box is created. We 
   
// send messages to this window to tell it what we want it to do.
   chVERIFY(SetDIPSHook(GetWindowThreadProcessId(hWndLV, NULL)));

   
// Wait for the DIPS server window to be created.
   MSG msg;
   GetMessage(
&msg, NULL, 00);      // 請(qǐng)注意這里

   
// Find the handle of the hidden dialog box window.
   HWND hWndDIPS = FindWindow(NULL, TEXT("Wintellect DIPS"));

   
// Make sure that the window was created.
   chASSERT(IsWindow(hWndDIPS));

   
// Tell the DIPS window which ListView window to manipulate
   
// and whether the items should be saved or restored.
   BOOL bSave = (cWhatToDo == TEXT('S'));
   SendMessage(hWndDIPS, WM_APP, (WPARAM) hWndLV, bSave);

   
// Tell the DIPS window to destroy itself. Use SendMessage 
   
// instead of PostMessage so that we know the window is 
   
// destroyed before the hook is removed.
   SendMessage(hWndDIPS, WM_CLOSE, 00);

   
// Make sure that the window was destroyed.
   chASSERT(!IsWindow(hWndDIPS));

   
// Unhook the DLL, removing the DIPS dialog box procedure 
   
// from the Explorer's address space.
   SetDIPSHook(0);  

   
return(0);
}

  看到上面代碼中的GetMessage函數(shù)(加紅色注釋那行),該函數(shù)是在接收一個(gè)來(lái)自explorer.exe進(jìn)程的消息,這個(gè)消息是在掛鉤DLL注入之后,由掛鉤過(guò)濾函數(shù)發(fā)送的。掛鉤過(guò)濾函數(shù)代碼如下:
LRESULT WINAPI GetMsgProc(int nCode, WPARAM wParam, LPARAM lParam) {

   
static BOOL bFirstTime = TRUE;

   
if (bFirstTime) {
      
// The DLL just got injected.
      bFirstTime = FALSE;

      
// Uncomment the line below to invoke the debugger 
      
// on the process that just got the injected DLL.
      
// ForceDebugBreak();

      
// Create the DIPS Server window to handle the client request.
      CreateDialog(g_hInstDll, MAKEINTRESOURCE(IDD_DIPS), NULL, Dlg_Proc);

      
// Tell the DIPS application that the server is up 
      
// and ready to handle requests.
      PostThreadMessage(g_dwThreadIdDIPS, WM_NULL, 00);
   }


   
return(CallNextHookEx(g_hHook, nCode, wParam, lParam));
}

  明顯地,這里發(fā)送了一個(gè)WM_NULL消息給DIPS進(jìn)程,當(dāng)使用經(jīng)典樣式的控件時(shí)一切安好,經(jīng)調(diào)試得到的MSG結(jié)構(gòu)中的各個(gè)字段為正確的值。但是加上了上面那行鏈接命令后,調(diào)試得到的MSG結(jié)構(gòu)的字段壓根就不是WM_NULL、0、0,而是一個(gè)數(shù)值為49211的消息,這樣導(dǎo)致了DIPS主線程喚醒,隨后的FindWindow可能會(huì)返回一個(gè)NULL,因?yàn)樵撓⒉⒉皇菕煦^過(guò)濾函數(shù)的發(fā)送的消息。當(dāng)然,如果在這里Sleep一下,可以得到正確的窗口句柄,我在GetMessage函數(shù)上加了一個(gè)do-while循環(huán),結(jié)果也的確是這樣,幾次循環(huán)之后可以收到消息為WM_NULL的消息,且參數(shù)均為0。
  但是我不明白為什么加上了一條鏈接命令會(huì)這樣?不妨大家都試試看,我用的IDE是VS2005。
  哪位高手可以來(lái)指導(dǎo)我一下呢?

posted @ 2009-06-13 13:37 小虎無(wú)憂 閱讀(1818) | 評(píng)論 (3)編輯 收藏

2009年5月22日

關(guān)于DLL中DllMain的線程死鎖問(wèn)題

  前一階段閑著無(wú)聊,用遠(yuǎn)程線程注入的方法把DLL注入到Explorer.exe進(jìn)程實(shí)現(xiàn)音樂(lè)循環(huán)播放。

  在DLL中的代碼是這樣的:

BOOL WINAPI DllMain(HINSTANCE hInstDll, DWORD fdwReason, PVOID fImpLoad)
{
   
static HANDLE hThread;
    
static DWORD dwThreadId;
    
switch (fdwReason)
    {
    
case DLL_PROCESS_ATTACH:
        g_hInstDll 
= hInstDll;
        hThread 
= BEGINTHREADEX(NULL, 0, ThreadProc, (PVOID)hInstDll, 0&dwThreadId);
        
if (hThread == NULL)
        {
            
return FALSE;
        }
        
break;

    
case DLL_PROCESS_DETACH:
        SendMessage(g_hWnd, WM_CLOSE, 
00);
        WaitForSingleObject(hThread, INFINITE);    
// 這里存在死循環(huán)

        CloseHandle(hThread);    
// 執(zhí)行不到這里
        break;

    
case DLL_THREAD_ATTACH:
        
break;

    
case DLL_THREAD_DETACH:
        
break;

    
default:
        
break;
    }
    
return TRUE;
}

  在DLL_PROCESS_ATTACH的時(shí)候創(chuàng)建了一個(gè)線程,這個(gè)線程中創(chuàng)建了一個(gè)隱藏的窗口,并利用MCI實(shí)現(xiàn)播放音樂(lè),具體就不貼出了。然后在DLL_PROCESS_DETACH中停止和關(guān)閉設(shè)備。

  但是在應(yīng)用程序中,發(fā)現(xiàn)注入時(shí)無(wú)異常,在需要撤銷DLL映射時(shí)出現(xiàn)了問(wèn)題,程序出現(xiàn)了死循環(huán),在等待遠(yuǎn)程線程執(zhí)行FreeLibaray完畢時(shí)不返回了。

  注意上面代碼中DLL_PROCESS_DETACH的代碼,SendMessage用來(lái)關(guān)閉窗口,窗口會(huì)在WM_DESTROY通知下調(diào)用PostQuitMessage(0)使得線程的消息循環(huán)退出,從而線程退出。但是WaitForSingleObject函數(shù)無(wú)法返回。

  后來(lái)發(fā)現(xiàn)這里存在死循環(huán),因?yàn)閳?zhí)行DllMain的線程是序列化的,必須等待一個(gè)線程執(zhí)行完畢之后另一個(gè)線程才能執(zhí)行。在SendMessage后,導(dǎo)致創(chuàng)建的線程即將退出,這時(shí)該線程會(huì)調(diào)用DllMain,并以DLL_THREAD_DETACH作為通知。可是調(diào)用SendMessage的線程調(diào)用DllMain時(shí)卻還在等待即將退出的線程結(jié)束,DllMain還沒(méi)有返回,因此存在了死循環(huán)。

  因此,在DllMain中不適合調(diào)用WaitForSingleObject等函數(shù)來(lái)等待線程完畢。

posted @ 2009-05-22 22:22 小虎無(wú)憂 閱讀(1747) | 評(píng)論 (0)編輯 收藏

終于在C++博客安家啦

  以前都是在博客園的,發(fā)現(xiàn)博客園關(guān)注的是.Net技術(shù),感覺(jué)和自己的興趣與特長(zhǎng)關(guān)系不大,因此申請(qǐng)了C++博客。
  原博客園博客地址:http://www.cnblogs.com/wz19860913/

posted @ 2009-05-22 22:15 小虎無(wú)憂 閱讀(161) | 評(píng)論 (0)編輯 收藏

僅列出標(biāo)題  
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

留言簿

隨筆分類

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美精品999| 久久精品成人一区二区三区蜜臀 | 欧美一区二区视频观看视频| 一区二区三区四区国产| 99视频精品全部免费在线| 亚洲精品色图| 在线一区二区三区四区五区| 一区二区三区高清在线观看| 中文亚洲欧美| 欧美在线视频一区二区| 欧美在线视频全部完| 久久亚洲国产精品一区二区| 欧美激情视频在线播放| 欧美日韩第一页| 国产精品高清一区二区三区| 欧美激情在线观看| 欧美日韩精品免费观看视一区二区 | 午夜精品福利视频| 蜜桃av综合| 亚洲欧洲av一区二区| 亚洲麻豆国产自偷在线| 激情综合网激情| 国产精品日本一区二区| 欧美日韩精品综合| 免费人成精品欧美精品| 久久精品视频免费播放| 欧美一区视频| 久久久久国色av免费观看性色| 国产精品日韩一区二区| 欧美精品18| 亚洲精品乱码久久久久久| 亚洲最黄网站| 亚洲精品自在在线观看| 久久成人精品| 欧美精品v国产精品v日韩精品| 欧美一区日韩一区| 亚洲一区二区黄色| 在线亚洲高清视频| 一本色道精品久久一区二区三区| 亚洲国产精品一区| 欧美成人自拍| 亚洲国产精品一区二区www| 六月婷婷久久| 欧美77777| 欧美成人精品在线| 亚洲第一中文字幕| 亚洲国产mv| 日韩一区二区高清| 一区二区三区四区蜜桃| 久久精品日产第一区二区| 国产一区二区三区黄| 免费成人网www| 一本色道久久88亚洲综合88| 欧美国产视频日韩| 亚洲精品美女在线观看| 国产精品国产精品| 久久久午夜视频| 亚洲精品看片| 欧美成人高清| 免费h精品视频在线播放| 久久国产精品99久久久久久老狼| 亚洲伦理在线免费看| 欧美日韩一卡| 另类亚洲自拍| 久久精品欧洲| 久久精品在线播放| 校园春色综合网| 99日韩精品| 亚洲国产成人在线| 免费在线播放第一区高清av| 一本一本a久久| 亚洲视频导航| 亚洲国产免费看| 国产农村妇女精品| 国产香蕉97碰碰久久人人| 欧美日韩中文在线观看| 噜噜噜在线观看免费视频日韩| 另类专区欧美制服同性| 欧美在线日韩在线| 午夜亚洲影视| 中日韩高清电影网| 国产精品一区二区久久精品| 亚洲风情亚aⅴ在线发布| 亚洲图片激情小说| 免费成人美女女| 一区二区精品在线| 久久男人资源视频| 国内精品福利| 亚洲国产三级| 亚洲欧美视频| 亚洲成人中文| 久久久久久色| 国产欧美日韩综合一区在线播放| 亚洲第一网站| 免费成人在线观看视频| 亚洲在线视频| 国产精品久久77777| 在线视频亚洲| 亚洲国产成人91精品 | 亚洲欧美日韩在线不卡| 久久久综合激的五月天| 一区二区激情视频| 欧美手机在线| 这里只有精品电影| 亚洲电影在线| 久久午夜精品一区二区| 国产亚洲精品成人av久久ww| 午夜精品久久久久久久白皮肤| 日韩一区二区免费看| 欧美激情va永久在线播放| 极品日韩久久| 久久午夜羞羞影院免费观看| 久久中文字幕一区二区三区| 午夜激情一区| 久久九九精品99国产精品| 亚洲欧洲另类国产综合| 久久国产综合精品| 久久久综合激的五月天| 亚洲国产精品高清久久久| 免费欧美高清视频| 久久aⅴ国产紧身牛仔裤| 一区二区三区四区蜜桃| 国产精品区一区二区三区| 亚洲欧美日韩视频一区| 亚洲欧美成人网| 国产主播在线一区| 免费在线成人av| 欧美激情中文字幕一区二区| 夜夜躁日日躁狠狠久久88av| 性18欧美另类| 中国日韩欧美久久久久久久久| 久久久国产一区二区三区| 亚洲国产精品黑人久久久| 亚洲精品在线观看免费| 国产精品欧美日韩| 久久精品青青大伊人av| 欧美www在线| 亚洲尤物视频网| 欧美在线观看网址综合| 亚洲激情在线观看| 亚洲天堂黄色| 韩国女主播一区二区三区| 91久久久久久久久久久久久| 国产精品极品美女粉嫩高清在线 | 久久黄色级2电影| 欧美影视一区| 91久久国产综合久久91精品网站| 亚洲国产精品va在线看黑人动漫| 欧美日韩一区国产| 亚洲精品免费在线播放| 国产日韩欧美a| 亚洲黄页一区| 国产亚洲精品久久久久久| 亚洲国产精品尤物yw在线观看 | 欧美二区不卡| 1000部精品久久久久久久久| 亚洲电影免费观看高清| 欧美精品999| 国产一区二区成人久久免费影院| 亚洲午夜国产一区99re久久| 午夜亚洲激情| 激情综合色综合久久| 久久久xxx| 欧美日韩裸体免费视频| 99成人在线| 午夜亚洲一区| 欧美成人激情视频| 久久免费偷拍视频| 久久久久久久综合日本| 亚洲制服少妇| 欧美大片91| 欧美激情精品久久久久久黑人| 亚洲精品社区| 久久九九热免费视频| 久久都是精品| 国产精品v欧美精品v日韩 | 另类综合日韩欧美亚洲| 久久精品盗摄| 国产日韩欧美不卡在线| 久久成人亚洲| 久久久视频精品| 一区电影在线观看| 欧美伊人久久| 国产在线精品一区二区夜色| 91久久久一线二线三线品牌| 欧美麻豆久久久久久中文| 欧美一区二区三区男人的天堂| 91久久久一线二线三线品牌| 亚洲麻豆一区| 欧美日韩高清在线| 亚洲激情视频网| 亚洲美女尤物影院| 欧美成人久久| 亚洲免费观看在线观看| 亚洲美女91| 欧美日韩一区二区欧美激情| 日韩午夜激情| 欧美一区二区视频97| 好吊色欧美一区二区三区视频| 午夜精品久久久久影视|