主頁 > 前端設計 > 傀儡行程學習

傀儡行程學習

2020-10-07 21:48:29 前端設計

0x00 前言

最近做了一道18年swpuctf的題,分析了一個病毒,正巧都用到了傀儡行程,就想著把傀儡行程學習一下,本文權當個人的學習總結了一些網上的文章,如有錯誤,還請路過的大佬斧正,

0x01 SWPUCTF -- GAME

進入main函式

先獲取當前目錄,再拼上GAME.EXE

進入sub_4011D0

首先尋找資源,做準備作業,進入sub_4012C0

1)檢測PE結構

2) CreateProcessA 創建行程

3)GetThreadContext 得到行程背景關系資訊,用于下文計算基地址

4)sub_4016F0

到ntdll.dll里找到NtUnmapViewOfSection函式

5)VirtualAllocEx 跨行程,在目標行程申請空間

6)寫入檔案

7)SetThreadContext 恢復現場

8) 運行傀儡行程

我們來找找注入的程式

把GAME.EXE載入到010editor里,搜索"MZ"

dump出來,就是剛剛注入到傀儡行程的程式了,

我們把它命名為 game2.exe

載到IDA里分析

發現是D3D繪制

之后的解題與本文關系不大,這里直接把官方的WP搬運來了https://www.anquanke.com/post/id/168338#h3-16

通過字串[Enter]可以跟蹤到獲取輸入以及回傳上一層的地

這里用了’ – ’符來分割string,然后保存到vector中,并且判斷vector中string的個數是否是4以及每一個string的長度是否是4

接著傳入前面兩部分進行一次加密,可以根據常量識別出這是DES演算法,這里把DES的subkeys進行了一次移位,并且修改了sbox3開頭的5個位元組,然后把結尾結果減去0x10,之后再進行一個簡單的方程check,解方程可以得到另外兩部分是個常量,

DES部分可以網上找個標準的DES把這幾部分改一下就能解出FLAG:HOPE-UCAN-GOOD-GAME

小結

本題的sub_4012C0,就是在進行傀儡行程的撰寫,有必要仔細的說說傀儡行程

0x02 傀儡行程

文章: https://blog.csdn.net/darcy_123/article/details/102532411

首先使用CreateProcess傳入CREATE_SUSPENDED

創建一個掛起的行程,以下稱為傀儡行程,然后使用GetThreadContext讀取傀儡行程的背景關系資訊,通過DWORD

指標指向CONTEXT的EBX,DWORD + 8 位元組可以讀取到傀儡行程的基地址,然后計算傀儡行程的鏡像大小

然后把自己的資料讀入到傀儡行程內,設定CONTEXT背景關系入口點資訊EAX,并恢復行程主執行緒

上文已經寫得很詳細了,個人覺得重要的點

1)在CreateProcess時,注意環境問題 lpCurrentDirectory

BOOL CreateProcessA(
  LPCSTR                lpApplicationName,
  LPSTR                 lpCommandLine,
  LPSECURITY_ATTRIBUTES lpProcessAttributes,
  LPSECURITY_ATTRIBUTES lpThreadAttributes,
  BOOL                  bInheritHandles,
  DWORD                 dwCreationFlags,
  LPVOID                lpEnvironment,
  LPCSTR                lpCurrentDirectory,
  LPSTARTUPINFOA        lpStartupInfo,
  LPPROCESS_INFORMATION lpProcessInformation
);

2) 計算基地址

context.Ebx + 8 = 基地址,因此從context.Ebx + 8的地址讀取4位元組的內容并轉化為DWORD型別,即是行程加載的基地址,

3) VirtualAllocEx時的權限問題

4)VirtualAllocEx重定位的問題

一般情況下,在寫入傀儡行程對應的檔案按照申請空間的首地址作為基地址進行“重定位”,這樣才能保證傀儡行程的正常運行,為了避免這一步操作,可以以傀儡行程PE檔案頭部的建議加載基地址作為VirtualAllocEx的lpAddress引數,申請與之對應的記憶體空間,然后以此地址作為基地址將傀儡行程寫入目標程式,就不會存在重定位問題,關于“重定位”的原理可以自行網路查找相關資料

