主頁 >  其他 > 室友打了倆把LOL,我知道了類是怎樣加載的

室友打了倆把LOL,我知道了類是怎樣加載的

2022-01-02 07:49:20 其他

目錄

類加載

類加載的時機

類加載的程序

加載階段

驗證階段

準備階段

決議階段

初始化階段

類加載器

雙親委派

破壞雙親委派


本文摘自(深入理解JVM)

如有錯誤望指出

類加載

Java虛擬機把描述類的資料從Class檔案加載到記憶體,并對資料進行校驗、轉換決議和初始化,最終形成可被java虛擬機直接使用的java型別,這個程序被稱為虛擬機的類加載機制

在java語言里面,型別的加載、連接和初始化都是在程式運行期間完成的

“Class檔案”也并非特指某個存在于具體磁盤的檔案,而應當是一串二進制位元組流

類加載的時機

一個型別被加載到java虛擬機記憶體中開始到記憶體結束時,會經歷七個階段,加載、驗證、準備、決議、初始化、使用和卸載

其中驗證、準備、決議三個部分統稱為連接

加載、驗證、準備、初始化和卸載這五個階段的順序是確定的,型別的加載程序必須按照這種順序按部就班的開始,而決議階段則不一樣,它在某些情況下可以在初始化階段之后再開始,這是為了支持Java語言的運行時系結特性(也稱為動態系結或晚期系結),

這些階段通常都是互相交叉地混合進行的,會在一個階段執行的程序中呼叫、激活另一個階段,

在什么情況下需要開始類加載的程序中的第一個階段“加載”:

  • 遇到new、getstatic、putstatic或invokestatic這四條位元組碼指令時,如果型別沒有進行過初始化,則需要先觸發其初始化階段,場景:

    • 使用new實體化物件

    • 讀取或設定一個型別的靜態欄位

    • 呼叫一個型別的靜態方法

  • 使用java.lang.reflect包的方法對型別進行反射呼叫的時候,如果型別沒有進行過初始化,則需要先觸發其初始化

  • 當初始化類的時候,還沒有觸發其父類的初始化則先觸發父類的初始化

  • 虛擬機啟動時,初始化主類(包含main()方法的)

  • 當使用JDK 7新加入的動態語言支持時,如果一個java.lang.invoke.MethodHandle實體最后的決議結果為REF_getStatic、REF_putStatic、REF_invokeStatic、REF_newInvokeSpecial四種型別的方法句柄,并且這個方法句柄對應的類沒有進行過初始化,則需要先觸發其初始化,

  • 當一個介面中定義了JDK 8新加入的默認方法(被default關鍵字修飾的介面方法)時,如果有這個介面的實作類發生了初始化,那該介面要在其之前被初始化,

這六種場景中的行為稱為對一個型別進行主動參考,除此之外,所有參考型別的方式都不會觸發初始化,稱為被動參考,

package org.fenixsoft.classloading; 

/**

\* 被動使用類欄位演示一: 

\* 通過子類參考父類的靜態欄位,不會導致子類初始化 

**/ 
public class SuperClass { 

static { 

System.out.println("SuperClass init!"); 

}

public static int value = 123; 

}

public class SubClass extends SuperClass { 

static { 

System.out.println("SubClass init!"); 

} 

}

/**

\* 非主動使用類欄位演示 

**/ 

public class NotInitialization { 

public static void main(String[] args) { 

System.out.println(SubClass.value); 

} 

} 

上述代碼運行之后,只會輸出“SuperClass init!”,而不會輸出“SubClass init!”,對于靜態欄位,只有直接定義這個欄位的類才會被初始化,因此通過其子類來參考父類中定義的靜態欄位,只會觸發父類的初始化而不會觸發子類的初始化

package org.fenixsoft.classloading; 

/**

\* 被動使用類欄位演示二: 

\* 通過陣列定義來參考類,不會觸發此類的初始化 

**/ 

public class NotInitialization { 

public static void main(String[] args) { 

SuperClass[] sca = new SuperClass[10]; 

} 

}

