本篇内容介绍了“Controller怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
Controller是MVC中的控制部分,主要的功能是接收客户端提交的请求,然后调用Service的功能及获取数据,最后返回View(视图,即JSP或freemarker页面)。
在Jspxcms中,Controller分为前台和后台。前台是普通用户浏览的页面,使用freemarker作为视图,通常不需要登录,比如网站首页、栏目页、专题页、搜索页等;后台一般为管理功能,使用JSP作为视图,需要管理员登录后台并且有相应权限,才能访问。
/src/main/resources/conf/plugin/plug/backend.xml
符合classpath:conf/**/backend*.xml这个规则的文件会加载为后台Controller的配置文件。
<context:component-scan base-package="com.jspxcms.plug.web.back" use-default-filters="false"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> <context:include-filter type="annotation" expression="org.springframework.web.bind.annotation.ControllerAdvice"/> </context:component-scan>
这个配置会自动加载com.jspxcms.plug.web.back包下所有带有Controller或ControllerAdvice注解的类。
后台Controller返回JSP页面,JSP路径的前后缀分别为/WEB-INF/views/、.jsp,相应的配置文件是/src/main/resources/application.properties。
# 后台JSP地址前缀 spring.mvc.view.prefix=/WEB-INF/views/ # 后台JSP地址后缀 spring.mvc.view.suffix=.jsp
后台访问地址以/cmscp为根路径,@RequestMapping("/plug/resume")和@RequestMapping("list.do")配置的最终访问地址为/cmscp/plug/resume/list.do。
/cmscp路径由com.jspxcms.core.Application中的new ServletRegistrationBean(backendDispatcherServlet(), "/cmscp/*");代码设定。
后台Controller返回JSP页面,如plug/resume/resume_list,加上前后缀,实际文件地址为/WEB-INF/views/plug/resume/resume_list.jsp
package com.jspxcms.plug.web.back; @Controller @RequestMapping("/plug/resume") public class ResumeController { @RequiresPermissions("plug:resume:list") @RequestMapping("list.do") public String list(...) { ... return "plug/resume/resume_list"; } @RequiresPermissions("plug:resume:create") @RequestMapping("create.do") public String create(...) { ... return "plug/resume/resume_form"; } ... }
com.jspxcms.plug.ContextConfig中的@ComponentScan({"com.jspxcms.plug.web.fore" })会加载com.jspxcms.plug.web.fore包中的@Controller类。
前台Controller返回的视图是FreeMarker,有关FreeMarker的配置在src/main/resources/context.xml。
其中templateLoaderPath是模板存储路径,也就是模板前缀,默认为/template。
<!-- FreeMarker --> <bean id="freeMarkerViewResolver" class="com.jspxcms.common.freemarker.MyFreeMarkerViewResolver"> <property name="contentType" value="text/html; charset=UTF-8"/> <property name="cacheUnresolved" value="false"/> <property name="redirectHttp10Compatible" value="false"/> </bean> <!-- <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> --> <bean id="freemarkerConfig" class="com.jspxcms.common.freemarker.AdapterFreeMarkerConfigurer"> <property name="freemarkerVariables" value="#{propertiesHelper.getBeanMap('freemarkerVariables.')}"/> <property name="templateLoaderPath" value="${templateStorePath}"/> <property name="freemarkerSettings"> <props> <prop key="tag_syntax">square_bracket</prop> <prop key="template_update_delay">${freemarkerConfig.template_update_delay}</prop> <prop key="defaultEncoding">UTF-8</prop> <prop key="url_escaping_charset">UTF-8</prop> <prop key="localized_lookup">false</prop> <prop key="locale">zh_CN</prop> <prop key="boolean_format">true,false</prop> <prop key="datetime_format">yyyy-MM-dd'T'HH:mm:ss</prop> <prop key="date_format">yyyy-MM-dd</prop> <prop key="time_format">HH:mm:ss</prop> <prop key="number_format">0.###</prop> <prop key="whitespace_stripping">true</prop> <prop key="auto_import">/spring.ftl as s</prop> </props> </property> </bean>
前台访问地址直接以网站根路径为相对路径,@RequestMapping(value = "/resume")配置的访问地址就为/resume。
前台返回的FreeMarker模板路径,一般返回当前站点的模板路径,如/1/default/plug_resume.html,加上模板前缀,实际地址是/template/1/default/plug_resume.html;
也可以是任意值,如:/abc/def.html,加上模板前缀,实际地址为/template/abc/def.html。
package com.jspxcms.plug.web.fore; @Controller public class ResumeController { public static final String TEMPLATE = "plug_resume.html"; @RequestMapping(value = "/resume") public String form(HttpServletRequest request, org.springframework.ui.Model modelMap) { ... // 将通用对象放到modelMap里,如ctx dy user site global等 Map<String, Object> data = modelMap.asMap(); ForeContext.setData(data, request); // 获得当前站点对象 Site site = Context.getCurrentSite(); // 返回当前站点模板路径。如:/1/default/plug_resume.html。加上模板前缀,实际地址是 /template/1/default/plug_resume.html return site.getTemplate(TEMPLATE); } @RequestMapping(value = "/resume", method = RequestMethod.POST) public String submit(...) { ... } }
“Controller怎么配置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。