html 代码
<form action="${base}/search.jspx" target="_blank" id="searchForm" style="position:relative">
<table width="100%" border="0" align="right" cellpadding="0" cellspacing="0">
<tbody>
<tr>
<td width="84%" ><input id="keyword" class="searchinput" name="q" value="请输入内容" type="text" onfocus="if(this.value=='请输入关键词')this.value=''" onblur="if(this.value=='')this.value='请输入关键词'" /></td>
<td width="16%"><input type="submit" class="btn" style="color:transparent; cursor:pointer;position:absolute;top:5px;right:4px;height:20px;width:20px;background:url('/${res}/images/lab/btn-search.jpg') no-repeat;background-size:20px 20px;background-position:center;border:0;padding:3px;" /></td>
</tr>
</tbody>
</table>
</form>
search_result.html代码
<!DOCTYPE HTML>
<html>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<link href="${resSys}/front.css" rel="stylesheet" type="text/css"/>
<link href="${resSys}/jqueryUI/jquery.ui.css" rel="stylesheet" type="text/css"/>
<link type="text/css" href="/${res}/css/lab/simplenews.css" rel="stylesheet" />
<link href="/${res}/css/page.css" rel="stylesheet" type="text/css" />
<link type="text/css" href="/${res}/css/lab/sudynav.css" rel="stylesheet" />
<link href="/${res}/css/lab/main.css" rel="stylesheet" type="text/css" />
<link href="/${res}/css/btn-content.css" rel="stylesheet" type="text/css" />
<script src="${resSys}/jquery.js" type="text/javascript"></script>
<script src="${resSys}/jqueryUI/jquery-ui.js" type="text/javascript"></script>
<script src="${resSys}/front.js" type="text/javascript"></script>
<script src="/${res}/js/common.js" type="text/javascript"></script>
<!--[if lt IE 9]>
<script src="/${res}/js/html5shiv.min.js"></script>
<script src="/${res}/js/respond.min.js"></script>
<![endif]-->
<script type="text/javascript">
$(function() {
Cms.siteFlow("${base}", location.href, document.referrer, "${site.config.flowSwitch?string}");
});
</script>
</head>
<body>
[#include "../include/head.html"/]
<div class="mainWraper-box">
<div id="mainWraper" style="background-color:#FFFFFF">
<div class="disprow">
<div class="info-box" >
<div class="article" style="padding-top:10px;">
[#if q??]
[@cms_lucene_page q=q channelId=channelId startDate=startDate endDate=endDate descLen='140' append='...' count='10' ]
<div class="searchNav">您搜索的“<span>${input!}</span>”, 共有<span>${tag_pagination.totalCount!}</span>个结果</div>
<div class="searchList">
[#list tag_list as s]
<div class="item">
<div class="search-title"><a href="${s.url}" title="${s.title}" target="_blank">${s.title?replace('${q!}', "<span>${q!}</span>")}</a></div>
<div class="search-date"><a href="${s.ctgUrl}" target="_blank">${s.ctgName}</a><em>${s.releaseDate}</em>浏览 <span>${s.views}</span></div>
</div>
[/#list]
</div>
[#include "../include/page.html"/]
[/@cms_lucene_page]
[/#if]
</div>
</div>
</div>
<div class="clear"></div>
</div>
</div>
[#include "../include/foot.html"/]
</body>
</html>
报错信息
18:04:08.916 ERROR freemarker.runtime - Error executing FreeMarker template
freemarker.core.NonStringOrTemplateOutputException: For "${...}" content: Expected a string or something automatically convertible to string (number, date or boolean), or "template output" , but this has evaluated to a macro+misc_template_model (wrapper: f.c.Macro):
==> s.url [in template "WEB-INF/t/cms/www/default/special/search_result.html" at line 46, column 46]
----
FTL stack trace ("~" means nesting-related):
- Failed at: ${s.url} [in template "WEB-INF/t/cms/www/default/special/search_result.html" at line 46, column 44]
- Reached through: @cms_lucene_page q=q channelId=channe... [in template "WEB-INF/t/cms/www/default/special/search_result.html" at line 41, column 5]
----
at freemarker.core.EvalUtil.coerceModelToTextualCommon(EvalUtil.java:492) ~[freemarker.jar:2.3.24]
at freemarker.core.EvalUtil.coerceModelToStringOrMarkup(EvalUtil.java:374) ~[freemarker.jar:2.3.24]
at freemarker.core.DollarVariable.calculateInterpolatedStringOrMarkup(DollarVariable.java:96) ~[freemarker.jar:2.3.24]
at freemarker.core.DollarVariable.accept(DollarVariable.java:59) ~[freemarker.jar:2.3.24]
at freemarker.core.Environment.visit(Environment.java:362) [freemarker.jar:2.3.24]
at freemarker.core.IteratorBlock$IterationContext.executeNestedContent(IteratorBlock.java:263) [freemarker.jar:2.3.24]
at freemarker.core.IteratorBlock$IterationContext.accept(IteratorBlock.java:200) [freemarker.jar:2.3.24]
at freemarker.core.Environment.visitIteratorBlock(Environment.java:595) [freemarker.jar:2.3.24]
at freemarker.core.IteratorBlock.acceptWithResult(IteratorBlock.java:81) [freemarker.jar:2.3.24]
at freemarker.core.IteratorBlock.accept(IteratorBlock.java:67) [freemarker.jar:2.3.24]
at freemarker.core.Environment.visit(Environment.java:362) [freemarker.jar:2.3.24]
at freemarker.core.Environment$NestedElementTemplateDirectiveBody.render(Environment.java:2727) [freemarker.jar:2.3.24]
at com.jeecms.cms.lucene.LuceneDirectivePage.execute(LuceneDirectivePage.java:86) [classes/:na]
at freemarker.core.Environment.visit(Environment.java:426) [freemarker.jar:2.3.24]
at freemarker.core.UnifiedCall.accept(UnifiedCall.java:101) [freemarker.jar:2.3.24]
at freemarker.core.Environment.visit(Environment.java:326) [freemarker.jar:2.3.24]
at freemarker.core.Environment.visit(Environment.java:332) [freemarker.jar:2.3.24]
at freemarker.core.Environment.visit(Environment.java:332) [freemarker.jar:2.3.24]
at freemarker.core.Environment.process(Environment.java:305) [freemarker.jar:2.3.24]
at freemarker.template.Template.process(Template.java:384) [freemarker.jar:2.3.24]
at com.jeecms.common.web.springmvc.SimpleFreeMarkerView.renderMergedTemplateModel(SimpleFreeMarkerView.java:114) [classes/:na]
at org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:167) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:303) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1257) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1037) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:980) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:897) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:624) [servlet-api.jar:na]
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) [spring-webmvc-4.3.jar:4.3.0.RELEASE]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) [servlet-api.jar:na]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) [tomcat7-websocket.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at com.jeecms.common.web.XssFilter.doFilter(XssFilter.java:40) [classes/:na]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(AbstractShiroFilter.java:449) [shiro-web-1.3.0.jar:1.3.0]
at org.apache.shiro.web.servlet.AbstractShiroFilter$1.call(AbstractShiroFilter.java:365) [shiro-web-1.3.0.jar:1.3.0]
at org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallable.java:90) [shiro-core-1.3.0.jar:1.3.0]
at org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable.java:83) [shiro-core-1.3.0.jar:1.3.0]
at org.apache.shiro.subject.support.DelegatingSubject.execute(DelegatingSubject.java:383) [shiro-core-1.3.0.jar:1.3.0]
at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:362) [shiro-web-1.3.0.jar:1.3.0]
at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:125) [shiro-web-1.3.0.jar:1.3.0]
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) [spring-web-4.3.0.jar:4.3.0.RELEASE]
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262) [spring-web-4.3.0.jar:4.3.0.RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at org.springframework.orm.hibernate4.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:151) [spring-orm-4.3.0.jar:4.3.0.RELEASE]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) [spring-web-4.3.0.jar:4.3.0.RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197) [spring-web-4.3.0.jar:4.3.0.RELEASE]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) [spring-web-4.3.0.jar:4.3.0.RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at com.jeecms.common.web.ProcessTimeFilter.doFilter(ProcessTimeFilter.java:35) [classes/:na]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.73]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.73]
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:218) [catalina.jar:7.0.73]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) [catalina.jar:7.0.73]
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) [catalina.jar:7.0.73]
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) [catalina.jar:7.0.73]
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) [catalina.jar:7.0.73]
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:958) [catalina.jar:7.0.73]
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) [catalina.jar:7.0.73]
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:452) [catalina.jar:7.0.73]
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1087) [tomcat-coyote.jar:7.0.73]
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637) [tomcat-coyote.jar:7.0.73]
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318) [tomcat-coyote.jar:7.0.73]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_31]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_31]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) [tomcat-coyote.jar:7.0.73]
at java.lang.Thread.run(Thread.java:745) [na:1.8.0_31] |
|