码迷,mamicode.com
首页 > 其他好文 > 详细

jfinal通过拦截器判断不同浏览器返回不同结果页面

时间:2015-08-31 19:57:06      阅读:299      评论:0      收藏:0      [点我收藏+]

标签:

  1. 目的

    前端做了两套页面,一套PC ,一套手机,我想通过程序控制返回的页面,而Controller不需要关心终端,只需要render固定的字符串。

  2. 思路方法

    拦截器拦截到render,然后修改viewpath

  3. 实现

    关键代码


public class AppConst {
    public static Routes SYSTEM_ROUTES = null ;
}

public class CmsConfig extends JFinalConfig {
    public void configConstant(Constants constants) {

        ConfigUtil.loadConfig(loadPropertyFile("application-test.properties", "application.properties", Const.DEFAULT_ENCODING));

        constants.setBaseViewPath("/WEB-INF/page");
    }
    
    public void configInterceptor(Interceptors interceptors) {
    interceptors.add(new RenderSwitchInterceptor());
}
}
    
    public class WebRoute extends Routes {
    @Override
    public void config() {
        add("/web/product",WebProductCtrl.class,"web/product");
    }

}


/**
 * PC 与手机 页面自动切换 关键代码
 * Created by YangTao on 2015-8-31.
 */
public class RenderSwitchInterceptor implements Interceptor {
    @Override
    public void intercept(Invocation ai) {

        Controller c = ai.getController();



        ai.invoke();

        Render render = c.getRender();

        String returnPath = render.getView(); // ctrl中render的字符串
        String viewPath = "";
        if (!returnPath.startsWith("/")){ // 如果不是以/开头,则说明不是页面的完整路径
            viewPath = AppConst.SYSTEM_ROUTES.getViewPath(ai.getControllerKey());
        }

        if (isMobile(c.getRequest())){ //手机
            viewPath = viewPath.replace("/web/","/wap/");
        }
        render.setView(viewPath+returnPath);
    }
  }



jfinal通过拦截器判断不同浏览器返回不同结果页面

标签:

原文地址:http://my.oschina.net/wanily/blog/499694

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!