一、表单中有th:object但后台传参没有Object导致访问报错

1)前台表单代码

注意,下图中的login.html中的form表单部分,根据从网上查到的Thymeleaf表单提交案例,模仿了之后,发现在<form>标签内有个th:object,我一开始一直不知道这个是用来干什么的,以为是提交之后往后台传输参数的(其实是上一步请求跳转后从后台传到前台的)。

	<form action="/user" th:action="@{/user/login}" method="post" th:object="${user}">
<!--		<form action="/user" th:action="@{/user/login}" method="post" >-->
		<table>
				<td>用户名:</td>
				<td><input type="text" name="uname" th:value="*{uname}"/></td>
				<td>密码:</td>
				<td><input type="password" name="upassword" th:value="*{upassword}"/></td>
				<td colspan="2" align="center"><input type="submit" value="提交" /></td>
		</table>
	</form>

2)后台Controller代码

后台是一个跳转链接,意思准备通过访问localhost:8080/user/loginUI,跳转到用户登录的/templates/pages/login.html表单提交页面,也就是上一步的login.html页面。

@Controller
@RequestMapping("/user")
public class UserController{
	@GetMapping("/loginUI")
	public String loginUI() {
		return "/pages/login";

       3)访问报错(前台th:object存在,后台model.addAttribute("user", new User())不存在)

       但是,当我们访问localhost:8080/user/loginUI的时候,报错了。下图中虽然访问网址没有变(请求转发的特点),但错误不在UserController后台转发那一步,而是在转发之后的login.html页面这里。报错内容明显地表示了,错误原因是模板解析错误造成的,也就是说login.html这个页面内有错误。

       继续往下看,下拉报错原因,很清楚的说明了在SpringEL表达式语句中,"uname"处发生了判断上的异常。也就是说,此时的SpringEL是不识别uname的。

       4)解决方法一:后台传参给user(前台th:object存在,后台model.addAttribute("user", new User())也存在)

       在网上查了好久,后来知道了th:object原来是后台传给当前页面的参数,所以我就去尝试了一下,给后台创建一个值为空的User对象,再传给前台,看看有没有效果。

@Controller
@RequestMapping("/user")
public class UserController{
	@GetMapping("/loginUI")
	public String loginUI(Model model) {
		model.addAttribute("user", new User());
		return "/pages/login";

       结果呢,如下图所示,访问localhost:8080/user/loginUI之后,没有报错,而是正常跳转到了login.html页面,也就可以进行下一步的提交表单操作了。

二、探索报错原因

       1)查看Thymeleaf官方文档

       下图中在对于星号变量表达式的使用中提到,星号和美元符号有一个重要的区别:星号语法仅对选定对象进行表达式语法上的认可,而不是对整个上下文起作用。也就是说,只要没有选定对象,星号和美元的语法作用完全相同。

       什么是被选中的对象?就是使用th:object属性表达式的对象。

       这句话的意思是说,如果使用了星号表达式语句,那么星号变量(比如uname)就必须有一个选定对象处于上一级标签中。这个选定对象你可以理解为,星号变量所处的类对象(比如User),星号变量(比如uname)就是这个类的一个变量。

       因此,我们选择了使用*{uname}来放置变量的话,那么必须存在th:object="${user}",既然必须存在${user},那么跳转到login.html页面的后台Controller请求就必须往前台传递一个User对象。因此,当我们把UserController中的loginUI(Model model)方法添加了model.addAttribute("user", new User());之后,访问就不再报错了。

       2)将星号替换为美元符号(前台th:object存在,后台model.addAttribute("user", new User())也存在)

       我们再来回顾下Thymeleaf官方文档中的一句话,“也就是说,只要没有选定对象,星号和美元的语法作用完全相同”。本来我是准备要去掉th:object的,但我们先看下th:object存在的时候,将星号替换为美元符号的访问情况。

       如下图所示,th:value="*{uname}"已经被替换成了th:value="${uname}"。

	<form action="/user" th:action="@{/user/login}" method="post" th:object="${user}">
		<table>
				<td>用户名:</td>
				<td><input type="text" name="uname" th:value="${uname}"/></td>
				<td>密码:</td>
				<td><input type="password" name="upassword" th:value="${upassword}"/></td>
				<td colspan="2" align="center"><input type="submit" value="提交" /></td>
		</table>
	</form>

       可以看到,访问localhost:8080/user/loginUI是没有问题的。那么为什么会这样,我判断是因为,和*{uname}不同,${uname}是不需要理会上一级中的th:object="${user}"的,因此在这里没有报错(因为表单提交是前台准备传给后台数据,如果前台接收后台传来的数据,就不可能直接写${uname}了,而是需要写${user.uname})。

