本文將力求用最簡單的語言和實例,介紹一下 OGNL 的語法規則,文章主要內容參考自官方文檔http://commons.apache.org/proper/commons-ognl/language-guide.htmlhtml
<!-- more -->java
ognl,全稱 Object Graphic Navigation Language(對象圖導航語言),根據約定的一些簡單的規則,組裝一個利於閱讀、可執行的表達式語句git
以下面是一個典型的表達式github
"name".toCharArray()[0].numericValue.toString()
即使徹底不懂 ognl,單純的以 java 的基礎知識就能夠看懂,而這就是 ognl 的魅力所在 (學習一點點東西,就能夠立刻入手)apache
說明,這一小節的內容爲我我的爲了方便理解而分類的,並不官方設計模式
咱們知道在 java 中,一切都是對象,因此咱們的 ognl 表達式必然是着手於某一個對象的,一般在 ognl 中,能夠將待執行目標對象劃分爲三類數組
在 gonl 的語法中,上面三種 case,根據不一樣的開頭來標記bash
靜態對象ide
簡單來講就是我想訪問靜態類的某個方法(或者靜態類的成員)學習
@java.lang.Math
語法規則爲根據@
開始,後面接上完整的類名
一個實例 case 以下,至關於 java 代碼中直接調用Math.max(10, 20)
@java.lang.Math@max(10, 20)
非簡單對象
訪問一個普通對象的成員 or 方法
#demo
語法規則爲根據#
開頭,後面爲對象名(說明,這個對象須要在 Ognl 的上下文中,且能夠根據對象名能夠惟必定位)
簡單對象
即基本類型的對象訪問,不加任何前綴,直接使用便可,以下
// 字符串的長度 "name".length() // 數字計算 1+2 // boolean true
執行目標對象的某個方法,規則以下
// 非基本對象的方法訪問,#開頭,對象與方法之間用.鏈接 #obj.method( 參數 ) // 靜態對象的方法訪問,@開頭,對象與方法之間用@鏈接 @xxx@method( 參數 ) // 基本對象的方法訪問,和非基本對象方法方式一致 "name".length()
訪問目標對象的成員,規則以下
// 非基本對象的成員訪問,#開頭,對象與成員之間用.鏈接 #obj.field // 靜態對象的成員訪問,@開頭,對象與成員之間用@鏈接 @xxx@field // 基本對象的成員訪問,和非基本對象成員方式一致 "name".hash
ognl 針對經常使用的集合進行了特殊的支持
List
經過{}建立列表,經過[]來訪問對象下標的元素
下面表示建立一個列表,有三個元素: 1,2,3; 獲取列表中下標爲 2 的元素
{1, 2, 3}[2]
Arrays
數組,能夠結合 new 來使用
new int[] {1,2,3}
Map
#{k:v, k:v} 方式來建立 map
下面的語句,表示建立一個 map,並獲取其中 key 爲 name 的元素
#{ "name" : "一灰灰Blog", "age" : 18}["name"]
前面是一些簡單的,基本的成員訪問,方法調用,除此以外還存在更牛逼的用法,支持表達式的執行
成員賦值
#demo.name = "一灰灰blog"
表達式計算
500 + 20 - 30 * 3
三目運算符
"name".length() % 2 == 0 ? "偶數長度" : "奇數長度"
集合支持
針對集合作了一些簡化,方便調用
// in 語句,判斷列表中是否包含 "name" in {"name", "hello"} // 遍歷集合,獲取全部的偶數 {1,2,3,4,5,6}.{? #this % 2 == 0} // 遍歷集合,獲取第一個知足條件的元素 {1,2,3,4,5,6}.{^ #this % 2 == 0} // 遍歷集合,獲取最後一個知足條件的元素 {1,2,3,4,5,6}.{$ #this % 2 == 0}
對象建立
能夠直接經過 new 來建立一個對象,當咱們須要執行的目標方法的參數爲非基本類型時,可能會很是好用
// new + 完整的類名 new java.lang.String("hello world")
鏈式語句
什麼是鏈式語句呢?
有點相似設計模式中的 Builder 模式,我要執行一串的操做,最後獲取目標
定義規則以下,圓括號包裹起來,中間用逗號分隔,依次執行,最後一個爲須要返回的目標
(step1, step2,..., result)
結合上面的對象建立,能夠實現很是強大的功能
package git.hui; class User { public String name; public Integer age; }
直接建立一個可用的 User 對象,下面執行完畢以後,直接獲取一個屬性被初始化後的 User 對象
(#user=new git.hui.User(), #user.name="一灰灰Blog", #user.age=18, #user)
lambda 表達式
這個有點高端了,首先是定義 lambda 表達式,而後藉助前面的鏈式方式調用,下面是一個階乘的 case
#fact = :[#this<=1? 1 : #this*#fact(#this-1)], #fact(3)
一灰灰的我的博客,記錄全部學習和工做中的博文,歡迎你們前去逛逛
盡信書則不如,已上內容,純屬一家之言,因我的能力有限,不免有疏漏和錯誤之處,如發現 bug 或者有更好的建議,歡迎批評指正,不吝感激
一灰灰 blog
知識星球