我們來看看實際上病毒用到的傀儡行程

0x03 病毒分析

1.virusTotal

https://www.virustotal.com/gui/file/32db88982a0d0f92804c4c53ffd8555935871e23b35a9d362e037353cb6b44c5/details

MD5 ba46b18f05ab2b24df26e343dd32946b
SHA-1 34f07e131d4f147af96d262eee761582c6f0b1a4
SHA-256 32db88982a0d0f92804c4c53ffd8555935871e23b35a9d362e037353cb6b44c5
Vhash bf09954b6ff12217cd0df0f93c7488e4
SSDEEP 24576:yij8jlUoiuFhypnWmUOJ4H0zMY/lspoBbRzRrT9MUF5jawb:yDhUoMFUcvo6FlrT2wb
File type RAR
Magic RAR archive data, v1d, os: Win32
File size 893.13 KB (914570 bytes)

環境win7 x64

是一個.rar檔案

在虛擬機里改后綴為.rar

解壓:

可以簡單的發現一個偽裝成檔案夾的.exe

2.對18XXXXXXXXXXXX.exe分析

查殼

沒有

然后GUI,有界面的程式

用LoadPE去看一下區段,資源等資訊

看一下重定位

和資源

關注一下匯入表

    0x0311       "WriteFile"
    0x0038       "CreateFileA"
    0x005F       "DeleteFileA"
    0x0240       "ReadFile"
    0x0128       "GetFileSize"
    0x020D       "OpenFile"
    0x0298       "SetFilePointer"
    0x0048       "CreateProcessA
    0x002B       "CopyFileA"
    0x00CC       "GetACP"

可能會新建新的檔案

IDA詳細分析

先搜字串

pavfnsvr.exe

sfctlcom.exe

后來看別人的分析,這兩個檔案是安全程式

IDA開始分析

開始時,一些準備作業,之后檢測版本號

申請堆,

釋放后,把申請的堆的句柄,放到40E968的位置

呼叫4057AE

檢測檔案的PE結構

主要是檢測PE結構,然后驗證目錄項要比14項多

之后回到start函式 sub_40624F

檢測的就是下圖紅框圈出來的那兩個

之后:

與SEH的高級使用有關

通過GetCommandLineA獲取當前檔案的路徑

"C:\Users\Administrator\Desktop\bingdu\1\bingdu\1\18xxxxxxxxxxxxxxxxxxxxxxxxxxxxx.EXE" 的地址存到了410268(00271F50)

sub_408D2C函式獲取環境資訊

獲取"ALLUSERSPROFILE=C:\ProgramData",

在將寬字符轉成多位元組

之后進入

