3

我正在尝试从 grails 域对象中显示分页数据。例如:我有一个域对象 Employee,其属性 firstName 和 lastName 是瞬态的,当调用它们的 setter/getter 方法时,它们会加密/解密数据。数据以加密的二进制格式保存在数据库中,因此无法按这些字段排序。再一次,也不能按瞬态排序,如:http: //www.grails.org/GSP+Tag+-+sortableColumn中所述。

所以现在我正试图找到一种以类似于以下方式使用瞬变的方法:

Employee.withCriteria( max: 10, offset: 30 ){
    order 'lastName', 'asc'
    order 'firstName', 'asc'
} 

课程是:

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)       
}

}

4

1 回答 1

2

由于执行 GORM/hibernate 标准的方式,这不起作用。这些订单指令被翻译成 SQL 并且只能在非瞬态字段上操作,因为它发生在数据库层。

您的选择是:

  1. 将查询结果加载到内存中,并使用未加密的值自己进行排序和分页。
  2. 使用数据库的加密功能和自定义查询(例如“ select * from employee order by AES_DECRYPT(lastName, key)”)。请注意,这会给您的数据库带来大量额外负载。
  3. 以可用于排序的未加密形式存储某些内容。示例:lastName 的前几个字母。但是,这会泄露您试图保护的一些信息。
于 2010-03-12T17:30:34.237 回答