Eke*_*era 3 java spring-security spring-data-jpa thymeleaf spring-boot
我试图为我的项目(电话簿)制作简单的过滤器,以便能够通过他们的电子邮件而不是 id 找到用户联系人。当我简单地启动 URL 时:http://localhost:8080/home/phonebook。我收到以下错误。
错误信息
org.thymeleaf.exceptions.TemplateProcessingException:评估 SpringEL 表达式的异常:“data.content”(模板:“/home/phonebook”-第 29 行,第 13 栏)
引起:org.springframework.expression.spel.SpelEvaluationException:EL1008E:在“java.util.ArrayList”类型的对象上找不到属性或字段“内容”——可能不是公共的或无效的?
家庭控制器
@RequestMapping(value = {"/home/phonebook"}, method = RequestMethod.GET)
public String showPage(Model model, @RequestParam(defaultValue = "0") int page){
Authentication auth = SecurityContextHolder.getContext().getAuthentication();
User user = userService.findUserByEmail(auth.getName());
model.addAttribute("data",phonebookRepository.findAllByUserEmail(user.getEmail(),PageRequest.of(page,10)));
model.addAttribute("currentPage",page);
return "/home/phonebook";
}
Run Code Online (Sandbox Code Playgroud)
电话簿.html
<tr th:each="phonebook :${data.content}">
<td th:text="${phonebook.id}"></td>
<td th:text="${phonebook.surname}"></td>
<td th:text="${phonebook.firstname}"></td>
<td th:text="${phonebook.phoneNumber}"></td>
<td>
<a th:href="@{delete/(id=${phonebook.id})}" class="btn btn-danger delBtn">Delete</a>
<a th:href="@{findOne/(id=${phonebook.id})}" class="btn btn-primary eBtn">Edit</a></td>
</tr>
</tbody>
</table>
<hr/>
<ul class="nav nav-pills">
<li class="nav-item" th:each="i: ${#numbers.sequence(0,data.totalPages-1)}">
<a th:href="@{/home/phonebook(page=${i})}" th:text="${i}" class="nav-link"
th:classappend="${currentPage}==${i}?'active':''"></a>
</li>
</ul>
Run Code Online (Sandbox Code Playgroud)
电话簿库
@Repository("phonebookRepository")
public interface PhonebookRepository extends JpaRepository<Phonebook,Integer> {
List<Phonebook> findAllByUserEmail(String email, Pageable pageable);
}
Run Code Online (Sandbox Code Playgroud)
安全配置
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.jdbcAuthentication().dataSource(dataSource)
.usersByUsernameQuery("select email, password, active from users where email=?")
.authoritiesByUsernameQuery("select u.email, r.role from users u inner join user_role ur on(u.user_id=ur.user_id) inner join role r on(ur.role_id=r.role_id) where u.email=?")
.passwordEncoder(passwordEncoder());
}
Run Code Online (Sandbox Code Playgroud)
更新 1
进行了更改<tr th:each="phonebook :${data}">,我认为它修复了它,但出现了新错误;
org.thymeleaf.exceptions.TemplateProcessingException:评估 SpringEL 表达式的异常:“#numbers.sequence(0,data.totalPages-1)”(模板:“/home/phonebook”-第 42 行,第 38 列)
引起:org.springframework.expression.spel.SpelEvaluationException:EL1008E:在“java.util.ArrayList”类型的对象上找不到属性或字段“totalPages”——可能不是公共的或无效的?
改变
<tr th:each="phonebook : ${data.content}">
到
<tr th:each="phonebook : ${data}">
因为您要迭代查询列表结果,而data.content只是一个属性。
| 归档时间: |
|
| 查看次数: |
33966 次 |
| 最近记录: |