三、去除th:object之后的访问

       1)星号变量(前台th:object不存在,后台model.addAttribute("user", new User())存在)

       如下图所示,我们现在将前台login.html中的th:object="${user}"去掉,但后台不变, 即model.addAttribute("user", new User())依然存在。

	<form action="/user" th:action="@{/user/login}" method="post" >
		<table>
				<td>用户名:</td>
				<td><input type="text" name="uname" th:value="*{uname}"/></td>
				<td>密码:</td>
				<td><input type="password" name="upassword" th:value="*{upassword}"/></td>
				<td colspan="2" align="center"><input type="submit" value="提交" /></td>
		</table>
	</form>
@Controller
@RequestMapping("/user")
public class UserController{
	@GetMapping("/loginUI")
	public String loginUI(Model model) {
		model.addAttribute("user", new User());
		return "/pages/login";

       对localhost:8080/user/loginUI的访问也是没有问题的。

       2)美元变量(前台th:object不存在,后台model.addAttribute("user", new User())存在)

       如下图所示,将"*{uname}"已经替换为了"${uname}"。

	<form action="/user" th:action="@{/user/login}" method="post" >
		<table>
				<td>用户名:</td>
				<td><input type="text" name="uname" th:value="${uname}"/></td>
				<td>密码:</td>
				<td><input type="password" name="upassword" th:value="${upassword}"/></td>
				<td colspan="2" align="center"><input type="submit" value="提交" /></td>
		</table>
	</form>

       对localhost:8080/user/loginUI的访问依然没有问题。

       3)星号变量(前台th:object不存在,后台model.addAttribute("user", new User())也不存在)

       现在,在login.html中为星号变量("*{uname}")的情况下,我们来尝试将后台的model.addAttribute("user", new User())去掉,即取消后台对前台表单提交此值为空的user。

@Controller
@RequestMapping("/user")
public class UserController{
	@GetMapping("/loginUI")
	public String loginUI() {
		// model.addAttribute("user", new User());
		return "/pages/login";

       结果,对localhost:8080/user/loginUI的访问仍没有问题。

       4)美元变量(前台th:object不存在,后台model.addAttribute("user", new User())也不存在)

       接着,将前台的星号变量改为美元变量("*{uname}"改为"${uname}"),同时也将后台的model.addAttribute("user", new User())去掉。

       结果,对localhost:8080/user/loginUI的访问也没有问题。

