新聞中心
隨著互聯(lián)網(wǎng)技術(shù)的飛速發(fā)展,網(wǎng)絡(luò)安全問(wèn)題越來(lái)越受到大眾關(guān)注。作為相較于傳統(tǒng)的Windows系統(tǒng)更加安全的操作系統(tǒng),Linux也不例外,它也會(huì)遭受各種各樣的攻擊。其中,系統(tǒng)調(diào)用劫持就是一種比較嚴(yán)重的攻擊手段,本文將著重對(duì)此進(jìn)行講解,并提供相應(yīng)的解決方法。

成都一家集口碑和實(shí)力的網(wǎng)站建設(shè)服務(wù)商,擁有專業(yè)的企業(yè)建站團(tuán)隊(duì)和靠譜的建站技術(shù),10多年企業(yè)及個(gè)人網(wǎng)站建設(shè)經(jīng)驗(yàn) ,為成都1000+客戶提供網(wǎng)頁(yè)設(shè)計(jì)制作,網(wǎng)站開(kāi)發(fā),企業(yè)網(wǎng)站制作建設(shè)等服務(wù),包括成都營(yíng)銷型網(wǎng)站建設(shè),品牌網(wǎng)站制作,同時(shí)也為不同行業(yè)的客戶提供做網(wǎng)站、網(wǎng)站建設(shè)的服務(wù),包括成都電商型網(wǎng)站制作建設(shè),裝修行業(yè)網(wǎng)站制作建設(shè),傳統(tǒng)機(jī)械行業(yè)網(wǎng)站建設(shè),傳統(tǒng)農(nóng)業(yè)行業(yè)網(wǎng)站制作建設(shè)。在成都做網(wǎng)站,選網(wǎng)站制作建設(shè)服務(wù)商就選成都創(chuàng)新互聯(lián)。
一、系統(tǒng)調(diào)用劫持的定義和危害
系統(tǒng)調(diào)用是Linux內(nèi)核提供的一種接口,它連接了用戶態(tài)和內(nèi)核態(tài)的橋梁,使得用戶態(tài)應(yīng)用程序能夠調(diào)用內(nèi)核提供的各種功能。在Linux中,每個(gè)系統(tǒng)調(diào)用都有一個(gè)唯一的函數(shù)名和一個(gè)特定的系統(tǒng)調(diào)用號(hào)。攻擊者可以通過(guò)篡改系統(tǒng)調(diào)用號(hào),將要調(diào)用的系統(tǒng)調(diào)用劫持到自己編寫(xiě)的惡意代碼上,從而控制系統(tǒng)獲取高權(quán)限。
系統(tǒng)調(diào)用劫持的危害主要包括以下幾個(gè)方面:
1.獲取系統(tǒng)高權(quán)限:通過(guò)劫持系統(tǒng)調(diào)用,惡意代碼可以獲取系統(tǒng)高權(quán)限,使得攻擊者可以完全掌控系統(tǒng),對(duì)系統(tǒng)進(jìn)行各種惡意操作。
2.數(shù)據(jù)篡改:通過(guò)劫持系統(tǒng)調(diào)用,攻擊者可以對(duì)系統(tǒng)中的數(shù)據(jù)進(jìn)行篡改,包括刪除、修改、添加等操作,從而影響系統(tǒng)的正常運(yùn)行。
3.信息竊?。和ㄟ^(guò)劫持系統(tǒng)調(diào)用,攻擊者可以獲取系統(tǒng)中的敏感信息,如密碼、賬戶信息、登陸記錄等,從而造成個(gè)人隱私泄露。
二、系統(tǒng)調(diào)用劫持的原理和攻擊方式
1.原理
系統(tǒng)調(diào)用劫持的原理主要是通過(guò)修改系統(tǒng)調(diào)用表中相應(yīng)系統(tǒng)調(diào)用號(hào)的入口指針,使得調(diào)用該系統(tǒng)調(diào)用時(shí),程序不再執(zhí)行原本的函數(shù),而是被惡意代碼所替代,從而實(shí)現(xiàn)對(duì)系統(tǒng)的控制。
2.攻擊方式
系統(tǒng)調(diào)用劫持的攻擊方式主要有兩種:
(1) 直接增加內(nèi)核模塊
攻擊者編寫(xiě)一個(gè)內(nèi)核模塊,將惡意代碼注入到內(nèi)核中,然后通過(guò)修改系統(tǒng)調(diào)用表中的指針,將要調(diào)用的系統(tǒng)調(diào)用劫持到自己的代碼中。
(2) 靜態(tài)劫持
攻擊者在系統(tǒng)中植入惡意代碼,篡改系統(tǒng)調(diào)用表中的指針,使得要調(diào)用的系統(tǒng)調(diào)用被劫持到惡意代碼中。
三、解決方法
為了防止系統(tǒng)調(diào)用劫持,必須采取相應(yīng)的措施進(jìn)行防范。
1.加強(qiáng)系統(tǒng)安全性
建議用戶加強(qiáng)系統(tǒng)安全性,使用防火墻、入侵檢測(cè)系統(tǒng)等工具,以及及時(shí)打補(bǔ)丁、更新系統(tǒng)等措施,增強(qiáng)系統(tǒng)的安全性。
2.升級(jí)內(nèi)核版本
目前,Linux內(nèi)核提供了比較完備的針對(duì)系統(tǒng)調(diào)用劫持的保護(hù)措施。用戶可以升級(jí)內(nèi)核版本,使用最新版內(nèi)核,從而避免系統(tǒng)調(diào)用劫持。
3.使用安全模塊
在Linux系統(tǒng)中,使用安全模塊可以對(duì)系統(tǒng)調(diào)用劫持進(jìn)行防范。常用的安全模塊有SELinux、Apparmor和Grsecurity等。這些安全模塊都提供了特定的策略來(lái)限制系統(tǒng)調(diào)用的使用,從而保證系統(tǒng)的安全。
4.編寫(xiě)函數(shù)鉤子
采用函數(shù)鉤子技術(shù)可以監(jiān)控特定的函數(shù)調(diào)用,并提供針對(duì)惡意調(diào)用的處理機(jī)制。通過(guò)編寫(xiě)函數(shù)鉤子,用戶可以實(shí)現(xiàn)針對(duì)系統(tǒng)調(diào)用劫持的監(jiān)控,從而預(yù)防系統(tǒng)調(diào)用劫持的發(fā)生。
5.使用虛擬化技術(shù)
通過(guò)虛擬化技術(shù),用戶可以將Linux系統(tǒng)運(yùn)行在虛擬機(jī)環(huán)境中,并且為每個(gè)虛擬機(jī)分配相應(yīng)的資源,避免系統(tǒng)調(diào)用劫持對(duì)系統(tǒng)的侵害。
綜上所述,系統(tǒng)調(diào)用劫持是一種嚴(yán)重的安全威脅,需要采取適當(dāng)?shù)拇胧┻M(jìn)行防范。用戶可以加強(qiáng)系統(tǒng)安全性、升級(jí)內(nèi)核版本、使用安全模塊、編寫(xiě)函數(shù)鉤子和使用虛擬化技術(shù)等措施,從而預(yù)防系統(tǒng)調(diào)用劫持的發(fā)生,確保系統(tǒng)的安全。
相關(guān)問(wèn)題拓展閱讀:
- LINUX中解決生產(chǎn)者消費(fèi)者問(wèn)題的幾個(gè)系統(tǒng)調(diào)用的語(yǔ)法及用法?
- 如何在linux內(nèi)核中添加系統(tǒng)調(diào)用
LINUX中解決生產(chǎn)者消費(fèi)者問(wèn)題的幾個(gè)系統(tǒng)調(diào)用的語(yǔ)法及用法?
在Linux中,生產(chǎn)者消費(fèi)者問(wèn)題通常使用進(jìn)程間通信(IPC)的方式來(lái)解決,可以使用以下幾個(gè)系統(tǒng)調(diào)用:
shmget():創(chuàng)建共享內(nèi)存區(qū)域
語(yǔ)法:int shmget(key_t key, size_t size, int shm);
用法:shmget()函數(shù)用于創(chuàng)建一個(gè)共享內(nèi)存區(qū)域,并返回共享內(nèi)存的標(biāo)識(shí)符。其中key表示共享內(nèi)存的鍵值,size表示需要分配的內(nèi)存大小,shm表示訪問(wèn)權(quán)限等標(biāo)志。
shmat():將共享內(nèi)存附加到進(jìn)程地址空間
語(yǔ)法:void *shmat(int shmid, const void *shmaddr, int shm);
用法:shmat()函數(shù)用于將共享內(nèi)擾李慧存區(qū)域附加到當(dāng)前進(jìn)程的地址空間,并返回共享內(nèi)存的首地址。其中shmid表示共享內(nèi)存的緩答標(biāo)識(shí)符,shmaddr表示共享內(nèi)存附加的地址,如果為NULL則表示讓系統(tǒng)自動(dòng)分配地址,shm表示訪問(wèn)權(quán)限等標(biāo)志。
shmctl():控制共享內(nèi)存區(qū)域
語(yǔ)法:int shmctl(int shmid, int cmd, struct shmid_ds *buf);
用法:shmctl()函數(shù)用于對(duì)共享內(nèi)存區(qū)域進(jìn)行控制,如刪除共享內(nèi)存區(qū)域等。其中shmid表示共享內(nèi)存的標(biāo)識(shí)符,cmd表示控制命令,buf表示共享內(nèi)存區(qū)域狀態(tài)的緩沖區(qū)。
semget():創(chuàng)建信號(hào)量集
語(yǔ)法:int semget(key_t key, int nsems, int sem);
用法:semget()函數(shù)用于創(chuàng)建一個(gè)信擾棚號(hào)量集,并返回信號(hào)量的標(biāo)識(shí)符。其中key表示信號(hào)量的鍵值,nsems表示信號(hào)量集中信號(hào)量的數(shù)量,sem表示訪問(wèn)權(quán)限等標(biāo)志。
semop():對(duì)信號(hào)量進(jìn)行操作
語(yǔ)法:int semop(int semid, struct sembuf *sops, unsigned nsops);
用法:semop()函數(shù)用于對(duì)信號(hào)量集中的一個(gè)或多個(gè)信號(hào)量進(jìn)行操作,如加鎖或解鎖。其中semid表示信號(hào)量的標(biāo)識(shí)符,sops表示要進(jìn)行的操作,nsops表示操作數(shù)量。
semctl():控制信號(hào)量集
語(yǔ)法:int semctl(int semid, int semnum, int cmd, union semun arg);
用法:semctl()函數(shù)用于對(duì)信號(hào)量集進(jìn)行控制,如刪除信號(hào)量集等。其中semid表示信號(hào)量的標(biāo)識(shí)符,semnum表示信號(hào)量的索引,cmd表示控制命令,arg表示控制命令的參數(shù)。
以上是解決生產(chǎn)者消費(fèi)者問(wèn)題的幾個(gè)系統(tǒng)調(diào)用的語(yǔ)法及用法
如何在linux內(nèi)核中添加系統(tǒng)調(diào)用
一、Linux0.11下添加系統(tǒng)調(diào)用:
我在bochs2.2.1中對(duì)linux0.11內(nèi)核添加了一個(gè)新的系統(tǒng)調(diào)用,步驟如下:
1./usr/src/linux/include/unistd.h中添加:#define __NR_mytest 87
然后在下面聲明函數(shù)原型:int mytest();
2./usr/src/差棗linux/include/linux/sys.h中添加:extern int sys_mytest();
然后在sys_call_table中最后加上sys_mytest;
3.在/usr/src/linux/kernel/sys.c中添加函數(shù)實(shí)現(xiàn)如下:
int sys_mytest(){
printk(“This is a test!”);
return 123;
}
4.在/usr/src/linux/kernel/system_call.s中對(duì)系統(tǒng)調(diào)用號(hào)加1(原來(lái)是86改成了87)
5.然后到/usr/src/linux目錄下編譯內(nèi)核make clean; make Image
6. cp /usr/src/linux/include/unistd.h /usr/include/unistd.h
7. reset bochs
8. 在/usr/root中生成test.c文件如下:
#define __LIBRARY__
#include
_syscall0(int,mytest)
int main(){
int a;
a = mytest();
printf(“%d”, a);
return 0;
}
9.然后gcc test.c編譯之后運(yùn)行a.out,前面所有步驟都通過(guò),但是每次調(diào)用都是返回-1,然后我查過(guò)errno為1(表示操作不允許),就不知道為什么了?
系統(tǒng)知道的高手們能夠告知一下,不勝感激!這個(gè)問(wèn)題困擾我很久了!
二、新Linux內(nèi)核添加系統(tǒng)調(diào)用
如何在Linux系統(tǒng)中添加新的系統(tǒng)調(diào)用
系統(tǒng)調(diào)用是應(yīng)用程序和操作系統(tǒng)內(nèi)核之間的功能接口。其主要目的是使得旅耐用戶可以使用操作系統(tǒng)提供的有關(guān)設(shè)備管理、輸入/輸入系統(tǒng)、文件系統(tǒng)和進(jìn)程控制、通信以及存儲(chǔ)管理等方面拆慶春的功能,而不必了解系統(tǒng)程序的內(nèi)部結(jié)構(gòu)和有關(guān)硬件細(xì)節(jié),從而起到減輕用戶負(fù)擔(dān)和保護(hù)系統(tǒng)以及提高資源利用率的作用。
Linux操作系統(tǒng)作為自由軟件的代表,它優(yōu)良的性能使得它的應(yīng)用日益廣泛,不僅得到專業(yè)人士的肯定,而且商業(yè)化的應(yīng)用也是如火如荼。在Linux中,大部分的系統(tǒng)調(diào)用包含在Linux的libc庫(kù)中,通過(guò)標(biāo)準(zhǔn)的C函數(shù)調(diào)用方法可以調(diào)用這些系統(tǒng)調(diào)用。那么,對(duì)Linux的發(fā)燒友來(lái)說(shuō),如何在Linux中增加新的系統(tǒng)調(diào)用呢?
1 Linux系統(tǒng)調(diào)用機(jī)制
在Linux系統(tǒng)中,系統(tǒng)調(diào)用是作為一種異常類型實(shí)現(xiàn)的。它將執(zhí)行相應(yīng)的機(jī)器代碼指令來(lái)產(chǎn)生異常信號(hào)。產(chǎn)生中斷或異常的重要效果是系統(tǒng)自動(dòng)將用戶態(tài)切換為核心態(tài)來(lái)對(duì)它進(jìn)行處理。這就是說(shuō),執(zhí)行系統(tǒng)調(diào)用異常指令時(shí),自動(dòng)地將系統(tǒng)切換為核心態(tài),并安排異常處理程序的執(zhí)行。Linux用來(lái)實(shí)現(xiàn)系統(tǒng)調(diào)用異常的實(shí)際指令是:
Int $0x80
這一指令使用中斷/異常向量號(hào)128(即16進(jìn)制的80)將控制權(quán)轉(zhuǎn)移給內(nèi)核。為達(dá)到在使用系統(tǒng)調(diào)用時(shí)不必用機(jī)器指令編程,在標(biāo)準(zhǔn)的C語(yǔ)言庫(kù)中為每一系統(tǒng)調(diào)用提供了一段短的子程序,完成機(jī)器代碼的編程工作。事實(shí)上,機(jī)器代碼段非常簡(jiǎn)短。它所要做的工作只是將送給系統(tǒng)調(diào)用的參數(shù)加載到CPU寄存器中,接著執(zhí)行int $0x80指令。然后運(yùn)行系統(tǒng)調(diào)用,系統(tǒng)調(diào)用的返回值將送入CPU的一個(gè)寄存器中,標(biāo)準(zhǔn)的庫(kù)子程序取得這一返回值,并將它送回用戶程序。
為使系統(tǒng)調(diào)用的執(zhí)行成為一項(xiàng)簡(jiǎn)單的任務(wù),Linux提供了一組預(yù)處理宏指令。它們可以用在程序中。這些宏指令取一定的參數(shù),然后擴(kuò)展為調(diào)用指定的系統(tǒng)調(diào)用的函數(shù)。
這些宏指令具有類似下面的名稱格式:
_syscallN(parameters)
其中N是系統(tǒng)調(diào)用所需的參數(shù)數(shù)目,而parameters則用一組參數(shù)代替。這些參數(shù)使宏指令完成適合于特定的系統(tǒng)調(diào)用的擴(kuò)展。例如,為了建立調(diào)用setuid()系統(tǒng)調(diào)用的函數(shù),應(yīng)該使用:
_syscall1( int, setuid, uid_t, uid )
syscallN( )宏指令的第1個(gè)參數(shù)int說(shuō)明產(chǎn)生的函數(shù)的返回值的類型是整型,第2個(gè)參數(shù)setuid說(shuō)明產(chǎn)生的函數(shù)的名稱。后面是系統(tǒng)調(diào)用所需要的每個(gè)參數(shù)。這一宏指令后面還有兩個(gè)參數(shù)uid_t和uid分別用來(lái)指定參數(shù)的類型和名稱。
另外,用作系統(tǒng)調(diào)用的參數(shù)的數(shù)據(jù)類型有一個(gè)限制,它們的容量不能超過(guò)四個(gè)字節(jié)。這是因?yàn)閳?zhí)行int $0x80指令進(jìn)行系統(tǒng)調(diào)用時(shí),所有的參數(shù)值都存在32位的CPU寄存器中。使用CPU寄存器傳遞參數(shù)帶來(lái)的另一個(gè)限制是可以傳送給系統(tǒng)調(diào)用的參數(shù)的數(shù)目。這個(gè)限制是最多可以傳遞5個(gè)參數(shù)。所以Linux一共定義了6個(gè)不同的_syscallN()宏指令,從_syscall0()、_syscall1()直到_syscall5()。
一旦_syscallN()宏指令用特定系統(tǒng)調(diào)用的相應(yīng)參數(shù)進(jìn)行了擴(kuò)展,得到的結(jié)果是一個(gè)與系統(tǒng)調(diào)用同名的函數(shù),它可以在用戶程序中執(zhí)行這一系統(tǒng)調(diào)用。
2 添加新的系統(tǒng)調(diào)用
如果用戶在Linux中添加新的系統(tǒng)調(diào)用,應(yīng)該遵循幾個(gè)步驟才能添加成功,下面幾個(gè)步驟詳細(xì)說(shuō)明了添加系統(tǒng)調(diào)用的相關(guān)內(nèi)容。
(1) 添加源代碼
之一個(gè)任務(wù)是編寫(xiě)加到內(nèi)核中的源程序,即將要加到一個(gè)內(nèi)核文件中去的一個(gè)函數(shù),該函數(shù)的名稱應(yīng)該是新的系統(tǒng)調(diào)用名稱前面加上sys_標(biāo)志。假設(shè)新加的系統(tǒng)調(diào)用為mycall(int number),在/usr/src/linux/kernel/sys.c文件中添加源代碼,如下所示:
alinkage int sys_mycall(int number)
{
return number;
}
作為一個(gè)最簡(jiǎn)單的例子,我們新加的系統(tǒng)調(diào)用僅僅返回一個(gè)整型值。
(2) 連接新的系統(tǒng)調(diào)用
添加新的系統(tǒng)調(diào)用后,下一個(gè)任務(wù)是使Linux內(nèi)核的其余部分知道該程序的存在。為了從已有的內(nèi)核程序中增加到新的函數(shù)的連接,需要編輯兩個(gè)文件。
在我們所用的Linux內(nèi)核版本(RedHat 6.0,內(nèi)核為2.2.5-15)中,之一個(gè)要修改的文件是:
/usr/src/linux/include/a-i386/unistd.h
該文件中包含了系統(tǒng)調(diào)用清單,用來(lái)給每個(gè)系統(tǒng)調(diào)用分配一個(gè)唯一的號(hào)碼。文件中每一行的格式如下:
#define __NR_name NNN
其中,name用系統(tǒng)調(diào)用名稱代替,而NNN則是該系統(tǒng)調(diào)用對(duì)應(yīng)的號(hào)碼。應(yīng)該將新的系統(tǒng)調(diào)用名稱加到清單的最后,并給它分配號(hào)碼序列中下一個(gè)可用的系統(tǒng)調(diào)用號(hào)。我們的系統(tǒng)調(diào)用如下:
#define __NR_mycall 191
系統(tǒng)調(diào)用號(hào)為191,之所以系統(tǒng)調(diào)用號(hào)是191,是因?yàn)長(zhǎng)inux-2.2內(nèi)核自身的系統(tǒng)調(diào)用號(hào)碼已經(jīng)用到190。
第二個(gè)要修改的文件是:
/usr/src/linux/arch/i386/kernel/entry.S
該文件中有類似如下的清單:
.long SYMBOL_NAME()
該清單用來(lái)對(duì)sys_call_table數(shù)組進(jìn)行初始化。該數(shù)組包含指向內(nèi)核中每個(gè)系統(tǒng)調(diào)用的指針。這樣就在數(shù)組中增加了新的內(nèi)核函數(shù)的指針。我們?cè)谇鍐巫詈筇砑右恍校?/p>
.long SYMBOL_NAME(sys_mycall)
?。?) 重建新的Linux內(nèi)核
為使新的系統(tǒng)調(diào)用生效,需要重建Linux的內(nèi)核。這需要以超級(jí)用戶身份登錄。
#pwd
/usr/src/linux
#
超級(jí)用戶在當(dāng)前工作目錄(/usr/src/linux)下,才可以重建內(nèi)核。
#make config
#make dep
#make clearn
#make bzImage
編譯完畢后,系統(tǒng)生成一可用于安裝的、壓縮的內(nèi)核映象文件:
/usr/src/linux/arch/i386/boot/bzImage
?。?) 用新的內(nèi)核啟動(dòng)系統(tǒng)
要使用新的系統(tǒng)調(diào)用,需要用重建的新內(nèi)核重新引導(dǎo)系統(tǒng)。為此,需要修改/etc/lilo.conf文件,在我們的系統(tǒng)中,該文件內(nèi)容如下:
boot=/dev/hda
map=/boot/map
install=/boot/boot.b
prompt
timeout=50
image=/boot/vmlinuz-2.2.5-15
label=linux
root=/dev/hdb1
read-only
other=/dev/hda1
label=dos
table=/dev/had
首先編輯該文件,添加新的引導(dǎo)內(nèi)核:
image=/boot/bzImage-new
label=linux-new
root=/dev/hdb1
read-only
添加完畢,該文件內(nèi)容如下所示:
boot=/dev/hda
map=/boot/map
install=/boot/boot.b
prompt
timeout=50
image=/boot/bzImage-new
label=linux-new
root=/dev/hdb1
read-only
image=/boot/vmlinuz-2.2.5-15
label=linux
root=/dev/hdb1
read-only
other=/dev/hda1
label=dos
table=/dev/hda
這樣,新的內(nèi)核映象bzImage-new成為缺省的引導(dǎo)內(nèi)核。為了使用新的lilo.conf配置文件,還應(yīng)執(zhí)行下面的命令:
#cp /usr/src/linux/arch/i386/boot/zImage /boot/bzImage-new
其次配置lilo:
# /in/lilo
現(xiàn)在,當(dāng)重新引導(dǎo)系統(tǒng)時(shí),在boot:提示符后面有三種選擇:linux-new 、linux、dos,新內(nèi)核成為缺省的引導(dǎo)內(nèi)核。
至此,新的Linux內(nèi)核已經(jīng)建立,新添加的系統(tǒng)調(diào)用已成為操作系統(tǒng)的一部分,重新啟動(dòng)Linux,用戶就可以在應(yīng)用程序中使用該系統(tǒng)調(diào)用了。
?。?)使用新的系統(tǒng)調(diào)用
在應(yīng)用程序中使用新添加的系統(tǒng)調(diào)用mycall。同樣為實(shí)驗(yàn)?zāi)康?,我們?xiě)了一個(gè)簡(jiǎn)單的例子xtdy.c。
/* xtdy.c */
#include
_syscall1(int,mycall,int,ret)
main()
{
printf(“%d \n”,mycall(100));
}
編譯該程序:
# cc -o xtdy xtdy.c
執(zhí)行:
# xtdy
結(jié)果:
# 100
注意,由于使用了系統(tǒng)調(diào)用,編譯和執(zhí)行程序時(shí),用戶都應(yīng)該是超級(jí)用戶身份。
關(guān)于linux劫持系統(tǒng)調(diào)用的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開(kāi)通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過(guò)10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開(kāi)發(fā)經(jīng)驗(yàn)。專業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊(cè)、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。
網(wǎng)站欄目:Linux下的系統(tǒng)調(diào)用劫持問(wèn)題及解決方法(linux劫持系統(tǒng)調(diào)用)
URL地址:http://www.dlmjj.cn/article/djhdipo.html


咨詢
建站咨詢
