本文整理匯總了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);
}
示例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);
}
示例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);
}
示例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;
}
示例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;
}
示例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;
}
示例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;
}
示例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;
}
示例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);
// }
}
示例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());
}
示例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;
}
示例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);
// }
}
示例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;
}
示例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);
}
}
}
示例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());
}