/**

\* 被動使用類欄位演示三: 

\* 常量在編譯階段會存入呼叫類的常量池中,本質上沒有直接參考到定義常量的類,因此不會觸發定義常量的 

類的初始化 

**/ 

public class ConstClass { 

static { 

System.out.println("ConstClass init!"); 

}

public static final String HELLOWORLD = "hello world"; 

}

/**

\* 非主動使用類欄位演示 

**/ 

public class NotInitialization { 

public static void main(String[] args) { 

System.out.println(ConstClass.HELLOWORLD); 

} 

}  

類加載的程序

加載階段

在加載階段,Java虛擬機需要完成以下三件事情:

  1. 通過一個類的全限定名來獲取定義此類的二進制位元組流

  2. 將這個位元組流所代表的靜態存盤結構轉化為方法區的運行時資料結構

  3. 在記憶體中生成一個代表這個類的java.lang.Class物件,作為方法區這個類的各種資料的訪問入口

驗證階段

驗證是連接階段的第一步

確保Class檔案中包含的位元組流符合《java虛擬機規范》,保證這些資訊不會危害虛擬機的安全

驗證的作業量在虛擬機的類加載程序中占了很大的比重

蘊含四個階段:

  • 檔案格式驗證

這一階段是驗證位元組流是否符合Class檔案格式的規范,并且能被當前虛擬機的版本所處理

  1. 是否以魔數0xCAFEBABE開頭

  2. 主、次版本號是否在當前Java虛擬機接受范圍之內,

  3. 常量池的常量中是否有不被支持的常量型別(檢查常量tag標志)

  4. 指向常量的各種索引值中是否有指向不存在的常量或不符合型別的常量

  5. CONSTANT_Utf8_info型的常量中是否有不符合UTF-8編碼的資料

  6. Class檔案中各個部分及檔案本身是否有被洗掉的或附加的其他資訊

  7. ............等等

  • 元資料驗證

第二階段是對位元組碼描述的資訊進行語意分析,保證其描述的資訊符合《java語言規范》的要求,驗證點如下:

  1. ·這個類是否有父類(除了java.lang.Object之外,所有的類都應當有父類)

  2. ·這個類的父類是否繼承了不允許被繼承的類(被final修飾的類),

  3. ·如果這個類不是抽象類,是否實作了其父類或介面之中要求實作的所有方法

  4. 類中的欄位、方法是否與父類產生矛盾(例如覆寫了父類的final欄位,或者出現不符合規則的方法多載,例如方法引數都一致,但回傳值型別卻不同等),

  5. ........等等

第二階段的主要目的是對類的元資料資訊進行語意校驗,保證不存在與《java語言規范》不相符的元資料資訊

  • 位元組碼驗證

第三階段是整個驗證程序中最復雜的一個階段

要目的是通過資料流分析和控制流分析,確定程式語意是合法的、符合邏輯的

  1. 保證任意時刻運算元堆疊的資料型別與指令代碼序列都能配合作業,例如不會出現類似于“在操作堆疊放置了一個int型別的資料,使用時卻按long型別來加載入本地變數表中”這樣的情況

  2. ·保證任何跳轉指令都不會跳轉到方法體以外的位元組碼指令上,

  3. ·保證方法體中的型別轉換總是有效的,例如可以把一個子類物件賦值給父類資料型別,這是安全的,但是把父類物件賦值給子類資料型別,甚至把物件賦值給與它毫無繼承關系、完全不相干的一個資料型別,則是危險和不合法的,

  4. 等等.........

如果一個型別中有方法體的位元組碼沒有通過位元組碼驗證,那它肯定是有問題的;

但如果一個方法體通過了位元組碼驗證,也仍然不能保證它一定就是安全的,即使位元組碼驗證階段中進行了再大量、再嚴密的檢查,也依然不能保證這一點

  • 符號參考驗證

最后一個階段的校驗行為發生在虛擬機將符號參考轉化為直接參考[3]的時候,這個轉化動作將在連接的第三階段——決議階段中發生

