當前位置: 首頁>>代碼示例>>Java>>正文


Java WebUtils.getHttpResponse方法代碼示例

本文整理匯總了Java中org.apache.shiro.web.util.WebUtils.getHttpResponse方法的典型用法代碼示例。如果您正苦於以下問題:Java WebUtils.getHttpResponse方法的具體用法?Java WebUtils.getHttpResponse怎麽用?Java WebUtils.getHttpResponse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.shiro.web.util.WebUtils的用法示例。


在下文中一共展示了WebUtils.getHttpResponse方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: onStart

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Stores the Session's ID, usually as a Cookie, to associate with future requests.
 *
 * @param session the session that was just {@link #createSession created}.
 */
@Override
protected void onStart(Session session, SessionContext context) {
    super.onStart(session, context);

    if (!WebUtils.isHttp(context)) {
        log.debug("SessionContext argument is not HTTP compatible or does not have an HTTP request/response " +
                "pair. No session ID cookie will be set.");
        return;

    }
    HttpServletRequest request = WebUtils.getHttpRequest(context);
    HttpServletResponse response = WebUtils.getHttpResponse(context);

    if (isSessionIdCookieEnabled()) {
        Serializable sessionId = session.getId();
        storeSessionId(sessionId, request, response);
    } else {
        log.debug("Session ID cookie is disabled.  No cookie has been set for new session with id {}", session.getId());
    }

    request.removeAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE);
    request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_IS_NEW, Boolean.TRUE);
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:29,代碼來源:DefaultWebSessionManager.java

示例2: rememberSerializedIdentity

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Base64-encodes the specified serialized byte array and sets that base64-encoded String as the cookie value.
 * <p/>
 * The {@code subject} instance is expected to be a {@link WebSubject} instance with an HTTP Request/Response pair
 * so an HTTP cookie can be set on the outgoing response.  If it is not a {@code WebSubject} or that
 * {@code WebSubject} does not have an HTTP Request/Response pair, this implementation does nothing.
 *
 * @param subject    the Subject for which the identity is being serialized.
 * @param serialized the serialized bytes to be persisted.
 */
protected void rememberSerializedIdentity(Subject subject, byte[] serialized) {

    if (!WebUtils.isHttp(subject)) {
        if (log.isDebugEnabled()) {
            String msg = "Subject argument is not an HTTP-aware instance.  This is required to obtain a servlet " +
                    "request and response in order to set the rememberMe cookie. Returning immediately and " +
                    "ignoring rememberMe operation.";
            log.debug(msg);
        }
        return;
    }


    HttpServletRequest request = WebUtils.getHttpRequest(subject);
    HttpServletResponse response = WebUtils.getHttpResponse(subject);

    //base 64 encode it and store as a cookie:
    String base64 = Base64.encodeToString(serialized);

    Cookie template = getCookie(); //the class attribute is really a template for the outgoing cookies
    Cookie cookie = new SimpleCookie(template);
    cookie.setValue(base64);
    cookie.saveTo(request, response);
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:35,代碼來源:CookieRememberMeManager.java

示例3: rememberSerializedIdentity

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void rememberSerializedIdentity(Subject subject, byte[] serialized) {
    if (!WebUtils.isHttp(subject)) {
        if (LOGGER.isDebugEnabled()) {
            String msg = "Subject argument is not an HTTP-aware instance.  This is required to obtain a servlet " +
                    "request and response in order to set the rememberMe cookie. Returning immediately and " +
                    "ignoring rememberMe operation.";
            LOGGER.debug(msg);
        }
        
        return;
    }


    HttpServletRequest request = WebUtils.getHttpRequest(subject);
    HttpServletResponse response = WebUtils.getHttpResponse(subject);

    // base 64 encode it and store as a cookie:
    String base64 = Base64.encodeToString(serialized);

    // the class attribute is really a template for the outgoing cookies
    Cookie cookie = getCookie(); 
    cookie.setValue(base64);
    cookie.saveTo(request, response);
}
 
開發者ID:nano-projects,項目名稱:nano-framework,代碼行數:26,代碼來源:CookieRememberMeManager.java

示例4: onStart

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void onStart(final Session session, final SessionContext context) {
    if (!WebUtils.isHttp(context)) {
        LOGGER.debug("SessionContext argument is not HTTP compatible or does not have an HTTP request/response " +
                "pair. No session ID cookie will be set.");
        return;
    }
    
    final HttpServletRequest request = WebUtils.getHttpRequest(context);
    final HttpServletResponse response = WebUtils.getHttpResponse(context);

    if (isSessionIdCookieEnabled()) {
        final Serializable sessionId = session.getId();
        storeSessionId(sessionId, request, response);
    } else {
        LOGGER.debug("Session ID cookie is disabled.  No cookie has been set for new session with id {}", session.getId());
    }

    request.removeAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE);
    request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_IS_NEW, Boolean.TRUE);
}
 
開發者ID:nano-projects,項目名稱:nano-framework,代碼行數:22,代碼來源:DefaultWebSessionManager.java