V13為0x271fa6 ..(\洳..C.:.\.W.i.n.d.o.w.s.\.s.y.s.t.e.m.3.2.;的指標

V6為10

進入函式:

首先會獲取當前行程已加載模塊的檔案的完整路徑

然后加載到緩沖區

把當前的目錄傳入402120

進入402120

會呼叫兩次401450

看一下401450

rep stosd:

在網上查了相關資料顯示:

/************************************************************/

lea edi,[ebp-0C0h]

mov ecx,30h

mov eax,0CCCCCCCCh

rep stos dword ptr es:[edi]

rep指令的目的是重復其上面的指令.ECX的值是重復的次數.

STOS指令的作用是將eax中的值拷貝到ES:EDI指向的地址.

首先獲取當前的路徑

打開檔案讀取

獲取windows的目錄

在源目錄生成.bak檔案

生成檔案夾

把檔案備份到"C:\Windows\Help\18xxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bak"

在把原來的.bak洗掉

進入402680

首先找到生成的空檔案夾

在記憶體里讀取檔案 1.jpg

將1.jpg和.archd作為引數進入4046A0

拼出路徑

將j.jpg換成1.liz

按照路徑寫入檔案,再將1.liz換成1.jpg

回圈7次生成7張圖片

第8次,生成Thumbs.db檔案

之后把C:/Windows/Help里的備份洗掉

進入第二個401450

先找到程式獲取臨時目錄檔案路徑

然后拼出路徑

"C:\Users\ADMINI~1\AppData\Local\Temp\\rat.EXE"

如果存在直接打開,不存在就創建

之后createprocess

創建行程,運行rat.EXE

先拼出來byeyou.tmp的路徑

之后 遍歷所有行程,保證沒有sftlcom.exe與pavfnsur.exe

把原檔案(18XXXX.EXE)移動到byeyou.tmp

分析 rat.exe

沒有殼

自啟動(嫖的圖)

注冊表相關(嫖的圖)

去找ctfmon.exe的目錄

拼路徑 將rat.exe copy成ctfmon.exe

之后尋找資源

拼出"C:\Windows\system32\alg.exe"

作為引數扔到sub_4016D0運行

進入傀儡行程函式

創建掛起行程 && 保存現場,收集資訊

之后像上述ctf一樣找到注入到傀儡行程的.exe

Dump出來起名為abc.def

分析 abc.def

看一下字串

進入WinMain函式

首先進入sub_405BD0

先解密字串從advapt32.dl,呼叫需要的函式

提權

之后進入 sub_401720解密接下來需要的字串

回到WinMain

從KERNEL32.DLL找需要的函式

之后進入sub_405960

進入遠控函式

首先登入一個網站

保存回傳的資料

之后就沒辦法動調了

把回傳的資料按照自己定義的字符切割

進入405DB0函式,依舊是解密

接著分配套介面,連上

進入403190

開始從.Dll里提取需要的函式

1.

2.

3.

4.

5&6

之后傳入域名引數

獲得本機的ip

能不能ping得通

檢測系統版本

CPU資訊

作業系統版本

獲取磁盤資訊

對檔案操作

創建,讀

洗掉,重命名

移動

復制

列出行程 &&殺死行程

卸載

關機重啟

截屏

接著還會在傳入其他的兩個域名

cn.fetftp.nu "rt.softseek.org"

進入403190控制函式

0x04 代碼實作

https://blog.csdn.net/superchickenchicken/article/details/102552787?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-6.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-6.nonecase

稍微修改了點去做別的用了

#include<stdio.h>
#include<windows.h>
#include<winbase.h>
struct _PROCESS_INFORMATION ProcessInfomation;


int main()
{
	LPVOID pAlloc1;
	LPVOID pAlloc2;
	HANDLE hfile;
	PIMAGE_NT_HEADERS pPeHeader;
	PIMAGE_SECTION_HEADER pSectionHeader;
	int lastError, ReadInfo = 0;
	DWORD BytesRead = 0;
	CONTEXT Context = { 0 };
	Context.ContextFlags = CONTEXT_ALL;
	char lpName[260];
	//準備路徑
	char Patch[] = "C:\\play.exe";//注入傀儡行程的.exe的路徑
	LPCSTR p = (const char*)Patch;
	//轉移檔案


	//以掛起的方式創建傀儡行程,并獲取行程基址
	STARTUPINFOA StartupInfo = { 0 };
	PROCESS_INFORMATION ProcessInfomation = { 0 };
	StartupInfo.cb = sizeof(StartupInfo);

	GetModuleFileName(0, lpName, 520);
	if (!CreateProcess(lpName, NULL, 0, 0, 0, CREATE_SUSPENDED, 0, 0, &StartupInfo, &ProcessInfomation)),
	{
		lastError = GetLastError();
		printf("CreateProcess fail  LastError:%d\n", lastError);
	};

	if (!GetThreadContext(ProcessInfomation.hThread, &Context))
	{
		lastError = GetLastError();
		printf("GetThreadContext fail LastError:%d\n", lastError);
	};

	if (!ReadProcessMemory(ProcessInfomation.hProcess, (LPCVOID)(Context.Ebx + 0x8), &ReadInfo, 4, 0))
	{
		lastError = GetLastError();
		printf("GetProcessImageBase fail LastError:%d\n", lastError);
		//printf("%d\n", dwIO);
	};
	printf("ProcessImageBase:address 0x%x\n", ReadInfo);

	
	// 把準備注入到傀儡行程的程式讀進記憶體
	hfile = CreateFileA(p, GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, 0, 0);
	//lastError = GetLastError();
	//printf("%d\n", lastError);

	pAlloc1 = VirtualAlloc(NULL, 0x70000, 0x3000, 4);//sucessful
	//printf("%d", pAlloc1);
	ReadFile(hfile, pAlloc1, 0x70000, &BytesRead, 0);

	pPeHeader = (PIMAGE_NT_HEADERS)((PBYTE)pAlloc1 + ((PIMAGE_DOS_HEADER)pAlloc1)->e_lfanew);//sucessful
	//printf("%d", pPeHeader);
	pSectionHeader = (IMAGE_SECTION_HEADER*)((char*)&pPeHeader->OptionalHeader + pPeHeader->FileHeader.SizeOfOptionalHeader);//sucessful
	//printf("%d", pSectionHeader);
	//向傀儡行程申請記憶體空間
	SetLastError(0);
	pAlloc2 = VirtualAllocEx(ProcessInfomation.hProcess, (LPVOID)pPeHeader->OptionalHeader.ImageBase, pPeHeader->OptionalHeader.SizeOfImage, MEM_COMMIT | MEM_RESERVE, 64);
	//printf("%d\n", pAlloc2);
	if (!pAlloc2)
	{
		lastError = GetLastError();
		printf("VirtualAllocEx fail LastError:%d\n", lastError);
		TerminateProcess(ProcessInfomation.hProcess, 0);
		return 0;

	}
	printf("AllocExBase: %x\n", pAlloc2);

	//寫入PE頭
	if (WriteProcessMemory(ProcessInfomation.hProcess, pAlloc2, pAlloc1, pPeHeader->OptionalHeader.SizeOfHeaders, 0))
	{
		printf("write PeHeader Success !\n");
	}


	//寫入節表,分節表寫入會使得程式展開在行程中
	int NumofSection = pPeHeader->FileHeader.NumberOfSections;
	for (int i = 0;i < NumofSection;i++)
	{
		LPVOID pAllocRawAddressSection = (char*)pAlloc1 + pSectionHeader->PointerToRawData;
		LPVOID pAllocVirtualAddressSection = (char*)pPeHeader->OptionalHeader.ImageBase + pSectionHeader->VirtualAddress;
		if (WriteProcessMemory(ProcessInfomation.hProcess, pAllocVirtualAddressSection, pAllocRawAddressSection, pSectionHeader->SizeOfRawData, 0))
		{
			printf("write the %d section success !\n", i + 1);
		}
		else
		{
			lastError = GetLastError();
			printf("write the %d section fail ! lastError:%d\n", i + 1, lastError);
		}
		pSectionHeader++;
	}

	//設定傀儡行程的行程基址0x400000
	if (WriteProcessMemory(ProcessInfomation.hProcess, (char*)Context.Ebx + 8, &pPeHeader->OptionalHeader.ImageBase, 4, 0))
	{
		printf("set Process ImageBase is 0x400000  success !\n");
	}

	//設定傀儡行程的行程OEP 為注入程式的OEP
	Context.Eax = pPeHeader->OptionalHeader.ImageBase + pPeHeader->OptionalHeader.AddressOfEntryPoint;//設定入口點地址 一定別忘了加基址

	if (SetThreadContext(ProcessInfomation.hThread, &Context))
	{
		printf("set Thread Context success !\n");
	}

	//恢復執行緒運行

	if (ResumeThread(ProcessInfomation.hThread) != (DWORD)-1)
	{
		lastError = GetLastError();
		printf("Resume Thread success ! \n");
	}


	system("pause");
	return 0;
}

0x04總結

emmmm不知道說啥,溜了

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/161911.html

標籤:其他

上一篇:做一個電商網站我們應該注意哪些問題?

下一篇:面試官怒噴:“你怎么并發編程都不會?”

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more