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


Java WebUtils.issueRedirect方法代碼示例

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


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

示例1: onPreHandle

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
public boolean onPreHandle(ServletRequest request, ServletResponse response, Object mappedValue) throws Exception {
    if (this.isAccessAllowed(request, response, mappedValue) && this.isLoginRequest(request, response)) {
        if (((HttpServletRequest)request).getRequestURL().toString().endsWith(".json")){
            response.setCharacterEncoding("UTF-8");
            response.setContentType("application/json; charset=utf-8");
            PrintWriter out = response.getWriter();
            out.println("{\"code\":200,\"info\":\"already logined\"}");
            out.flush();
            out.close();
        }else {
            WebUtils.issueRedirect(request,response,this.getSuccessUrl());
        }
        return false;
    }
    return super.onPreHandle(request, response, mappedValue);
}
 
開發者ID:liaojiacan,項目名稱:zkAdmin,代碼行數:18,代碼來源:LoginFilter.java

示例2: issueSuccessRedirect

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
protected void issueSuccessRedirect(ServletRequest request, ServletResponse response)
		throws Exception {
	HttpServletRequest req = (HttpServletRequest) request;
	HttpServletResponse res = (HttpServletResponse) response;
	String successUrl = req.getParameter(RETURN_URL);
	if (StringUtils.isBlank(successUrl)) {
		if (req.getRequestURI().startsWith(
				req.getContextPath() + getAdminPrefix())) {
			// 後台直接返回首頁
			successUrl = getAdminIndex();
			// 清除SavedRequest
			WebUtils.getAndClearSavedRequest(request);
			WebUtils.issueRedirect(request, response, successUrl, null,true);
			return;
		} else {
			successUrl = getSuccessUrl();
		}
	}
	WebUtils.redirectToSavedRequest(req, res, successUrl);
}
 
開發者ID:huanzhou,項目名稱:jeecms6,代碼行數:21,代碼來源:CmsAuthenticationFilter.java

示例3: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws Exception {


    String error = request.getParameter("error");
    String errorDescription = request.getParameter("error_description");
    if(!StringUtils.isEmpty(error)) {//如果服務端返回了錯誤
        WebUtils.issueRedirect(request, response, failureUrl + "?error=" + error + "error_description=" + errorDescription);
        return false;
    }

    Subject subject = getSubject(request, response);
    if(!subject.isAuthenticated()) {
        if(StringUtils.isEmpty(request.getParameter(authcCodeParam))) {
            //如果用戶沒有身份驗證,且沒有auth code,則重定向到服務端授權
            saveRequestAndRedirectToLogin(request, response);
            return false;
        }
    }

    return executeLogin(request, response);
}
 
開發者ID:babymm,項目名稱:mumu,代碼行數:23,代碼來源:OAuth2AuthenticationFilter.java

