Portal_membership.getAuthenticatedUser、portal_state.member 等.. 始终在 View 对象的 __init__ 和 publicTraversal 上返回匿名

发布于 2024-12-17 19:07:13 字数 331 浏览 1 评论 0原文

我正在制作一个带有自定义遍历的视图。我想根据当前登录的用户动态遍历到下一个对象。但我知道的所有方法(portal_membership.getAuthenticatedUser、portal_state.member 等)始终在 View 对象的 __init__publicTraversal 上返回匿名。它们正确返回的唯一情况是在对象的 __call__ 中。

我应该怎么做才能使 getAuthenticatedUser 对我的案例起作用(在视图的 __init__publicTraversal 调用上)?

I'm making a View with customized traversal. I want to traverse to next object dynamically base on current logged in user. But all method I know (portal_membership.getAuthenticatedUser, portal_state.member etc..) always return anonymous on View object's __init__ and publicTraversal. The only case they return right is in object's __call__.

What should I do to make getAuthenticatedUser work on my case (either on view's __init__ or publicTraversal call)?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

当梦初醒 2024-12-24 19:07:13

你不能。由于 Zope 的安全模型,用户是在遍历之后确定的,因为此信息取决于已发布对象的上下文。

您只能在发布对象时依赖 getAuthenticatedUser;遍历之后进行认证授权,然后发布,这在视图中意味着调用__call__方法。

由于 publicTraversal 是作为遍历阶段的一部分调用的,因此您也无法知道该方法中经过身份验证的用户。您必须重新考虑您的观点,不要依赖于该阶段已知的经过身份验证的用户。

You can't. Due to Zope's security model, the user is determined after traversal, because this information depends on the context of the published object.

You can only rely on getAuthenticatedUser when the object is being published; after traversal, authentication and authorization take place, and then publication, which in views means invoking the __call__ method.

Because publicTraversal is called as part of the traversal stage, you cannot know the authenticated user in that method either. You'll have to re-think your view to not rely on the authenticated user being known during that stage.

柠檬心 2024-12-24 19:07:13

您不应该在 browser:view 的 __init__ 中执行任何操作,主要是因为您无法确定所有环境都已设置。值得注意的是,在您的情况下,您可以通过使用 __call__ 方法中的相同方法而不是 __init__ 中的相同方法来解决您的问题

You shouldn't do anything in the __init__ of your browser:view mainly because you cannot be sure that all the environment has been set up. Notably in your case, you can solve your issue by using the same methods in the __call__ method instead that in the __init__

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文