我正在使用spring-security-acl插件實現ACL安全性。我有以下域類:使用Grails安全ACL過濾選擇下拉菜單
package test
class Subitem {
String name
static belongsTo = [employer: Employer]
static constraints = {
name blank: false
}
}
package test
class Employer {
String name
static hasMany = [users: User, items: Subitem]
static belongsTo = User
static constraints = {
name blank: false, unique: true
}
String toString() {
name
}
}
在其用於創建一個子項的create.gsp文件中,有下面的語句:
<g:select id="employer" name="employer.id" from="${test.Employer.list()}" optionKey="id" required="" value="${subitemInstance?.employer?.id}" class="many-to-one"/>
從EmployerController:
def list = {
params.max = Math.min(params.max ? params.int('max') : 10, 100)
[employerInstanceList: employerService.list(params),
employerInstanceTotal: employerService.count()]
}
按照給出的教程here,我已將一些與僱主打交道的功能轉移到名爲EmployerService的服務:
@PreAuthorize("hasRole('ROLE_USER')")
@PostFilter("hasPermission(filterObject, read)")
List<Employer> list(Map params) {
Employer.list params
}
int count() {
Employer.count()
}
使用ACL限制訪問任何給定僱主類實例中的信息。目前,我可以在下拉列表中看到數據庫中所有Employer實例,我假設這是因爲我使用的是控制器列表(),而不是服務列表() - 但是,我只想查看過濾列表的僱主領域類。但是,如果我更換G:選擇具有:
<g:select id="employer" name="employer.id" from="${test.EmployerService.list()}" optionKey="id" required="" value="${subitemInstance?.employer?.id}" class="many-to-one"/>
然後我得到一個內部服務器錯誤,因爲我沒有通過一個地圖參數的服務列表()函數(我不知道如何標籤內),這樣做:
URI /security/subitem/create
Class groovy.lang.MissingMethodException
Message No signature of method: static test.EmployerService.list() is applicable for argument types:() values: [] Possible solutions: list(java.util.Map), is(java.lang.Object), wait(), find(), wait(long), get(long)
我只希望看到來自EmployerService list()函數的信息 - 我怎麼做到這一點嗎?我如何從差距中引用正確的功能?
- 編輯08年3月16日:謝謝@OverZealous,這真的很有幫助,我沒有意識到這一點。但是,我已經嘗試過,仍然遇到同樣的問題。我在Employer和EmployerService list()函數中都放了一個println()語句,並且可以看到,在解析g:select標籤時,實際上似乎都沒有調用過(即使我離開g:select來引用僱主)。是否有另一個版本的list()函數可能被調用?或者如何獲得g:select來考慮ACL?
非常感謝,我不知道!然而,似乎g:select調用list()函數的方式還有一個更深層次的問題 - 請參閱上面的編輯問題。 – John 2012-03-16 08:40:41