,符號參考驗證可以看作是對類自身以外(常量池中的各種符號

參考)的各類資訊進行匹配性校驗,通俗來說就是,該類是否缺少或者被禁止訪問它依賴的某些外部

類、方法、欄位等資源,本階段通常需要校驗下列內容:

  1. ·符號參考中通過字串描述的全限定名是否能找到對應的類,

  2. ·在指定類中是否存在符合方法的欄位描述符及簡單名稱所描述的方法和欄位

  3. ·符號參考中的類、欄位、方法的可訪問性(private、protected、public、<package>)是否可被當前類訪問,

驗證階段對于虛擬機的類加載機制來說,是一個非常重要的、但卻不是必須要執行的階段,因為驗證階段只有通過或者不通過的差別,只要通過了驗證,其后就對程式運行期沒有任何影響了

準備階段

準備階段是正式為類中定義的變數(即靜態變數被static修飾的變數)分配記憶體并設定類變數初始值的階段

假設一個類變數的定義為:

 public static int value = 123;

那變數value在準備階段過后的初始值為0而不是123,因為這時尚未開始執行任何Java方法,

而把value賦值為123的putstatic指令是程式被編譯后,存放于類構造器<clinit>()方法之中,

所以把value賦值為123的動作要到類的初始化階段才會被執行

如果類欄位的欄位屬性表中存在ConstantValue屬性,那在準備階段變數值就會被初始化為ConstantValue屬性所指定的初始值

假設上面類變數value的定義修改為:

 public static final int value = 123;

編譯時Javac將會為value生成ConstantValue屬性,在準備階段虛擬機就會根據Con-stantValue的設定將value賦值為123,

上面講述了設定類變數初始值,但沒講述分配記憶體,分配在哪里呢?

分配在哪個空間是比較模糊的,概念上是被分配在方法區中,但必須注意方法區是一個邏輯上的區域,JDK7以前可以說被分配在方法區,7以后就是一種,這時候“類變數在 方法區”就完全是一種對邏輯概念的表述了

決議階段

決議階段是Java虛擬機將常量池內的符號參考替換為直接參考的程序

  • 符號參考(Symbolic References):符號參考以一組符號來描述所參考的目標,符號可以是任何形式的字面量,只要使用時能無歧義地定位到目標即可

  • ·直接參考(Direct References):直接參考是可以直接指向目標的指標、相對偏移量或者是一個能間接定位到目標的句柄

符號參考與虛擬機實作的記憶體布局無關直接參考是和虛擬機實作的記憶體布局直接相關的同一個符號參考在不同虛擬機實體上翻譯出來的直接參考一般不會相同,

如果有了直接參考,那參考的目標必定已經在虛擬機的記憶體中存在,

決議動作主要針對類或介面、欄位、類方法、介面方法、方法型別、方法句柄和呼叫點限定符這7類符號參考進行

初始化階段

類的初始化階段是類加載程序的最后一個步驟,之前介紹的幾個類加載的動作里,

除了在加載階段用戶應用程式可以通過自定義類加載器的方式區域參與外,其余動作都完全由Java虛擬機來主導控制,

直到初始化階段,Java虛擬機才真正開始執行類中撰寫的Java程式代碼,將主導權移交給應用程式,

進行準備階段時,變數已經賦過一次系統要求的初始零值,而在初始化階段,

則會根據程式員通程序式編碼制定的主觀計劃去初始化類變數和其他資源,

我們也可以從另外一種更直接的形式來表達:初始化階段就是執行類構造器<clinit>()方法的程序

·<clinit>()方法是由編譯器自動收集類中的所有類變數的賦值動作和靜態陳述句塊(static{}塊)中的 陳述句合并產生的,它是Javac編譯器的自動生成物

編譯器收集的順序是由陳述句在源檔案中出現的順序決定的,靜態陳述句塊中只能訪問到定義在靜態陳述句塊之前的變數,定義在它之后的變數,在前面的靜態陳述句塊可以賦值,但是不能訪問

 public class Test { 
 ?
 static { 
 ?
 i = 0; // 給變數賦值可以正常編譯通過 
 ?
 System.out.print(i); // 這句編譯器會提示“非法向前參考” 
 ?
 }
 ?
 static int i = 1; 
 ?
 }

