So beheben Sie den Fehler bei der Integration von Freemarker in Springboot
springboot整合freemarker踩坑
报错
2021-04-23 02:01:18.148 FEHLER 9484 --- [nio-8080-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet .service() für Servlet [dispatcherServlet] im Kontext mit Pfad [] löste Ausnahme aus [Anforderungsverarbeitung fehlgeschlagen; Die verschachtelte Ausnahme ist freemarker.core.InvalidReferenceException: Folgendes wurde als null ausgewertet oder fehlt:
==> hots [in Vorlage „inc/right.ftl“ in Zeile 6, Spalte 11]----
Tipp: Wenn bekannt ist, dass sich der fehlerhafte Ausdruck rechtmäßig auf etwas bezieht, das manchmal null ist oder fehlt, geben Sie entweder einen Standardwert an, z. B myOptionalVar!myDefault, oder verwenden Sie when-presentwhen-missing#if>. (Diese decken nur den letzten Schritt des Ausdrucks ab; um den gesamten Ausdruck abzudecken, verwenden Sie Klammern: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
--------
FTL-Stack-Trace („~“ bedeutet verschachtelungsbezogen):
- Fehler bei: @hots [in Vorlage „inc/right.ftl“ in Zeile 6, Spalte 9]
- Erreicht über: #include „/inc/right.ftl“ [ in der Vorlage „index.ftl“ in Zeile 52, Spalte 13]
~ Erreicht über: #nested [in der Vorlage „inc/layout.ftl“ im Makro „layout“ in Zeile 25, Spalte 5]
~ Erreicht über: @layout „首页“ [in Vorlage „index.ftl“ in Zeile 2, Spalte 1]
----] mit Grundursachefreemarker.core.InvalidReferenceException: Folgendes wurde als null oder fehlend ausgewertet:
==> [in der Vorlage „inc/right.ftl“ in Zeile 6, Spalte 11]----
Tipp: Wenn bekannt ist, dass sich der fehlerhafte Ausdruck rechtmäßig auf etwas bezieht, das manchmal null ist oder fehlt, geben Sie entweder einen Standardwert wie myOptionalVar an !myDefault, oder verwenden Sie when-presentwhen-missing#if> (Diese decken nur den letzten Schritt des Ausdrucks ab; Um den gesamten Ausdruck abzudecken, verwenden Sie Klammern: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
--------
FTL-Stack-Trace („~“ bedeutet verschachtelungsbezogen):
- Fehler bei: @hots [in Vorlage „inc/right.ftl“ in Zeile 6, Spalte 9]
- Erreicht über: #include „/inc/right.ftl“ [in Vorlage „index.ftl“ in Zeile 52, Spalte 13]
~ Erreicht über: #nested [in Vorlage „inc/layout.ftl“ im Makro „layout“ in Zeile 25, Spalte 5]
~ Erreicht über: @layout „首页“ [in der Vorlage „index.ftl“ in Zeile 2, Spalte 1]
----
bei freemarker.core.InvalidReferenceException.getInstance(InvalidReferenceException.java:134) ~[ freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.UnifiedCall.accept(UnifiedCall.java:106) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment. Visit(Environment.java:330) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment.visit(Environment.java:336) ~[freemarker-2.3.28.jar:2.3. 28]
bei freemarker.core.Environment.include(Environment.java:2582) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Include.accept(Include.java:171) ~[ freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment.visit(Environment.java:366) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment. invokeNestedContent(Environment.java:618) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.BodyInstruction.accept(BodyInstruction.java:60) ~[freemarker-2.3.28.jar:2.3. 28]
bei freemarker.core.Environment.visit(Environment.java:366) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment.invoke(Environment.java:775) ~[ freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.UnifiedCall.accept(UnifiedCall.java:83) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment. Visit(Environment.java:330) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.core.Environment.visit(Environment.java:336) ~[freemarker-2.3.28.jar:2.3. 28]
bei freemarker.core.Environment.process(Environment.java:309) ~[freemarker-2.3.28.jar:2.3.28]
bei freemarker.template.Template.process(Template.java:384) ~[ freemarker-2.3.28.jar:2.3.28]
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate(FreeMarkerView.java:389) ~[spring-webmvc-5.1.4.RELEASE.jar: 5.1.4.RELEASE]
bei org.springframework.web.servlet.view.freemarker.FreeMarkerView.doRender(FreeMarkerView.java:302) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web.servlet.view.freemarker.FreeMarkerView.renderMergedTemplateModel(FreeMarkerView.java:253) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework. web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:178) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web.servlet.view.AbstractView. render(AbstractView.java:316) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1370) ~[ spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1116) ~[spring-webmvc-5.1.4.RELEASE. jar:5.1.4.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1055) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:942) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web.servlet.FrameworkServlet. ProcessRequest(FrameworkServlet.java:1005) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:897) ~[ spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei javax.servlet.http.HttpServlet.service(HttpServlet.java:634) ~[tomcat-embed-core-9.0.14.jar: 9.0.14]
bei org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:882) ~[spring-webmvc-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei javax.servlet. http.HttpServlet.service(HttpServlet.java:741) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
unter org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
unter org.apache.tomcat.websocket.server.WsFilter .doFilter(WsFilter.java:53) ~[tomcat-embed-websocket-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat -embed-core-9.0.14.jar:9.0.14]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-9.0.14.jar:9.0 .14]
bei org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web .filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java :193) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-9.0 .14.jar:9.0.14]
bei org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:92) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE]
unter org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE]
unter org.apache.catalina.core.ApplicationFilterChain .internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat -embed-core-9.0.14.jar:9.0.14]
at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:93) ~[spring-web-5.1.4.RELEASE.jar:5.1 .4.RELEASE]
bei org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE]
bei org.apache .catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java :166) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200) ~[spring-web-5.1.4 .RELEASE.jar:5.1.4.RELEASE]
bei org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) ~[spring-web-5.1.4.RELEASE.jar:5.1.4.RELEASE ]
bei org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.ApplicationFilterChain .doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) ~[tomcat -embed-core-9.0.14.jar:9.0.14]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) ~[tomcat-embed-core-9.0.14.jar:9.0 .14]
bei org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core .StandardHostValve.invoke(StandardHostValve.java:139) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) ~ [tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74) ~[tomcat-embed-core-9.0.14.jar :9.0.14]
bei org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.coyote .http11.Http11Processor.service(Http11Processor.java:408) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) ~ [tomcat-embed-core-9.0.14.jar:9.0.14]
bei org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834) ~[tomcat-embed-core-9.0.14.jar :9.0.14]
bei org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1417) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei org .apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
bei java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128) ~[na:na]
bei java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628 ) ~[na:na]
bei org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) ~[tomcat-embed-core-9.0.14.jar:9.0.14]
unter java.base/java.lang.Thread.run(Thread.java:834) ~[na:na]2021-04-23 02:01:18.177 FEHLER 9484 --- [nio-8080-exec-1 ] s.e.ErrorMvcAutoConfiguration$StaticView: Fehlerseite für Anfrage [/] und Ausnahme kann nicht gerendert werden [Folgendes wurde als null ausgewertet oder fehlt:
==> hots [in Vorlage „inc/right.ftl“ in Zeile 6, Spalte 11]----
Tipp: Wenn bekannt ist, dass sich der fehlerhafte Ausdruck rechtmäßig auf etwas bezieht, das manchmal null ist oder fehlt, geben Sie entweder einen Standardwert an, z. B myOptionalVar!myDefault, oder verwenden Sie when-presentwhen-missing#if>. (Diese decken nur den letzten Schritt des Ausdrucks ab; um den gesamten Ausdruck abzudecken, verwenden Sie Klammern: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
--------
FTL-Stack-Trace („~“ bedeutet verschachtelungsbezogen):
- Fehler bei: @hots [in Vorlage „inc/right.ftl“ in Zeile 6, Spalte 9]
- Erreicht über: #include „/inc/right.ftl“ [ in der Vorlage „index.ftl“ in Zeile 52, Spalte 13]
~ Erreicht über: #nested [in der Vorlage „inc/layout.ftl“ im Makro „layout“ in Zeile 25, Spalte 5]
~ Erreicht über: @layout „首页“ [in Vorlage „index.ftl“ in Zeile 2, Spalte 1]
----], da die Antwort bereits festgeschrieben wurde. Daher hat die Antwort möglicherweise den falschen Statuscode.
问题原因
因为在service里试着把redis逻辑代码运行,然后再控制台上输出,结果发现结果是没有问题的, 而且通过报错信息初步认为是前端的问题, hots没找到, 但是跟之前的一个类似功能相比较,然后通过不断的对比,找到问题是出在配置类.
之前一直认为template类中的getname方法就能完成映射功能
其实需要在FreemarkerConfig类里面进行声明
解决方法
再FreemarkerConfig类先通过@Autowired导入template类,然后使用configuration.setSharedVariable(“hots“, hotsTemplate);进行声明,缺少这一步会使得前端对于这个标签无法识别.
springboot freemarker基础配置及使用
1.基础配置
1.1引入依赖
<!-- 引入freemarker模板引擎的依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency>
1.2在application.properties配置文件中添加如下配置:
# 是否开启thymeleaf缓存,本地为false,生产建议为true spring.freemarker.cache=false spring.freemarker.charset=UTF-8 spring.freemarker.allow-request-override=false spring.freemarker.check-template-location=true #类型 spring.freemarker.content-type=text/html spring.freemarker.expose-request-attributes=true spring.freemarker.expose-session-attributes=true # #文件后缀 spring.freemarker.suffix=.ftl #路径 .ftl文件就创建在templates下面或者子目录 spring.freemarker.template-loader-path=classpath:/templates/
2.基础使用
首先我在Controller类中编写一个测试接口用来测试使用,编写内容如下
@Controller public class FreeMarkerController { Map<String ,Object> map = new HashMap<>(); List<Object> list = new ArrayList(); @GetMapping("/freemaker/{id}/{name}") public String demo(@PathVariable("id")String id ,@PathVariable("name") String name,Model model){ map.clear(); map.put("id",id); map.put("name",name); list.add(2); list.add(4); map.put("aa",null); model.addAttribute("map",map); model.addAttribute("list",list); model.addAttribute("date",new Date()); return "index"; } }
以下所有变量都是有上面接口提供
2.1 set集合也可用此格式调用相应的元素
/*可直接获取id对应的v值*/ id:${map.id} name:${map.name}
2.3字符串拼接的两种方法
list01:${list[0]} list02:${list[1]}
2.4FreeMarker wird mit „+“, „-“, „*“, „/“ angezeigt. „%“运算符
${"你好啊${map.name}"} ${"你好啊"+map.name}
2.5表达式中支持的比较运算符有如下几种:
1. =(或者==):判断两个值是否相等;2. ! =:必须相同.而且FreeMarker的比较是精确比较,不会忽略大小写及空格.3. >(或者gt):大于
4. >=(或者gte):大于等于5. 6. 注:部分时候,使用gt比>有更好的效果,因为FreeMarker会把>解释成标签的结束字符.可以使用括号来避免这种2.7支持逻辑表达式
2.6时间格式转换${list[1]+list[0]} ${list[1]-list[0]} ${list[1]*list[0]} ${list[1]/list[0]} ${list[1]%list[0]}
FreeMarker支持逻辑运算但是只支持布尔型逻辑运算两个值进行比较运算的的时候需要添加括号才能进行逻辑运算,一般用于指令中
FreeMarker支持逻辑运算但是只支持布尔型逻辑运算两个值进行比较运算的的时候需要添加括号才能进行逻辑运算,一般用于指令中
1. &&: 逻辑与;
2. ||:逻辑或;
3. !:逻辑非
逻辑运算符只能用于布尔值。
2.8FreeMarker无法理解null值
FreeMarker的变量必须赋值,否则就会抛出异常。而对于FreeMarker来说,null值和不存在的变量是完全一样的,因为FreeMarker无法理解null值。
FreeMarker提供两个运算符来避免空值:
1.!运算
1.1若是msg不存在不报异常默认空值,若是不使用!会报异常
${msg!}
1.2若是存在则输出,若是不存在则默认为abc
${map.a!"abc"}
2.??返回布尔值一般用在指令中下面会有引用此处不解释
2.9 if指令
<#if map.aa?? > 存在 <#else > 不存在 </#if> <br> <#if (list[0]>=3) > 优秀 <#elseif (list[0]>=2)> 良好 <#else > 差劲 </#if>
2.10 list指令 遍历
<#list list as li> ${li}<br> </#list>
Das obige ist der detaillierte Inhalt vonSo beheben Sie den Fehler bei der Integration von Freemarker in Springboot. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Java'splattformIndependencemeansDevelopersCanwriteCodeonceAnDrunitonanyDevicewithoutrecompiling.Thissisached ThejavavirtualMachine (JVM), Who IssisByteCodeIntomachine-spezifische STRADIONS, ZUSTANDUNGUNGENSALVATIBILIBILIBLETUNGEN.HOWIFRISIONENS