       总的来看,我们尝试了很多种情况,通过改变前台有无th:object和后台有无User传递到前台,最终发现,除了前台有th:object="${user}"且th:value="*{uname}"(星号变量)的时候,后台是必须有一个User对象传递到前台给${user}的。其他各种情况,前台th:object是否存在和后台是否有User对象传递到前台,都不会导致访问localhost:8080/user/loginUI后跳转到的/templates//pages/login.html页面报错。

【学习笔记——SpringBoot 0106】Thymeleaf表单页面因th:object无后台对象传入而解析错误/An error happened during template parsing 此篇分享一个关于Thymeleaf表单提交的问题
最近在学习spring实战这本书时,使用thymeleaf模板引擎时,用到了th:object标签。在查询thymeleaf官方文档,得到了具体的解释。 以下是文档中的一段话: Not only can variable expressions be written as ${…} , but also as *{…} . There is an important difference though: the asterisk syntax evaluates expressions on selec
<script th:inline="javascript"> [#th:block th:object="${T(org.apache.shiro.SecurityUtils).getSubject().getPrincipal()}"] var currentUser = { loginName:[[*{loginName}]], userName:[[*{userName}]], userId:[(*{userId})], deptId:[(*{dep
Spring Boot中Thymeleaf表单处理的一些用法: (1)使用th:field属性:进行表单字段绑定 (2)使用ids对象:一般用于lable配合radio或checkbox使用 (3)表单提交处理 开发环境:IntelliJ IDEA 2019.2.2 Spring Boot版本:2.1.8 新建一个名称为demo的Spring Boot项目。 pom.xml
目录标准变量表达式${}介绍案例:标准变量表达式显示实体对象中的属性选择变量表达式*{}介绍案例:选择变量表达式显示实体对象中的属性案例:选择变量表达式显示实体对象中的属性URL表达式(路径表达式)介绍案例:路径表达式绑定相对路径Thymeleaf常用th标签th:actionth:methodth:hrefth:srcth:idth:nameth:valueth:attrth:textth:objectth:onclickth:styleth:eachth:ifth:unlessth:switch/th:
1. 概述 在web开发中,我们经常会将公共头,公共尾,菜单等部分提取成模板供其它页面使用。在thymeleaf中,通过th:fragment、th:include、th:replace、参数化模板配置、css选择器加载代码块等实现。下文通过例子来说明用法: fragment语法 通过 th:fragment 和 css选择器加载代码块 th:include 和 th:replace
        今天我们说一下springboot项目中,前端如何使用thymeleaf提交form表单数据到后台controller中,这与jsp还是有些区别的。 第一步,修改thymeleaf页面: <form method="post" th:action="@{/login}" th:object="${user}" class="loginForm"> <div cl
org.thymeleaf.exceptions.templateinputexception: an error happened during template parsing
看到你遇到了一个模板解析异常(org.thymeleaf.exceptions.TemplateInputException)的错误。 这个错误通常发生在Thymeleaf模板引擎在解析模板文件时出现问题时。可能的原因包括模板语法错误、模板文件路径错误、模板文件不存在或不可读、模板文件编码错误等等。 为了解决这个问题,你可以尝试以下几个步骤: 1. 检查模板文件路径是否正确,并确保模板文件存在和可读。你可以使用绝对路径或相对路径来引用模板文件。如果使用相对路径,请确保它相对于应用程序的根目录。 2. 检查模板文件的编码是否正确。如果模板文件的编码不正确,可能会导致解析错误。通常情况下,UTF-8编码是一个比较好的选择。 3. 检查模板语法是否正确。确保你使用的是正确的Thymeleaf语法,并且所有的标签都被正确地关闭。 如果你仍然无法解决这个问题,你可以在你的代码中设置调试标志,以便在运行时输出更详细的错误信息,帮助你更好地定位问题。 ### 回答2: org.thymeleaf.exceptions.TemplateInputException: 模板解析过程中发生错误 在使用Thymeleaf时,有时会发生模板解析失败的情况,此时会抛出TemplateInputException异常。这个异常通常是由模板语法错误或者模板文件缺失等导致的。 其主要的原因有以下几点: 1. 模板语法错误:当模板中存在语法错误,例如语法不正确、标签闭合不正确等,就会导致模板解析失败,并抛出异常。 2. 模板文件缺失:当请求某个模板文件时,如果该文件不存在,就会抛出TemplateInputException异常。 3. 模板文件编码问题:当模板文件采用非UTF-8编码方式时,可能会导致乱码或解析失败。 为了解决这个问题,我们可以逐步排查错误原因。 首先,可以检查模板文件的语法是否正确,是否存在标签未闭合等语法错误;其次,可以检查模板文件是否存在,以及路径是否正确;最后,可以检查模板文件的编码方式,确保采用UTF-8编码方式。 除此之外,还可以在模板中添加debug信息来排查问题: <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <meta charset="UTF-8"> <title>Template</title> </head> <div th:text="${debug}"></div> </body> </html> 通过在模板中添加debug信息,可以查看当前模板中的变量、表达式等信息,帮助排查错误。 总之,在使用Thymeleaf时,需要注意模板的语法正确性、文件是否存在、编码方式是否正确等,从而确保模板解析成功,避免出现TemplateInputException异常。 ### 回答3: org.thymeleaf.exceptions.TemplateInputException是指在解析模板过程中出现了错误,可能是由于模板文件的格式不正确或存在语法错误导致的。 模板文件通常是由HTML标记和Thymeleaf模板引擎的特定语法组成,用于动态生成Web页面。当解析模板时,Thymeleaf引擎会查找并读取模板文件,将其中的语法转换为有效的HTML标记。如果模板文件存在语法错误或无法识别,就会抛出TemplateInputException这个异常。 为了防止这种异常出现,我们要遵循以下几条规则: 1. 模板文件应该遵循HTML标准,并使用合法的语法和标记。 2. 在Thymeleaf模板文件中使用特定的语法和标记时,应该遵循Thymeleaf的规则和示例,并确认语法的正确性。 3. 对于模板文件中出现的错误,应该及时检查并修改,以免影响页面的正常输出。 4. 在开发过程中,建议在IDE中启用模板文件的语法检查器,以及及时查看和调试错误信息,避免出错。 总之,遵循标准和规则,保持良好的开发习惯,会有助于避免出现TemplateInputException这种异常,提高Web应用的稳定性和可靠性。
【学习笔记——SpringBoot 0106】Thymeleaf表单页面因th:object无后台对象传入而解析错误/An error happened during template parsing 赞一下,解决了我的一个问题 【DDSCAT——离散偶极近似仿真程序12】calltarget与vtrconvert程序的使用 m0_54128681: 你好,为什么我用calltarget程序生成的文件改名字成shape.dat文件后再用vtrconvert生成vtr文件时报错说At line 78 of file VTRCONVERT.f90 (unit = 10, file = 'target.out') Fortran runtime error: End of file