@CallerSensitive注解(隨筆)

前言

在閱讀Unsafe源碼是,以下是Unsafe部分源碼:

    @CallerSensitive
    public static Unsafe getUnsafe() {
        Class var0 = Reflection.getCallerClass();
        if (!VM.isSystemDomainLoader(var0.getClassLoader())) {
            throw new SecurityException("Unsafe");
        } else {
            return theUnsafe;
        }
    }

我們可以看到,這個方法上有一個@CallerSensitive注解,所以今天我們就來了解下這個注解儒飒。

分析

查看源碼,我們可以看到方法內(nèi)部都調(diào)用了Reflection.getCallerClass()檩奠,這是一個native方法桩了;
巧的是,這個方法也有@CallerSensitive注解埠戳,下面是這個方法的源碼:

    @CallerSensitive
    public static native Class<?> getCallerClass();
解釋

Caller:調(diào)用者井誉,Sensitive:敏感的/易感知的,顧名思義整胃,這是主要針對于方法調(diào)用者所做的一些控制送悔;

然而實際上,@CallSensitive是JVM中專用的注解爪模,在類加載過過程中是可以常常看到這個注解荚藻;

那么屋灌,需要什么權(quán)限才能調(diào)用這個方法?

  1. 由bootstrap class loader加載的類可以調(diào)用
  2. 由extension class loader加載的類可以調(diào)用

用戶路徑的類加載都是由 application class loader進(jìn)行加載的应狱,也就是用戶自定義的類基本上是無法調(diào)用此方法的

作用

Reflection.getCallerClass()方法調(diào)用所在的方法必須用@CallerSensitive進(jìn)行注解共郭;
通過此方法獲取class時會跳過鏈路上所有的有@CallerSensitive注解的方法的類;
直到遇到第一個未使用該注解的類疾呻,避免了用Reflection.getCallerClass(int n) 這個過時方法來自己做判斷除嘹;

番外

據(jù)說注解是為了堵住漏洞用的,曾經(jīng)有黑客通過構(gòu)造雙重反射來提升權(quán)限岸蜗,原理是當(dāng)時反射只檢查固定深度的調(diào)用者的類尉咕,看它有沒有特權(quán)胆胰;

當(dāng)你嘗試用反射調(diào)用Reflection.getCallerClass()叔收,結(jié)果會拋出異常型宝;

所以在我們?nèi)粘i_發(fā)中木人,可以說作用不大便监,了解就好了阅束;
主要還是JDK底層控制權(quán)限的地方使用细疚。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末躁垛,一起剝皮案震驚了整個濱河市犁柜,隨后出現(xiàn)的幾起案子洲鸠,更是在濱河造成了極大的恐慌,老刑警劉巖馋缅,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件扒腕,死亡現(xiàn)場離奇詭異绢淀,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)袜匿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門更啄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人居灯,你說我怎么就攤上這事祭务。” “怎么了怪嫌?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵义锥,是天一觀的道長。 經(jīng)常有香客問我岩灭,道長拌倍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任噪径,我火速辦了婚禮柱恤,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘找爱。我一直安慰自己梗顺,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布车摄。 她就那樣靜靜地躺著寺谤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪吮播。 梳的紋絲不亂的頭發(fā)上变屁,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天,我揣著相機(jī)與錄音意狠,去河邊找鬼粟关。 笑死,一個胖子當(dāng)著我的面吹牛环戈,可吹牛的內(nèi)容都是我干的誊役。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼谷市,長吁一口氣:“原來是場噩夢啊……” “哼蛔垢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起迫悠,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤鹏漆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體艺玲,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡括蝠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了饭聚。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忌警。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖秒梳,靈堂內(nèi)的尸體忽然破棺而出法绵,到底是詐尸還是另有隱情,我是刑警寧澤酪碘,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布朋譬,位于F島的核電站,受9級特大地震影響兴垦,放射性物質(zhì)發(fā)生泄漏徙赢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一探越、第九天 我趴在偏房一處隱蔽的房頂上張望狡赐。 院中可真熱鬧,春花似錦钦幔、人聲如沸阴汇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至拐纱,卻和暖如春铜异,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背秸架。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工揍庄, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人东抹。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓蚂子,卻偏偏與公主長得像,于是被迫代替她去往敵國和親缭黔。 傳聞我的和親對象是個殘疾皇子食茎,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 今天感恩節(jié)哎,感謝一直在我身邊的親朋好友馏谨。感恩相遇别渔!感恩不離不棄。 中午開了第一次的黨會,身份的轉(zhuǎn)變要...
    迷月閃星情閱讀 10,567評論 0 11
  • 彩排完哎媚,天已黑
    劉凱書法閱讀 4,218評論 1 3
  • 表情是什么喇伯,我認(rèn)為表情就是表現(xiàn)出來的情緒。表情可以傳達(dá)很多信息拨与。高興了當(dāng)然就笑了稻据,難過就哭了。兩者是相互影響密不可...
    Persistenc_6aea閱讀 125,132評論 2 7