我正在尝试显示 grails 域对象中的分页数据。例如: 我有一个域对象 Employee ,其属性firstName和lastName是 transient 的,当调用它们的setter/getter方法时,它们会加密/解密数据。数据以加密的二进制格式保存在数据库中,因此无法按这些字段排序。再说一遍,也不能按 transient 排序,如下所示: http://www.grails.org/GSP+Tag+-+sortableColumn .
所以现在我正在尝试找到一种以类似于以下方式使用 transient 的方法:
Employee.withCriteria( max: 10, offset: 30 ){
order 'lastName', 'asc'
order 'firstName', 'asc'
}
类(class)是:
class Employee {
byte[] encryptedFirstName
byte[] encryptedLastName
static transients = [
'firstName',
'lastName'
]
String getFirstName(){
decrypt("encryptedFirstName")
}
void setFirstName(String item){
encrypt("encryptedFirstName",item)
}
String getLastName(){
decrypt("encryptedLastName")
}
void setLastName(String item){
encrypt("encryptedLastName",item)
}
}
最佳答案
由于 GORM/hibernate 标准的执行方式,这是行不通的。这些订单指令被转换为 SQL,并且只能对非 transient 字段进行操作,因为它发生在数据库层。
您的选择是:
- 将查询结果加载到内存中,并使用未加密的值自行进行排序和分页。
- 使用数据库的加密功能和自定义查询(例如“
通过 AES_DECRYPT(lastName, key) 从员工订单中选择 *
”)。请注意,这会给您的数据库带来大量额外负载。 - 以未加密的形式存储可用于排序的内容。示例:姓氏的前几个字母。但是,这会泄露您试图确保安全的一些信息。
关于hibernate - 使用 transient 字段在 grails 中查询和排序数据库结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2433916/