gpt4 book ai didi

java - Wildfly 15 从 jax rs 登录用户获取 Singleton 中的 EJBContext

转载 作者:行者123 更新时间:2023-11-30 05:49:23 27 4
gpt4 key购买 nike

我想从登录用户获取单例中的调用者主体。用户正在使用用户名/密码对其余服务进行身份验证

安全域在war中的jboss-web.xml中

<security-domain>application-security</security-domain>

war 的终点是:

@Path("/message/{message}")
public class MyRessource
{
@EJB
MySingleton singletonBean;

@GET
public Response resource(@PathParam("message") String message)
{
singletonBean.printText(message);
System.out.println("called from: " + ctx.getUserPrincipal().getName());
}

单例位于自己的项目中,并在 war 中作为依赖项提供。

@Stateless
public class MySingletonBean implements MySingleton
{

@Resource
EJBContext context;

@Resource
SessionContext ctx;

public void printText(String text) {
System.out.println(text + ":: EJBContext: " + context.getCallerPrincipal().getName() + " SessionContext: " + ctx.getCallerPrincipal().getName());
}

}

我的 web.xml:

<web-app>
<security-role>
<role-name>Admin</role-name>
</security-role>

<security-constraint>
<web-resource-collection>
<url-pattern>/*</url-pattern>
<http-method-omission>OPTIONS</http-method-omission>
</web-resource-collection>
<auth-constraint>
<role-name>Admin</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
</web-app>

独立-full-ha.xml

<subsystem xmlns="urn:wildfly:elytron:5.0" ...>
[...]
<security-domain name="application-security" default-realm="application-properties" permission-mapper="default-permission-mapper">
<realm name="application-properties"/>
</security-domain>
[...]
</subsystem>
[...]

<http-authentication-factory name="application-security-http" security-domain="application-security" http-server-mechanism-factory="global">
<mechanism-configuration>
<mechanism mechanism-name="BASIC"/>
</mechanism-configuration>
</http-authentication-factory>
[...]

<security-domains>
<security-domain name="application-security" default-realm="application-properties" permission-mapper="default-permission-mapper">
<realm name="application-properties"/>
</security-domain>
[...]
</security-domains>
[...]

<subsystem xmlns="urn:jboss:domain:security:2.0">
<security-domains>
<security-domain name="application-security">
<authentication>
<login-module code="UsersRoles" flag="required">
<module-option name="usersProperties" value="file://${jboss.server.config.dir}/context-users.properties"/>
<module-option name="rolesProperties" value="file://${jboss.server.config.dir}/context-roles.properties"/>
</login-module>
</authentication>
</security-domain>
[...]
</subsystem>
[...]

<subsystem xmlns="urn:boss:domain:undertow"...>
<application-security-domains>
<application-security-domain name="application-security" http-authentication-factory="application-security-http"/>
</application-security-domains>
[...]
</subsystem>

但作为校长我总是匿名。

我做错了什么?

最佳答案

您在这里至少遇到三个问题:

  1. <subsystem xmlns="urn:jboss:domain:security:2.0">是一个旧配置元素,不与 elytron 连接;

  2. 您完全缺少 ejb3 安全配置;

  3. 您的 EJB 方法不受 @RolesAllowed(...) 的保护.

我有一个类似的例子:

  1. 创建一个elytron属性领域:

    /subsystem=elytron/properties-realm=DemoPropsRealm:add(groups-attribute=groups,\
    groups-properties={\
    path=demo-roles.properties,relative-to=jboss.server.config.dir},\
    users-properties={\
    path=demo-users.properties,relative-to=jboss.server.config.dir,plain-text=true})
  2. 创建elytron安全域:

    /subsystem=elytron/security-domain=DemoDomain:add(\
    realms=[{realm=DemoPropsRealm,role-decoder=groups-to-roles}],\
    default-realm=DemoPropsRealm,permission-mapper=default-permission-mapper)
  3. 创建映射到我们的 DemoDomain 的 elytron http 身份验证工厂:

    /subsystem=elytron/http-authentication-factory=demo-http-auth:add(\
    http-server-mechanism-factory=global,\
    security-domain=DemoDomain,\
    mechanism-configurations=[{\
    mechanism-name=BASIC,\
    mechanism-realm-configurations=[{\
    realm-name=DemoApplicationDomain\
    }]\
    }])
  4. ejb3 子系统应用程序安全域映射到我们的 DemoDomain

    /subsystem=ejb3/application-security-domain=\
    DemoApplicationDomain:add(security-domain=DemoDomain)
  5. undertow 子系统应用程序安全域链接到我们的 http-authentication-factory:

    /subsystem=undertow/application-security-domain=\
    DemoApplicationDomain:add(http-authentication-factory=demo-http-auth)

    “DemoApplicationDomain”将是 login-config 中的领域名称web.xml 的元素和 security-domain在 jboss-web.xml 文件中。

  6. 声明 EJB 方法上允许的角色:

    @RolesAllowed("Admin")
    public void printText(String text) {
    System.out.println(text + ":: EJBContext: " + context.getCallerPrincipal().getName()
    + " SessionContext: " + ctx.getCallerPrincipal().getName());
    }

示例源代码位于 GitHub jax-rs-basic-auth .

关于java - Wildfly 15 从 jax rs 登录用户获取 Singleton 中的 EJBContext,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54219391/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com