Um die JVM einzurichten, müssen Sie die folgenden Schritte ausführen: 1) Laden Sie die JDK -Set -Variablen herunter und installieren Sie die Umgebungsvariablen, 3) Überprüfen Sie die Installation, 4) Setzen Sie die IDE, 5) Testen Sie das Läuferprogramm. Bei der Einrichtung eines JVM geht es nicht nur darum, es funktioniert, sondern auch die Optimierung der Speicherzuweisung, der Müllsammlung, der Leistungsstimmung und der Fehlerbehandlung, um einen optimalen Betrieb sicherzustellen.

ToensurejavaplatformIndependenz, folge theSesteps: 1) compileandrunyourApplicationOnmultiPlatformSusendifferentosandjvmversions.2) utilizeci/cdpipelines-usjenkinsorgithubactionsForAutomatedCross-PlatformTesting.3) US-Erklammern

JavastandsoutinMoDerndevelopmentDuetoitsRobustFeatureSlikelambdaExpressions, Streams, andenhancedConcurcurcysupport.)

Die Kernmerkmale von Java sind Plattformunabhängigkeit, objektorientiertes Design und eine reichhaltige Standardbibliothek. 1) Objektorientiertes Design macht den Code durch polymorphe Merkmale flexibler und wartbarer. 2) Der Mechanismus -Sammelmechanismus befreit die Belastung des Gedächtnismanagements von Entwicklern, muss jedoch optimiert werden, um Leistungsprobleme zu vermeiden. 3) Die Standardbibliothek bietet leistungsstarke Tools von Sammlungen bis hin zu Netzwerken, aber Datenstrukturen sollten sorgfältig ausgewählt werden, um den Code präzise zu halten.

Ja, Javacanruneverywhereduetoits "Writeonce, Runanywhere" Philosophie.1) JavacodeiscompiledIntoplatform-unabhängigem BYTecode.2) thejavavirtualmachine (JVM) interpretiert, wiesByteCodinualmachine-spezifisch-spezifiziert

Jdkincludestoolsfordeveloving und Compilingjavacode, während JvmrunStheCompiledByteCode.1) Jdkcontainsjre, Compiler und Änderungen.2) JVMManmanageByteeexexexexexecution undSupports "Writeonce, Run Anlywhere.

Die wichtigsten Merkmale von Java sind: 1) objektorientiertes Design, 2) Plattformunabhängigkeit, 3) Mechanismus für Müllsammlung, 4) Reiche Bibliotheken und Rahmenbedingungen, 5) Unterstützung der Parallelität, 6) Ausnahmebehandlung, 7) Kontinuierliche Entwicklung. Diese Funktionen von Java machen es zu einem leistungsstarken Tool für die Entwicklung einer effizienten und wartbaren Software.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft
