gpt4 book ai didi

java - Spring mvc jdbc 和 hibernate

转载 作者:行者123 更新时间:2023-11-29 12:32:25 25 4
gpt4 key购买 nike

我需要一些帮助来理解 spring mvc 中发生的事情!假设我有一个展示书籍的项目,我有:

一个包含书籍的数据库(mysql),如下所示:

INSERT INTO books (title, author) VALUES ('Some book', 'this author')

这些书还有一个自动递增的 ID (book_id)

在我们的项目中,我们有一个图书类:

@Entity
@Table
public class Books {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column
private int book_id;
private String title;
private String author;

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column
public int getBook_id() {
return book_id;
}

public void setBook_id(int book_id) {
this.book_id = book_id;
}

public String getTitle() {
return title;
}

public void setTitle(String title) {
this.title = title;
}

public String getAuthor() {
return author;
}

public void setAuthor(String author) {
this.author = author;
}

我们有一个 DAO

@Repository
public interface bookDao {
public List<Book> BookList();
}

以及 Dao 实现

@Controller
@Transactional
public class BookDAOImpl implements BookDao {

@Inject
private SessionFactory sessionFactory;

private Session getSession(){
return sessionFactory.getCurrentSession();
}

@Override
public List<Book> bookList(){
return getSession().createQuery("from Book").list();
}

服务

@Service
@Transactional
public class BookService {

@Autowired
private BookDao bookDao;

public List<Book> list(){
return bookDao.bookList();
}

和 Controller

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

@Autowired
BookService bookService;

@RequestMapping(value="/menu",method = RequestMethod.GET)
public String printMenu(){
return "menu";
}

@RequestMapping(value="/list", method = RequestMethod.GET)
public void list (Model model){
List<Book> books = bookService.list();
model.addAttribute("books", books);
}
}

最后,mvc 调度程序

    <context:component-scan base-package="package"/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"/>
<property name="suffix" value=".jsp"/>
</bean>

<util:properties id="hibernateProperties">
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">false</prop>
</util:properties>

<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource"
p:driverClassName="com.mysql.jdbc.Driver"
p:url="URL"
p:username="USERNAME"
p:password="PASSWORD"/>

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"
p:dataSource-ref="dataSource"
p:packagesToScan="package"
p:hibernateProperties-ref="hibernateProperties"/>

<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"
p:sessionFactory-ref="sessionFactory"/>

我们还有 .jsp 页面/menu 和/list

当我转到 localhost:port 时,我将被定向到/menu 页面,当我按“转到/list”时,会发生什么以及它是如何工作的?我希望有人能解释这个过程,我很难理解“bean”和“autowire”,所以如果你知道,请分享!

以及根据请求的 web.xml!

    <display-name>Spring MVC Application</display-name>

<servlet>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

最佳答案

这很容易理解,但这是您所要求的 Spring 基础知识,因此阅读一篇不错的教程或 Spring 书籍将是您所期望的努力......

Spring MVC 构建在 Servlet 技术之上。 DispatcherServlet 是处理 Spring 时最重要的入口点。它负责接受和分发传入 Spring Web 应用程序的请求。

DispatcherServlet(其配置通常位于web.xml中)接收您的HelloController请求。请注意,方法上方有一个 @RequestMapping("/") 。这指向您的 Web 应用程序的根上下文路径。因此,点击localhost:port会将请求路由到这个特定的Controller(通过DispatcherServlet)。

出于同样的原因,通过指向 /list,您的请求将被路由到该特定方法。

@Autowired 是一个注释,它告诉 Spring 容器初始化该特定 bean (POJO)、解析依赖项,然后将其提供/注入(inject)到您的资源中以供使用。这称为依赖注入(inject)或 DI,如果您使用 Spring,您应该知道它是什么以及我们为什么使用它。

您称为 mvc-dispatcher 的文件是您配置 Spring 容器或上下文的方式。 bean 是一个简单的类,定义后将由 Spring 容器管理。我所说的管理是指:初始化、解决依赖关系并在需要时注入(inject)。

我可以永远继续下去,但这应该是你的开始......

关于java - Spring mvc jdbc 和 hibernate,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27278007/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com