我正在做一个简单的小grails应用程序,并决定使用Shiro进行注册/安全,但遇到了一个(可能很愚蠢的)问题。

我生成了User(和Realm)类,然后将User扩展为与Posts具有一对多关联(即,用户可以编写例如博客条目)。但是,如何从Shiro主题获取Domain对象?

我尝试了以下方法:

def currentUser = SecurityUtils.getSubject()
def posts = Post.findByUser(currentUser)

但这给了我:“消息:找不到能够将org.apache.shiro.web.subject.support.WebDelegatingSubject类型转换为com.lordfoom.challengetrackr.User类型的转换器”

域类如下:
class User {
    String username
    String passwordHash

    static hasMany = [ roles: Role, permissions: String, posts: Post ]

    static constraints = {
        username(nullable: false, blank: false, unique: true)
    }
}



class Post {

    String title;
    String body;

    static belongsTo = [user:User]
    static constraints = {
        title(nullable:false, blank: false, unique: true)
        user(unique:true)
    }
}

有没有一种简单的方法可以从Shiro Subject到当前登录的用户的域对象?还是我必须以某种方式查找它?

任何帮助表示赞赏。

最佳答案

如果我正确理解了这一点,那么您只想为当前登录的用户检索用户对象,是吗?

我通常实现此目的的方法是设置包含两个方法的UserService。然后,我可以在整个应用程序中实现getLocalUser()。

import org.apache.shiro.SecurityUtils

class UserService {
    /**
     * for currently logged in user
     */
    def getLocalUserId(){
        def userName  = SecurityUtils.subject?.principal
        User.findByUsername(userName)
    }

    User getLocalUser(){
        getLocalUserId()
    }
}

希望这可以帮助。

关于java - 从Shiro主题获取grails域对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/22918311/

10-13 02:07