java - 使用 Spring Controller 列出数据库中的对象

标签 java database spring service controller

我正在使用 Java Spring 框架开发一个网站。这是一个互联网论坛。现在,登录后,我想列出当前存储在数据库中的所有线程。我将首先向您介绍迄今为止实现的重要部分。这篇文章很长,但不要灰心,这确实是一个简单、基本的问题,任何具有基本 Web 编程经验的人都可以立即解决。我向你保证。

Thread对象由它自己的Thread类定义。它是一个标准实体类,包含一些字段、构造函数和 getter/setter。

@Entity
public class Thread {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    int _id;

    private Date last_modified;
    private int topics;
    private String description;
    private String name;

    public Thread(){

    }



    public Thread(int _id, Date last_modified, int topics, String description,
            String name) {
        super();
        this._id = _id;
        this.last_modified = last_modified;
        this.topics = topics;
        this.description = description;
        this.name = name;
    }



    public int getId() {
        return _id;
    }
    public void setId(int _id) {
        this._id = _id;
    }
    public Date getLast_modified() {
        return last_modified;
    }
    public void setLast_modified(Date last_modified) {
        this.last_modified = last_modified;
    }
    public int getTopics() {
        return topics;
    }
    public void setTopics(int topics) {
        this.topics = topics;
    }
    public String getDescription() {
        return description;
    }
    public void setDescription(String description) {
        this.description = description;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

}

现在,进入下一层,我的 DAO 包中有相应的 DAO 接口(interface):

@Transactional(propagation = Propagation.REQUIRED)
public interface ThreadDAO {

    public void addThread(Thread thread);
    public List<Thread> listThread();
    public void removeThread (int id);
    public void editThread(Thread thread);


}

及其实现:

@Repository("threadDao")
@Transactional
public class ThreadDAOImpl implements ThreadDAO{

    @Autowired
    SessionFactory sessionFactory;



    @Override
    public void addThread(Thread thread) {
        // TODO Auto-generated method stub
        sessionFactory.getCurrentSession().save(thread);    
    }

    @Override
    public List<Thread> listThread() {
        // TODO Auto-generated method stub
        return sessionFactory.getCurrentSession().createQuery("from Thread order by _id").list();
    }

    @Override
    public void removeThread(int id) {
        // TODO Auto-generated method stub
         Thread thread = (Thread) sessionFactory.getCurrentSession().load(
                    Thread.class, id);
            if (null != thread) {
                sessionFactory.getCurrentSession().delete(thread);
            }
    }

    @Override
    public void editThread(Thread thread) {
        // TODO Auto-generated method stub
        sessionFactory.getCurrentSession().update(thread);
    }

}

为了将数据推送到我的 Controller ,我使用自动连线服务:

@Transactional(propagation = Propagation.REQUIRED)
public interface ThreadService {

    public void addThread(Thread thread);
    public List<Thread> listThread();
    public void removeThread (int id);
    public void editThread(Thread thread);


}

实现:

@Service("threadService")
@Transactional
public class ThreadServiceImpl implements ThreadService{


    @Autowired
    ThreadDAO threadDAO;

    @Override
    public void addThread(Thread thread) {
        // TODO Auto-generated method stub
        threadDAO.addThread(thread);
    }

    @Override
    public List<Thread> listThread() {
        // TODO Auto-generated method stub
        return threadDAO.listThread();
    }

    @Override
    public void removeThread(int id) {
        // TODO Auto-generated method stub
        threadDAO.removeThread(id);
    }

    @Override
    public void editThread(Thread thread) {
        // TODO Auto-generated method stub
        threadDAO.editThread(thread);
    }

}

最后,我应该在 Controller 中执行 Service 方法:

@Controller
public class LoginController {

    @Autowired
    UserService userService;

    @Autowired
    ThreadService threadService;

    @RequestMapping(value = "/login", method = RequestMethod.GET)
    public ModelAndView login(
        @RequestParam(value = "error", required = false) String error,
        @RequestParam(value = "logout", required = false) String logout) {

        ModelAndView model = new ModelAndView();
        if (error != null) {
            model.addObject("error", "Invalid username and password!");
        }

        if (logout != null) {
            model.addObject("msg", "You've been logged out successfully.");
        }
        model.setViewName("login");

        return model;

    }



    @RequestMapping(value = "/standard", method = RequestMethod.GET)
    public ModelAndView standardView() 
    {

        ModelAndView model = new ModelAndView();
        model.setViewName("standard");
        return model; 

    }
}

这就是我的问题开始的地方。因为我总体上不擅长网络编程,而且请求映射的概念对我来说一直很困惑。 “标准”布局目前包含用户已登录的信息,并显示其用户名,此外我还为我的线程添加了列表布局:

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Access denied</title>
</head>
<body>
<!-- h1><spring:message code="access.denied"/></h1> -->
<h6>Logged in as: ${pageContext.request.userPrincipal.name}</h6>

<c:url value="/j_spring_security_logout" var="logoutUrl" />

    <!-- csrt for log out-->
    <form action="${logoutUrl}" method="post" id="logoutForm">
      <input type="hidden" 
        name="${_csrf.parameterName}"
        value="${_csrf.token}" />
    </form>
    <script>
        function formSubmit() {
            document.getElementById("logoutForm").submit();
        }
    </script>

<a href="javascript:formSubmit()"> Logout</a>

<h3><spring:message code="label.threadList"/></h3>
<c:if  test="${!empty threadList}">
<table class="data">
<tr>
    <th><spring:message code="label.threadName"/></th>
     <th><spring:message code="label.threadDescription"/></th>
    <th><spring:message code="label.threadTopicCount"/></th>
    <th><spring:message code="label.threadLastModified"/></th>

</tr>
<c:forEach items="${threadList}" var="thread">
    <tr>
        <td>${thread.name} </td>
        <td>${thread.description} </td>
        <td>${thread.topics}</td>
        <td>${thread.last_modified}</td>

    </tr>
</c:forEach>
</table>

缺少的是 Controller 中的请求映射。我如何映射它,以便它逐条记录地传递线程条目,并将它们与登录信息一起显示在这个布局中?

最佳答案

只需将对象添加到 Controller 中的 ModelAndView 实例即可:

model.addObject("threadList", threadService.listThread());

并且它应该可以在 JSP 页面中访问。

此外,请不要在 DAO 层上使用事务 - 仅在服务层上使用它。请参阅this post .

关于java - 使用 Spring Controller 列出数据库中的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28332198/

相关文章:

java - 正则表达式需要太多步骤

java - 隐藏空父项 - JFace 的 TreeViewer

java - 我在哪里可以找到 xuggler 简单教程?

mysql - 如何在 SQL 中创建多语言 Unicode 文本属性?

Spring 启动: can't create ear with maven: Unable to deduce layout

Spring Cloud - 如何仅允许访问特定微服务的端点?

java - 使用 MM/dd/yyyy hh :mm:ss zzz format in android 解析自定义日期

mysql - Linux:MySQL:如何在 Linux 中使用安装在 NTFS 上的 mysql 数据库作为 mysql 数据库?

mysql - 如何在多个表中实现唯一 ID

spring - @CreationTimestamp 和 @UpdateTimestamp 在 Kotlin 中不起作用