s2sh框架搭建mysql_搭建一个完整的SSH框架

一、jar包的下载和选择

第一步:下载jar包

69030f8f5437

image.png

69030f8f5437

image.png

69030f8f5437

image.png

69030f8f5437

image.png

69030f8f5437

image.png

69030f8f5437

image.png

69030f8f5437

image.png

第二步:选择三个框架的基础jar包文件,准备放入搭建的项目里

本项目下载的SSH框架的jar包版本,分别为:hibernate-release-5.4.0.Final(hibernate)、mysql-connector-java-8.0.13(mysql连接)、spring-framework-5.1.3.RELEASE(spring)、struts-2.5.18(struts2)

(1)struts的基础jar包:

69030f8f5437

image.png

(2)spring的jar包(应为不多,所以暂时全部包括):

69030f8f5437

image.png

(3)hibernate的基础jar包:

69030f8f5437

image.png

(4)mysql连接的jar包:

69030f8f5437

image.png

二、项目搭建

项目搭建工具:eclipse、navicat premium

项目开发环境:①Windows10-64位 ②Tomcat 9.0 ③jdk1.8.0_91 ④MySql 8.0.11

第一步:新建项目,导入jar包,并配置web.xml

(1)新建一个Dynamic Web Project,可命名为ssh_01,直接点击finish按钮

69030f8f5437

image.png

(2)将选择的jar包导入到lib(/WebContent/WEB-INF/lib)中

69030f8f5437

image.png

(3)将导入的jar包添加到项目Libraries中,项目右键==》Properties==》Java Build Path==》Libraries==》选中导入的所有jar包添加到进Libraries中

69030f8f5437

image.png

69030f8f5437

image.png

(4)在/WebContent/WEB-INF/下新建一个web.xml,配置过滤器和监听器

web.xml:

xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"

id="WebApp_ID" version="3.1">

ssh

index.action

struts2

org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter

struts2