<clinit>()方法與類的建構式(即在虛擬機視角中的實體構造器<init>()方法)不同,

它不需要顯式地呼叫父類構造器,Java虛擬機會保證在子類的<clinit>()方法執行前,父類的<clinit>()方法已經執行完畢,

因此在Java虛擬機中第一個被執行的<clinit>()方法的型別肯定是java.lang.Object,

·由于父類的<clinit>()方法先執行,也就意味著父類中定義的靜態陳述句塊要優先于子類的變數賦值操作

<Clinit>方法對類或介面來說不是必須的,因為類中不一定需要靜態陳述句塊,而且如果沒有對變數的賦值操作,那么編譯器可以不為這個類生成<clinit>()方法,

介面中不能使用靜態陳述句塊,但仍然有變數初始化的賦值操作,因此介面與類一樣都會生成<clinit>()方法,但介面與類不同的是,執行介面的<clinit>()方法不需要先執行父介面的<clinit>()方法,

因為只有當父介面中定義的變數被使用時,父介面才會被初始化,此外,介面的實作類在初始化時也一樣不會執行介面的<clinit>()方法

Java虛擬機必須保證一個類的<clinit>()方法在多執行緒環境中被正確地加鎖同步,

如果多個執行緒同時去初始化一個類,那么只會有其中一個執行緒去執行這個類的<clinit>()方法,其他執行緒都需要阻塞等待

直到活動執行緒執行完畢<clinit>()方法,如果在一個類的<clinit>()方法中有耗時很長的操作,那就可能造成多個行程阻塞

在實際應用中這種阻塞往往是很隱蔽的

 static class DeadLoopClass { 
 ?
 static { 
 ?
 // 如果不加上這個if陳述句,編譯器將提示“Initializer does not complete normally” 
 ?
 并拒絕編譯 
 ?
 if (true) { 
 ?
 System.out.println(Thread.currentThread() + "init DeadLoopClass"); 
 ?
 while (true) { 
 ?
 } 
 ?
 } 
 ?
 } 
 ?
 }
 ?
 public static void main(String[] args) { 
 ?
 Runnable script = new Runnable() { 
 ?
 public void run() { 
 ?
 System.out.println(Thread.currentThread() + "start"); 
 ?
 DeadLoopClass dlc = new DeadLoopClass(); 
 ?
 System.out.println(Thread.currentThread() + " run over"); 
 ?
 } 
 ?
 };
 ?
 Thread thread1 = new Thread(script); 
 ?
 Thread thread2 = new Thread(script); 
 ?
 thread1.start(); 
 ?
 thread2.start(); 
 ?
 } 

運行結果如下,一條執行緒在死回圈以模擬長時間操作,另外一條執行緒在阻塞等待

 Thread[Thread-0,5,main]start 
 ?
 Thread[Thread-1,5,main]start 
 ?
 Thread[Thread-0,5,main]init DeadLoopClass

同一個類加載器下,一個型別只會被初始化一次

類加載器

比較兩個類是否“相等”,只有在這兩個類是由同一個類加載器加載的前提下才有意義,否則,即使這兩個類來源于同一個

Class檔案,被同一個Java虛擬機加載,只要加載它們的類加載器不同,那這兩個類就必定不相等

名稱加載哪的類說明
Bootstrap ClassLoaderJAVE_HOME/jre/lib無法直接訪問 null
Extension ClassLoaderJAVE_HOME/jre/lib/ext上級為Bootstrap
Application ClassLoaderclasspath上級為Extension
自定義類加載器自定義上級為Application

由下至上詢問是否加載

雙親委派

圖中展示的各種類加載器之間的層次關系被稱為類加載器的“雙親委派模型(Parents Delegation Model)”,雙親委派模型要求除了頂層的啟動類加載器外,其余的類加載器都應有自己的父類加載

器,不過這里類加載器之間的父子關系一般不是以繼承(

Inheritance)的關系來實作的,而是通常使用

組合(Composition)關系來復用父加載器的代碼,