示例5: onStop

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void onStop(Session session, SessionKey key) {
    super.onStop(session, key);
    if (WebUtils.isHttp(key)) {
        HttpServletRequest request = WebUtils.getHttpRequest(key);
        HttpServletResponse response = WebUtils.getHttpResponse(key);
        log.debug("Session has been stopped (subject logout or explicit stop).  Removing session ID cookie.");
        removeSessionIdCookie(request, response);
    } else {
        log.debug("SessionKey argument is not HTTP compatible or does not have an HTTP request/response " +
                "pair. Session ID cookie will not be removed due to stopped session.");
    }
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:14,代碼來源:DefaultWebSessionManager.java

示例6: onStart

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Stores the Session's ID, usually as a Cookie, to associate with future
 * requests.
 *
 * @param session
 *            the session that was just {@link #createSession created}.
 */
@Override
protected void onStart(Session session, SessionContext context) {
	super.onStart(session, context);

	if (!WebUtils.isHttp(context)) {
		log.debug("SessionContext argument is not HTTP compatible or does not have an HTTP request/response "
				+ "pair. No session ID cookie will be set.");
		return;

	}
	HttpServletRequest request = WebUtils.getHttpRequest(context);
	HttpServletResponse response = WebUtils.getHttpResponse(context);

	if (isSessionIdCookieEnabled()) {
		Serializable sessionId = session.getId();
		if (sessionId != null) {
			storeSessionId(sessionId, request, response);
		}
	} else {
		log.debug("Session ID cookie is disabled.  No cookie has been set for new session with id {}",
				session.getId());
	}

	request.removeAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_ID_SOURCE);
	request.setAttribute(ShiroHttpServletRequest.REFERENCED_SESSION_IS_NEW, Boolean.TRUE);
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:34,代碼來源:SimpleWebSessionManager.java

示例7: onStop

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void onStop(Session session, SessionKey key) {
	super.onStop(session, key);
	if (WebUtils.isHttp(key)) {
		HttpServletRequest request = WebUtils.getHttpRequest(key);
		HttpServletResponse response = WebUtils.getHttpResponse(key);
		log.debug("Session has been stopped (subject logout or explicit stop).  Removing session ID cookie.");
		removeSessionIdCookie(request, response);
	} else {
		log.debug("SessionKey argument is not HTTP compatible or does not have an HTTP request/response "
				+ "pair. Session ID cookie will not be removed due to stopped session.");
	}
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:14,代碼來源:SimpleWebSessionManager.java

示例8: getRememberedSerializedIdentity

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Returns a previously serialized identity byte array or {@code null} if the byte array could not be acquired.
 * This implementation retrieves an HTTP cookie, Base64-decodes the cookie value, and returns the resulting byte
 * array.
 * <p/>
 * The {@code SubjectContext} instance is expected to be a {@link WebSubjectContext} instance with an HTTP
 * Request/Response pair so an HTTP cookie can be retrieved from the incoming request.  If it is not a
 * {@code WebSubjectContext} or that {@code WebSubjectContext} does not have an HTTP Request/Response pair, this
 * implementation returns {@code null}.
 *
 * @param subjectContext the contextual data, usually provided by a {@link Subject.Builder} implementation, that
 *                       is being used to construct a {@link Subject} instance.  To be used to assist with data
 *                       lookup.
 * @return a previously serialized identity byte array or {@code null} if the byte array could not be acquired.
 */
protected byte[] getRememberedSerializedIdentity(SubjectContext subjectContext) {

    if (!WebUtils.isHttp(subjectContext)) {
        if (log.isDebugEnabled()) {
            String msg = "SubjectContext argument is not an HTTP-aware instance.  This is required to obtain a " +
                    "servlet request and response in order to retrieve the rememberMe cookie. Returning " +
                    "immediately and ignoring rememberMe operation.";
            log.debug(msg);
        }
        return null;
    }

    WebSubjectContext wsc = (WebSubjectContext) subjectContext;
    if (isIdentityRemoved(wsc)) {
        return null;
    }

    HttpServletRequest request = WebUtils.getHttpRequest(wsc);
    HttpServletResponse response = WebUtils.getHttpResponse(wsc);

    String base64 = getCookie().readValue(request, response);
    // Browsers do not always remove cookies immediately (SHIRO-183)
    // ignore cookies that are scheduled for removal
    if (Cookie.DELETED_COOKIE_VALUE.equals(base64)) return null;

    if (base64 != null) {
        base64 = ensurePadding(base64);
        if (log.isTraceEnabled()) {
            log.trace("Acquired Base64 encoded identity [" + base64 + "]");
        }
        byte[] decoded = Base64.decode(base64);
        if (log.isTraceEnabled()) {
            log.trace("Base64 decoded byte array length: " + (decoded != null ? decoded.length : 0) + " bytes.");
        }
        return decoded;
    } else {
        //no cookie set - new site visitor?
        return null;
    }
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:56,代碼來源:CookieRememberMeManager.java

示例9: forgetIdentity

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Removes the 'rememberMe' cookie from the associated {@link WebSubject}'s request/response pair.
 * <p/>
 * The {@code subject} instance is expected to be a {@link WebSubject} instance with an HTTP Request/Response pair.
 * If it is not a {@code WebSubject} or that {@code WebSubject} does not have an HTTP Request/Response pair, this
 * implementation does nothing.
 *
 * @param subject the subject instance for which identity data should be forgotten from the underlying persistence
 */
protected void forgetIdentity(Subject subject) {
    if (WebUtils.isHttp(subject)) {
        HttpServletRequest request = WebUtils.getHttpRequest(subject);
        HttpServletResponse response = WebUtils.getHttpResponse(subject);
        forgetIdentity(request, response);
    }
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:17,代碼來源:CookieRememberMeManager.java


注:本文中的org.apache.shiro.web.util.WebUtils.getHttpResponse方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。