Thymeleaf没有看到Controller的参考

时间:2017-01-11 15:45:45

标签: java postgresql spring-boot spring-data thymeleaf

我试图使用Thymeleaf在html页面上显示我本地数据库(PostgreSQL)中的所有客户。我的项目是使用Spring Boot。

连接和从数据库获取数据不是这个问题的重点(或者是?)。关键是百里香叶看不到我通过控制器的模型。

homePage.html

!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-4.dtd">

<html xmlns="http://www.w3.org/1999/xhtml"
  xmlns:th="http://www.thymeleaf.org">

<head>
<title>Opera</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
<p th:text="'Opera home page'" />

<ul th:each="customer : ${customers}">
<li>
    <span th:text="${customers.getFirstName}">Name</span>
    <span th:text="${customers.getLastName}">Surname</span>
    <span th:text="${customers.getPhone}">Phone</span>
    <span th:text="${customers.getEmail}">e-mail</span>
</li>
</ul>
</body>
</html>

HomePageController.java

@Controller
@RequestMapping("/")
public class HomePageController {

    private CustomerRepository customerRepository;

    @Autowired
    public HomePageController(CustomerRepository customerRepository){
        this.customerRepository = customerRepository;
    }


    @RequestMapping(method = RequestMethod.GET)
    public String homePage(Model model) {
        List<Customer> customers = Lists.newArrayList(customerRepository.findAll());
        model.addAttribute("customers", customers);
        return "homePage";
    }
}

CustomerRepository.java

@Repository
public interface CustomerRepository extends CrudRepository<Customer, Long> {
}

Customer.java

@Entity
@Getter @Setter
public class Customer {

    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private Long id;
    @NotNull private String firstName;
    @NotNull private String lastName;
    @NotNull private String phoneNumber;
    @NotNull private String email;

    protected Customer(){}

    public Customer(Long id, String firstName, String lastName, String phoneNumber, String email){
        this.id = id;
        this.firstName = firstName;
        this.lastName = lastName;
        this.phoneNumber = phoneNumber;
        this.email = email;
    }

    @Override
    public String toString(){
        return String.format(
            "Customer[id=%d, firstName='%s', lastName='%s', phoneNumber='%s', emailr='%s']",this.getId(),
            firstName, lastName, phoneNumber, email);
    }
}

显示问题的html文件的屏幕截图: screen

编辑:一些英语修正:(

1 个答案:

答案 0 :(得分:1)

不要在模板中使用getter。这样做:

<span th:text="${customer.firstName}">Name</span>

对不起,您还必须删除s