/*

contextConfigLocation

classpath:applicationContext.xml

org.springframework.web.context.ContextLoaderListener

第二步 创建用于分层的四个基础包,并分别添加BookCard的操作类

(1)项目切换到Project Explorer窗口,在/Java Resources/src/目录下创建四个包(package)

69030f8f5437

image.png

(2)根据数据库表的字段编写BookCard(实体类)和BookCard.hbm.xml(映射文件)放到ssh_01.entity包里

BookCard.java:

package ssh_01.entity;

import java.math.BigDecimal;

import java.util.Date;

public class BookCard {

private int cid ;

private String name;

private String sex ;

private Date cardDate;

private BigDecimal deposit;

public int getCid() {

return cid;

}

public void setCid(int cid) {

this.cid = cid;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public Date getCardDate() {

return cardDate;

}

public void setCardDate(Date cardDate) {

this.cardDate = cardDate;

}

public BigDecimal getDeposit() {

return deposit;

}

public void setDeposit(BigDecimal deposit) {

this.deposit = deposit;

}

}

BookCard.hbm.xml:

/p>

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

(3)在ssh_01.dao包里编写BookCardDao(接口类)和BookCardDaoImpl(实现类)。

BookCardDao.java:

package ssh_01.dao;

import java.util.List;

import ssh_01.entity.BookCard;

public interface BookCardDao {

public List getAllBookCard();

}

BookCardDaoImpl.java:

package ssh_01.dao;

import java.util.List;

import org.hibernate.Session;

import org.hibernate.SessionFactory;

import org.hibernate.cfg.Configuration;

import org.hibernate.query.Query;

import ssh_01.entity.BookCard;

public class BookCardDaoImpl implements BookCardDao {

//在SSH的设计理念:要使用某个实例,那么就定义声明一个对象,然后

//给它添加set方法(用于spring注入进来)

//实现不要关注这个实例来自于那里,以及怎么创建,或者它是谁

private SessionFactory sessionFactory;

public void setSessionFactory(SessionFactory sessionFactory) {

this.sessionFactory = sessionFactory;

}

@Override

public List getAllBookCard() {

//sessionFactory这个实例可以自己按常规的hibernate传统写法创建

//也可以交给spring去托管

Configuration cfg = new Configuration().configure();

sessionFactory = cfg.buildSessionFactory();

//获取session

Session session = sessionFactory.openSession();

//后面当使用JPA的时候,EntityManager 类似于 Session

Query query = session.createQuery("from BookCard");

//将所有的数据查询出来并放到List集合里

List list = query.getResultList();

//将集合遍历循环

for(BookCard bookCard:list){

//打印输出到控制台

System.out.println(bookCard);

}

//关闭session

session.close();

//关闭sessionFactory

sessionFactory.close();

//返回list集合

return list;

}

}

(4)在ssh_01.service包里编写BookCardService(接口类)和BookCardServiceImpl(实现类)。

BookCardService.java:

package ssh_01.service;

import java.util.List;

import ssh_01.entity.BookCard;

public interface BookCardService {

public List getAllBookCard();

}

BookCardServiceImpl.java:

package ssh_01.service;

import java.util.List;

import ssh_01.dao.BookCardDao;

import ssh_01.entity.BookCard;

public class BookCardServiceImpl implements BookCardService{

//dao实例使用注入方式

private BookCardDao id;

//用于注入使用

public void setId(BookCardDao id) {

this.id = id;

}

@Override

public List getAllBookCard() {

//本类应该编写业务逻辑的代码,

//但本例没有业务逻辑,就不用写。

//访问数据库的代码,不会出现在service这一层

//交给dao来操作数据库

List myBookCardList = id.getAllBookCard();

//进行其它的业务逻辑操作,比如增加多一个选项,是否过期

//本例不需要

//....

return myBookCardList;

}

}

(5)在ssh_01.action包里编写IndexAction(action类)。

IndexAction.java:

package ssh_01.action;

import java.text.DecimalFormat;

import java.util.List;

import com.opensymphony.xwork2.ActionContext;

import com.opensymphony.xwork2.ActionSupport;

import ssh_01.entity.BookCard;

import ssh_01.service.BookCardService;

//创建IndexAction(action类)继承ActionSupport接口

public class IndexAction extends ActionSupport {

private static final long serialVersionUID = 1L;

//声明service,但不给它创建具体的实现类的实例,

private BookCardService is = null;

//添加set()方法

public void setIs(BookCardService is) {

this.is = is;

}

//编写execute()方法

public String execute() {

//获取IndexService实例,调用getAllBookCard()方法

//将结果保存到List集合里

List myBookCardList = is.getAllBookCard();

//将查询出来的结构集打印到控制台

System.out.println("结果集:"+myBookCardList.size());

//获取Context上下文对象

ActionContext ac = ActionContext.getContext();

//将myBookCardList集合添加到上下文对象里

ac.put("myBookCardList", myBookCardList);

//返回一个字符串

return "success";

}

//金额格式转换

public String formatDouble(double s){

DecimalFormat fmat=new DecimalFormat("\u00A4##.0");

return fmat.format(s);

}

}

第三步 编写struts.xml(struts配置文件)、applicationContext.xml(spring配置文件)、hibernate.cfg.xml(hibernate配置文件)

(1)在/src/目录下新建配置文件struts.xml、applicationContext.xml、hibernate.cfg.xml

69030f8f5437

image.png

(2)编写各配置文件

struts.xml:

/p>

"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"

"http://struts.apache.org/dtds/struts-2.5.dtd">

/WEB-INF/jsp/index.jsp

applicationContext.xml:

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:p="http://www.springframework.org/schema/p"

xmlns:aop="http://www.springframework.org/schema/aop"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:jee="http://www.springframework.org/schema/jee"

xmlns:tx="http://www.springframework.org/schema/tx"

xsi:schemaLocation="

http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd

http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd

http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee.xsd

http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

hibernate.cfg.xml:

/p>

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/ssh_01

root

123456

org.hibernate.dialect.MySQLDialect

5

true

true

update

第四步 显示结果

(1)在/WebContent/WEB-INF/目录下创建文件夹jsp,再在/jsp/目录下创建一个index.jsp页面

69030f8f5437

image.png

(2)将所有数据取出来显示到index.jsp页面上

index.jsp:

pageEncoding="UTF-8"%>

Insert title here
卡号姓名性别办卡日期押金
没有查找到数据

(3)运行项目并显示结果

表中无数据时:

69030f8f5437

image.png

表中有数据时:

69030f8f5437

image.png

总结

虽然按照该步骤完成了SSH框架的整合和搭建,并显示出相应的结果,并对其中某些步骤的细节仍需要研究,特别是配置文件的使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值