当前位置: 首页>>代码示例>>Java>>正文


Java ContextHolder.setContext方法代码示例

本文整理汇总了Java中net.sf.acegisecurity.context.ContextHolder.setContext方法的典型用法代码示例。如果您正苦于以下问题:Java ContextHolder.setContext方法的具体用法?Java ContextHolder.setContext怎么用?Java ContextHolder.setContext使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在net.sf.acegisecurity.context.ContextHolder的用法示例。


在下文中一共展示了ContextHolder.setContext方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: getUserDetails

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
/**
 * We actually have an acegi object so override the default method.
 */
@Override
protected UserDetails getUserDetails(String userName)
{
    if (AuthenticationUtil.isMtEnabled())
    {
        // ALF-9403 - "manual" runAs to avoid clearing ticket, eg. when called via "validate" (->setCurrentUser->CheckCurrentUser)
        Authentication originalFullAuthentication = AuthenticationUtil.getFullAuthentication();
        try
        {
            if (originalFullAuthentication == null)
            {
                AuthenticationUtil.setFullyAuthenticatedUser(getSystemUserName(getUserDomain(userName)));
            }
            return authenticationDao.loadUserByUsername(userName);
        }
        finally
        {
            if (originalFullAuthentication == null)
            {
                ContextHolder.setContext(null); // note: does not clear ticket (unlike AuthenticationUtil.clearCurrentSecurityContext())
            }
        }
    }
    else
    {
        return authenticationDao.loadUserByUsername(userName);
    }
}
 
开发者ID:Alfresco,项目名称:alfresco-repository,代码行数:32,代码来源:AuthenticationComponentImpl.java

示例2: setFullAuthentication

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
/**
 * Re-authenticate using a previously-created authentication.
 */
public static Authentication setFullAuthentication(Authentication authentication)
{
    if (authentication == null)
    {
        clearCurrentSecurityContext();
        return null;
    }
    else
    {
        if (s_logger.isDebugEnabled())
            s_logger.debug("Setting fully authenticated principal: " + authentication.getName());
        Context context = ContextHolder.getContext();
        AlfrescoSecureContext sc = null;
        if ((context == null) || !(context instanceof AlfrescoSecureContext))
        {
            if (s_logger.isDebugEnabled())
                s_logger.debug("Creating new secure context.");
            sc = new AlfrescoSecureContextImpl();
            ContextHolder.setContext(sc);
        }
        else
        {
            sc = (AlfrescoSecureContext) context;
        }
        authentication.setAuthenticated(true);
        // Sets real and effective
        sc.setRealAuthentication(authentication);
        sc.setEffectiveAuthentication(authentication);
        return authentication;
    }
}
 
开发者ID:Alfresco,项目名称:alfresco-data-model,代码行数:35,代码来源:AuthenticationUtil.java

示例3: setRunAsAuthentication

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
static Authentication setRunAsAuthentication(Authentication authentication)
{
    if (authentication == null)
    {
        clearCurrentSecurityContext();
        return null;
    }
    else
    {
        if (s_logger.isDebugEnabled())
            s_logger.debug("Setting RunAs principal: " + authentication.getName());
        Context context = ContextHolder.getContext();
        AlfrescoSecureContext sc = null;
        if ((context == null) || !(context instanceof AlfrescoSecureContext))
        {
            if (s_logger.isDebugEnabled())
                s_logger.debug("Creating new secure context.");
            sc = new AlfrescoSecureContextImpl();
            ContextHolder.setContext(sc);
        }
        else
        {
            sc = (AlfrescoSecureContext) context;
        }
        authentication.setAuthenticated(true);
        if (sc.getRealAuthentication() == null)
        {
            if (s_logger.isDebugEnabled())
                s_logger.debug("There is no fully authenticated prinipal. Setting fully authenticated principal: " + authentication.getName());
            sc.setRealAuthentication(authentication);
        }
        sc.setEffectiveAuthentication(authentication);
        return authentication;
    }
}
 
开发者ID:Alfresco,项目名称:alfresco-data-model,代码行数:36,代码来源:AuthenticationUtil.java

示例4: clearCurrentSecurityContext

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
/**
 * Remove the current security information
 */
public static void clearCurrentSecurityContext()
{
    if (s_logger.isDebugEnabled())
        s_logger.debug("Removing the current security information.");
    ContextHolder.setContext(null);
    InMemoryTicketComponentImpl.clearCurrentSecurityContext();
    
    NDC.remove();
    
    TenantContextHolder.clearTenantDomain();
}
 
开发者ID:Alfresco,项目名称:alfresco-data-model,代码行数:15,代码来源:AuthenticationUtil.java

示例5: clearCurrentSecurityContext

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
public void clearCurrentSecurityContext()
{
    ContextHolder.setContext(null);
}
 
开发者ID:Alfresco,项目名称:alfresco-repository,代码行数:5,代码来源:TestAuthenticationServiceImpl.java

示例6: afterPhase

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
@Override
public void afterPhase(PhaseEvent phaseevent)
{
    ContextHolder.setContext(null);
}
 
开发者ID:Alfresco,项目名称:community-edition-old,代码行数:6,代码来源:SecurityContextCleanupPhaseListener.java

示例7: doFilter

import net.sf.acegisecurity.context.ContextHolder; //导入方法依赖的package包/类
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException
{
    ContextHolder.setContext(null);
    chain.doFilter(servletRequest, servletResponse);
}
 
开发者ID:Alfresco,项目名称:community-edition-old,代码行数:7,代码来源:CmisSecurityContextCleanerFilter.java


注:本文中的net.sf.acegisecurity.context.ContextHolder.setContext方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。