Zhiqim Manager(知启蒙管理台)是知启蒙框架中最核心的基础组件,大部分后台组件和产品都依赖该组件。因为管理台提供了核心的系统配置、菜单、操作员、部门、角色等权限功能,以及6种皮肤样式可供选择

森中灵 最后提交于4月前 修复切换frame模式时未情况includeUrl
ZmrInterceptor.java4KB
/*
 * 版权所有 (C) 2015 知启蒙(ZHIQIM) 保留所有权利。[遇见知启蒙,邂逅框架梦]
 * 
 * https://zhiqim.org/project/zhiqim_components/zhiqim_manager.htm
 *
 * Zhiqim Manager is licensed under Mulan PSL v2.
 * You can use this software according to the terms and conditions of the Mulan PSL v2.
 * You may obtain a copy of Mulan PSL v2 at:
 *          http://license.coscl.org.cn/MulanPSL2
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 * See the Mulan PSL v2 for more details.
 */
package org.zhiqim.manager;

import org.zhiqim.httpd.HttpRequest;
import org.zhiqim.httpd.context.ZmlContexts;
import org.zhiqim.httpd.context.core.Interceptor;
import org.zhiqim.kernel.annotation.AnAlias;
import org.zhiqim.kernel.util.Strings;
import org.zhiqim.kernel.util.Validates;
import org.zhiqim.manager.dao.ZmrParamDao;

/**
 * 检查是否登录拦截器
 *
 * @version v1.0.0 @author zouzhigang 2015-5-28 新建与整理
 */
@AnAlias("chkZmrLogin")
public class ZmrInterceptor implements Interceptor, ZmrConstants
{
    private String mainUrl;
    
    public void intercept(HttpRequest request) throws Exception
    {
        if (mainUrl == null)
        {//主页地址
            this.mainUrl = ZmlContexts.parseZmlContent(request, ZMR_MAIN_URL_DEFAULT);
        }
        
        if (_PATH_SERVICE_AJAX_.equals(request.getPathInContext()))
        {//AJAX访问
            chkAjax(request);
        }
        else
        {//URL访问
            chkUrl(request);
        }
    }
    
    /** AJAX访问 */
    private void chkAjax(HttpRequest request) throws Exception
    {
        if (!request.isXMLHttpRequest())
        {
            request.setResponseError("您闲置太久或未登录,请重新登录后再操作...");
            return;
        }
        
        ZmrSessionUser sessionUser = request.getSessionUser(ZmrSessionUser.class);
        if (sessionUser == null)
        {//会话超时
            request.setResponseError("您闲置太久或未登录,请重新登录后再操作...");
            return;
        }
        
        String path = request.getPathInRMI();
        if (Validates.isEmpty(path))
        {//没有配置权限路径
            return;
        }
        
        path = ZmlContexts.parseZmlContent(request, path);
        if (!sessionUser.hasMenuRule(path))
        {//没有权限
            request.setResponseError("您没有该权限,请与管理员联系...");
            return;
        }
    }
    
    /** URL访问 */
    private void chkUrl(HttpRequest request)
    {
        ZmrSessionUser sessionUser = request.getSessionUser(ZmrSessionUser.class);
        if (sessionUser == null)
        {//会话超时
            request.setRedirectTop("/"+request.getContextAttributeString(ZMR_PATH)+"/logout.htm", "您闲置太久或未登录,正在返回初始界面,请确定.....");
            return;
        }
        
        String path = request.getPathInContext();
        if (sessionUser.hasAllRule(path))
        {//在所有菜单中的,要检查是否有权限
            if (!sessionUser.hasMenuRule(path))
            {//没有权限
                request.setRedirectTop("/"+request.getContextAttributeString(ZMR_PATH)+"/logout.htm", "您没有该权限,请与管理员联系...");
                return;
            }
        }
        
        if (!ZmrParamDao.isThemeFrame())
        {//非框架模式结束检查
            return;
        }

        if (!_GET_.equalsIgnoreCase(request.getMethod()) || !ZMR_TEMPLATE_MAIN.equals(request.getView()))
        {//非GET方法和没使用主模板的请求不处理
            return;
        }

        if (!Strings.endsWith(path, ".htm") && !Strings.endsWith(path, ".zml"))
        {//不是.htm/.zml结尾的不处理
            return;
        }
        
        if (mainUrl.equals(path) || "/manager/welcome.htm".equals(path))
        {//主页不处理
            return;
        }
        
        //其他认为是内部页,设置到会话中,以便F5刷新恢复
        sessionUser.setIncludeUrl(request.getRequestURI());
    }
}