示例4: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request,
		ServletResponse response) throws Exception {
	
		Subject subject = getSubject(request, response);  
        if (null == subject.getPrincipal()) {//表示沒有登錄,重定向到登錄頁麵  
            saveRequest(request);
            WebUtils.issueRedirect(request, response, ShiroUtils.LOGIN_URL);  
        } else {
    		if(ShiroUtils.isAjax(request)){
    			Map<String, Object> result = new HashMap<String, Object>();
    			result.put("status", "401");
    			result.put("message", "sorry,您沒有權限");
    			result.put("url", ShiroUtils.UNAUTHORIZED);
    			ShiroUtils.writeJson(response, result);
    		}else
    		{
    			if (StringUtils.hasText(ShiroUtils.UNAUTHORIZED)) {//如果有未授權頁麵跳轉過去  
	                WebUtils.issueRedirect(request, response, ShiroUtils.UNAUTHORIZED);  
	            } else {//否則返回401未授權狀態碼  
	                WebUtils.toHttp(response).sendError(HttpServletResponse.SC_UNAUTHORIZED);  
	            } 
    		}
        }  
	return Boolean.FALSE;
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:27,代碼來源:PermissionFilter.java

示例5: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request,
		ServletResponse response) throws Exception {
	//先退出
	Subject subject = getSubject(request, response);
	subject.logout();
	/**
	 * shiro保存上次請求地址:
	 * WebUtils.getSavedRequest(request);
	 * 然後在需要使用的地方:String url = WebUtils.getSavedRequest(request).getRequestUrl();
	 */
	//判斷是不是Ajax請求
	if (ShiroUtils.isAjax(request) ) {
		Map<String, Object> result = new HashMap<String, Object>();
		logger.debug("當前用戶已經被踢出,並且是Ajax請求!");
		result.put("status", "403");
		result.put("message", "您已經被踢出,請重新登錄!");
		result.put("url", ShiroUtils.LOGIN_URL);
		ShiroUtils.writeJson(response, result);
	}else
	{
		WebUtils.getSavedRequest(request);
		//再重定向
		WebUtils.issueRedirect(request, response, ShiroUtils.LOGIN_URL);
	}
	return false;
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:28,代碼來源:KickoutAuthFilter.java

示例6: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request,
		ServletResponse response) throws Exception {
	
		Subject subject = getSubject(request, response);  
        if (subject.getPrincipal() == null) {//表示沒有登錄,重定向到登錄頁麵  
            saveRequest(request);  
            WebUtils.issueRedirect(request, response, ShiroUtils.LOGIN_URL);  
        } else {  
        	if(ShiroUtils.isAjax(request)){
    			Map<String, Object> result = new HashMap<String, Object>();
    			result.put("status", "401");
    			result.put("message", "sorry,您沒有權限");
    			result.put("url", ShiroUtils.UNAUTHORIZED);
    			ShiroUtils.writeJson(response, result);
    		}else
    		{
    			if (StringUtils.hasText(ShiroUtils.UNAUTHORIZED)) {//如果有未授權頁麵跳轉過去  
	                WebUtils.issueRedirect(request, response, ShiroUtils.UNAUTHORIZED);  
	            } else {//否則返回401未授權狀態碼  
	                WebUtils.toHttp(response).sendError(HttpServletResponse.SC_UNAUTHORIZED);  
	            } 
    		}
        }  
	return false;
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:27,代碼來源:RoleFilter.java

示例7: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request,
		ServletResponse response) throws Exception {
   		if(ShiroUtils.isAjax(request)){
   			Map<String, Object> result = new HashMap<String, Object>();
   			result.put("status", "401");
   			result.put("message", "非法操作");
   			result.put("url", ShiroUtils.INDEX_URL);
   			ShiroUtils.writeJson(response, result);
   		}else
   		{
   			if (StringUtils.hasText(ShiroUtils.INDEX_URL)) {//如果有未授權頁麵跳轉過去  
                WebUtils.issueRedirect(request, response, ShiroUtils.INDEX_URL);
            } else {//否則返回401未授權狀態碼
                WebUtils.toHttp(response).sendError(HttpServletResponse.SC_UNAUTHORIZED);  
            } 
   		}
	return Boolean.FALSE;
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:20,代碼來源:URLFilter.java

示例8: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws Exception {
	log.debug("username[{}] SimpleAuthFilter denied,未登陸,跳轉到登陸頁麵");
	Subject subject = SecurityUtils.getSubject();
	subject.logout();
	/**
	 * 保存Request,用來保存當前Request,然後登錄後可以跳轉到當前瀏覽的頁麵. 比如:
	 * 我要訪問一個URL地址,/admin/index.html,這個頁麵是要登錄.然後要跳轉到登錄頁麵,但是登錄後要跳轉回來到/admin/
	 * index.html這個地址,怎麽辦?
	 * 傳統的解決方法是變成/user/login.shtml?redirectUrl=/admin/index.html.
	 * shiro的解決辦法不是這樣的.需要:<code>WebUtils.getSavedRequest(request);</code>
	 * 然後:{@link UserLoginController.submitLogin(...)}中的
	 * <code>String url = WebUtils.getSavedRequest(request).getRequestUrl();</code>
	 */
	WebUtils.saveRequest(request);
	// 再重定向
	WebUtils.issueRedirect(request, response, "/toLogin.htm");
	return false;
}
 
開發者ID:ls960972314,項目名稱:report,代碼行數:20,代碼來源:SimpleAuthFilter.java

示例9: issueSuccessRedirect

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
	protected void issueSuccessRedirect(ServletRequest request,
			ServletResponse response) throws Exception {
//		Principal p = UserUtils.getPrincipal();
//		if (p != null && !p.isMobileLogin()){
			 WebUtils.issueRedirect(request, response, getSuccessUrl(), null, true);
//		}else{
//			super.issueSuccessRedirect(request, response);
//		}
	}
 
開發者ID:whatlookingfor,項目名稱:spring-boot-sample,代碼行數:11,代碼來源:FormAuthenticationFilter.java

示例10: redirectToLogin

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
protected void redirectToLogin(ServletRequest request, ServletResponse response) throws IOException {  	
	if (isAjaxRequest((HttpServletRequest)request)) {
		response.setCharacterEncoding( Constants.BASE_ENCODING );
		response.setContentType("application/json");
		response.getWriter().write(Constants.NO_LOGIN_JSON_DATA);
		return;
	}
	if (this.isIframeMode((HttpServletRequest)request)) { // iframe 不要導向 login.action 因為畫麵會怪怪的    		
		WebUtils.issueRedirect(request, response, "/pages/system/error_static.jsp");
		return;
	}    	
	if (this.isDojoxContentPane((HttpServletRequest)request)) { // 在 dojox.layout.ContentPane 不要出現 login.action 頁麵    		
		WebUtils.issueRedirect(request, response, Constants.DOJOX_CONTENT_PANE_XHR_RE_LOGIN_PAGE);
		return;
	}
	WebUtils.issueRedirect(request, response, getLoginUrl());
}
 
開發者ID:billchen198318,項目名稱:bamboobsc,代碼行數:18,代碼來源:GreenStepMobileFormAuthenticationFilter.java

示例11: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws Exception {
    getSubject(request, response).logout();
    String loginUrl = getLoginUrl() + (getLoginUrl().contains("?") ? "&" : "?") + "forceLogout=1";
    WebUtils.issueRedirect(request, response, loginUrl);
    return false;
}
 
開發者ID:youngMen1,項目名稱:-Spring-SpringMVC-Mybatis-,代碼行數:8,代碼來源:UpmsSessionForceLogoutFilter.java

示例12: issueSuccessRedirect

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void issueSuccessRedirect(ServletRequest request, ServletResponse response) throws Exception {
    // Principal p = UserUtils.getPrincipal();
    // if (p != null && !p.isMobileLogin()){
    WebUtils.issueRedirect(request, response, getSuccessUrl(), null, true);
    // }else{
    // super.issueSuccessRedirect(request, response);
    // }
}
 
開發者ID:ansafari,項目名稱:melon,代碼行數:10,代碼來源:FormAuthenticationFilter.java

示例13: onAccessDenied

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
/**
 * Redirects the request to the same exact incoming URL, but with the port listed in the filter's configuration.
 *
 * @param request     the incoming <code>ServletRequest</code>
 * @param response    the outgoing <code>ServletResponse</code>
 * @param mappedValue the config specified for the filter in the matching request's filter chain.
 * @return {@code false} always to force a redirect.
 */
@Override
protected boolean onAccessDenied(ServletRequest request, ServletResponse response, Object mappedValue) throws IOException {

    //just redirect to the specified port:
    int port = toPort(mappedValue);

    String scheme = getScheme(request.getScheme(), port);

    StringBuilder sb = new StringBuilder();
    sb.append(scheme).append("://");
    sb.append(request.getServerName());
    if (port != DEFAULT_HTTP_PORT && port != SslFilter.DEFAULT_HTTPS_PORT) {
        sb.append(":");
        sb.append(port);
    }
    if (request instanceof HttpServletRequest) {
        sb.append(WebUtils.toHttp(request).getRequestURI());
        String query = WebUtils.toHttp(request).getQueryString();
        if (query != null) {
            sb.append("?").append(query);
        }
    }

    WebUtils.issueRedirect(request, response, sb.toString());

    return false;
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:36,代碼來源:PortFilter.java

示例14: redirectToLogin

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
@Override
protected void redirectToLogin(ServletRequest request, ServletResponse response) throws IOException {
    PrintWriter printWriter = null;
    try {
        String loginUrl = getLoginUrl();
        //ajax請求
        HttpServletRequest httpServletRequest = WebUtils.toHttp(request);
        HttpServletResponse httpServletResponse = WebUtils.toHttp(response);
        if ("XMLHttpRequest".equalsIgnoreCase(httpServletRequest.getHeader("X-Requested-With"))) {
            httpServletResponse.setContentType("text/json; charset=utf-8");
            Map<String, Object> json = new HashMap<String, Object>();
            json.put("status", HttpServletResponse.SC_PROXY_AUTHENTICATION_REQUIRED);
            json.put("message", "Authentication fail");
            httpServletResponse.setStatus(HttpServletResponse.SC_PROXY_AUTHENTICATION_REQUIRED);
            printWriter = httpServletResponse.getWriter();
            printWriter.write(JsonUtils.toJsonString(json));
        } else {
            WebUtils.issueRedirect(request, response, loginUrl);
        }
    } finally {
        try {
            if (printWriter != null) {
                printWriter.close();
            }
            response.flushBuffer();
        } catch (IOException e) {
            logger.warn(e.getMessage(), e);
        }
    }
}
 
開發者ID:xuegongzi,項目名稱:rabbitframework,代碼行數:31,代碼來源:FormAuthcFilter.java

示例15: redirectToLogin

import org.apache.shiro.web.util.WebUtils; //導入方法依賴的package包/類
protected void redirectToLogin(ServletRequest request, ServletResponse response) throws IOException {
 	if ( !Constants.getSystem().equals( Constants.getMainSystem() ) && !isAjaxRequest((HttpServletRequest)request) ) { // 非 core-web
 		try {
	if ( this.loginUseCurrentCookieForGeneralPackage(request, response) ) { // no need to login-page
		String url = SimpleUtils.getHttpRequestUrl( (HttpServletRequest)request );
		logger.warn("URL = " + url );					
		WebUtils.issueRedirect(request, response, url);
		return;
	}
} catch (Exception e) {
	e.printStackTrace();
}
 	}    	
 	if (isAjaxRequest((HttpServletRequest)request)) {
 		response.setCharacterEncoding( Constants.BASE_ENCODING );
 		response.setContentType("application/json");
 		response.getWriter().write(Constants.NO_LOGIN_JSON_DATA);
 		return;
 	}
 	if (this.isIframeMode((HttpServletRequest)request)) { // iframe 不要導向 login.action 因為畫麵會怪怪的    		
 		WebUtils.issueRedirect(request, response, "/pages/system/error_static.jsp");
 		return;
 	}    	
 	if (this.isDojoxContentPane((HttpServletRequest)request)) { // 在 dojox.layout.ContentPane 不要出現 login.action 頁麵    		
 		WebUtils.issueRedirect(request, response, Constants.DOJOX_CONTENT_PANE_XHR_RE_LOGIN_PAGE);
 		return;
 	}
 	WebUtils.issueRedirect(request, response, getLoginUrl());
 }
 
開發者ID:billchen198318,項目名稱:bamboobsc,代碼行數:30,代碼來源:GreenStepBaseFormAuthenticationFilter.java


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