雙親委派模型的作業程序是:如果一個類加載器收到了類加載的請求,它首先不會自己去嘗試加載這個類,

而是把這個請求委派給父類加載器去完成,每一個層次的類加載器都是如此,因此所有的 加載請求最終都應該傳送到最頂層的啟動類加載器中,

只有當父加載器反饋自己無法完成這個加載請 求(它的搜索范圍中沒有找到所需的類)時,子加載器才會嘗試自己去完成加載,

破壞雙親委派

  • 雙親委派第一次被破壞

即為了兼容雙親委派模型出現之前(JDK1.2)的代碼不得不做出的妥協

只能在JDK1.2,只能在JDK 1.2之后的java.lang.ClassLoader中添加一個新的

protected方法findClass(),并引導用戶撰寫的類加載邏輯時盡可能去重寫這個方法,而不是在 loadClass()中撰寫代碼

  • 雙親委派第二次被破壞

是由于自身這個雙親委派模型的缺陷導致的

雙親委派很好地解決了各個類加載器協作時基礎型別的一致性問題(越基礎的類由越上層的加載器進行加載)

基礎型別之所以被稱為“基礎”,是因為它們總是作為被用戶代碼繼承、呼叫的API存在,但程式設計往往沒有絕對不變

的完美規則,如果有基礎型別又要呼叫回用戶的代碼,那該怎么辦呢?

這時候就需要執行緒背景關系加載器了

這個類加載器可以通過java.lang.Thread類的setContext-ClassLoader()方

法進行設定,如果創建執行緒時還未設定,它將會從父執行緒中繼承一個,如果在應用程式的全域范圍內都沒有設定過的話,那這個類加載器默認就是應用程式類加載器

有了執行緒背景關系類加載器,程式就可以做一些“舞弊”的事情了

這是一種父類加載器去請求子類加載器完成類加載的行為,這種行

為實際上是打通了雙親委派模型的層次結構來逆向使用類加載器,已經違背了雙親委派模型的一般性原則,但也是無可奈何的事情

  • 雙親委派模型的第三次“被破壞”

是由于用戶對程式動態性的追求而導致的

動態性:代碼熱替換(Hot Swap)、模塊熱部署(Hot Deployment)等,說白了就是希望Java應用程式能像我們的電腦外設那樣,接上滑鼠、U盤,不用重啟機器就能立即使用

由IBM公司提出的OSGi提案動態化

OSGi通過類加載器實作熱部署

1)將以java.*開頭的類,委派給父類加載器加載,

2)否則,將委派串列名單內的類,委派給父類加載器加載,

3)否則,將Import串列中的類,委派給Export這個類的Bundle的類加載器加載,

4)否則,查找當前Bundle的ClassPath,使用自己的類加載器加載,

5)否則,查找類是否在自己的Fragment Bundle中,如果在,則委派給Fragment Bundle的類加載器

加載,

6)否則,查找Dynamic Import串列的Bundle,委派給對應Bundle的類加載器加載,

7)否則,類查找失敗,

上面的查找順序中只有開頭兩點仍然符合雙親委派模型的原則,其余的類查找都是在平級的類加載器中進行的

筆者雖然使用了“被破壞”這個詞來形容上述不符合雙親委派模型原則的行為,但這里“被破壞”并不一定是帶有貶義的,只要有明確的目的和充分的理由,突破舊有原則無疑是一種創新,

  • 雙親委派第四次被破壞

是JDK9之后出現的

JDK 9中雖然仍然維持著三層類加載器和雙親委派的架構,但類加載的委派關系也發生了變動,當平臺及應用程式類加載器收到類加載請求,在委派給父加載器加載前

要先判斷該類是否能夠歸屬到某一個系統模塊中,如果可以找到這樣的歸屬關系,就要優先委派給負責那個模塊的加載器完成加載,也許這可以算是對雙親委派的第四次破壞

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

標籤:其他

上一篇:【Qt6網路抓包工具專案實戰】導航目錄

下一篇:一文教你快速部署OneBlog開源專案

標籤雲
其他(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)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more