手记

SSH框架整合,最基础开始(详细)

1.首先先创建一个动态web项目。

2.一路点击next最后记得勾选创建创建xml文档选项。

3.创建完成之后首先添加本次项目所需要的jar包。为避免在找jar过程中的麻烦,我已经所有jar包上传至百度网盘。
链接:http://pan.baidu.com/s/1eRLnf6i 密码:vc2a

4.将所有jar包添加至如图的lib目录下。

5.选中所有jar包,右键BuildPath-->Configure buil path。

6.添加完成之后打开web.xml文档,添加Struts2的核心过滤器。

7.中间红框标明的那一段,我们把鼠标放上面,按住Ctrl然后点击,之后弹出这个页面就说明我们添加正确。

8.再后续添加Spring监听器。

9.同理如此添加spring监听器。也将鼠标置于org.springframework.web.context.ContextLoaderListener上面,按住ctrl点击,弹出这个页面就说明添加正确,那个applicationContext.xml后续进行创建。

10.添加Spring容器,创建appliactionContext.xml文件。

文件取名为applicationContext.xml
点击next选中aop、beans、context类别

11.再创建一个普通xml文件,与applicationContext.xml放在同一个文件夹,文件结构如下图所示

12.然后编辑struts.xml基本文件,我是从struts工具包中拷贝过来的xml文件再做修改。struts.xml文件先这样后续再进行修改

13.在webContent文件夹下先创建一个普通jsp文件,取名index.jsp。在内部先添加一个连接,先打通struts跳转逻辑再后续添加内容,这个页面只用添加一行内容就不添加图片了。

<a href="employee">跳转</a>

14.接下来创建action类,再src目录下先创建com.imooc.action包,由于这次使用ssh框架来搭建员工管理系统,所以先创建EmployeeAction类。action类中新建一个save方法让save方法直接返回success字符串。

15.继续修改struts.xml文件,添加跳转的逻辑。看图知肯定还需要创建一个success.jsp页面用来提示跳转成功。随便在success.jsp页面随便输点东西,自己认识就好。

16.接下来测试struts跳转是否成功。将项目部署到tomcat容器中,在开启项目的时候出错了,提示找不到applicationContext.xml。经查看是我在创建applicationContext.xml文件过程中,文件名少写了一个a,添加之后运行正常。顺利打开indes.jsp页面。

17.点击跳转按钮,跳转到success.jsp页面,至此struts顺利打通。

18.接下来我们整合spring。在整合spring之前我们先来创建两个类。分别是EmployeeService与EmployeeDao,在这里我并没有使用接口的方式,如果想练习也可以使用接口。

再分别编辑action,service与dao类。
action:

package com.imooc.action;

import com.imooc.service.EmployeeService;
/**
 * 保存员工的action
 * @author ha
 *
 */
public class EmployeeAction {

    //使用spring传入EmployeeService实例
    EmployeeService employeeService;

    public void setEmployeeService(EmployeeService employeeService) {
        this.employeeService = employeeService;
    }

    public String save(){
        System.out.println("action执行了");
        employeeService.saveEmployee();

        return "success";
    }
}

service:

package com.imooc.service;

import com.imooc.dao.EmployeeDao;

/**
 * 保存员工service类
 * @author ha
 *
 */
public class EmployeeService {

    //使用spring自动注入EmployeeDao实例
    EmployeeDao employeeDao;

    public void setEmployeeDao(EmployeeDao employeeDao) {
        this.employeeDao = employeeDao;
    }

    public void saveEmployee() {
        // TODO Auto-generated method stub
        System.out.println("service执行了");
        employeeDao.saveEmployee();

    }

}

dao:

package com.imooc.dao;

public class EmployeeDao {

    public void saveEmployee() {
        // TODO Auto-generated method stub
        System.out.println("dao层执行了");
    }

}

19.接下来编辑applicationContext.xml配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd">

    <!-- 创建dao -->
    <bean id="employeeDao" class="com.imooc.dao.EmployeeDao">

    </bean>
    <!-- 创建service 自动注入dao -->
    <bean id="employeeService" class="com.imooc.service.EmployeeService">
        <property name="employeeDao" ref="employeeDao"></property>
    </bean>
    <!-- 创建action -->
    <bean id="employeeAction" class="com.imooc.action.EmployeeAction"> 
        <property name="employeeService" ref="employeeService"></property>
    </bean>

</beans>

20.然后进行测试。试试,action,service,dao三层是否可以正常运行。控制台正常打印出三层分别执行。说明spring配置文件并未书写错误。

21.整合hibernate。首先需要创建一个实体类,员工一般会有部门信息,但我这为了简单并没有写部门信息,只包含:用户ID,用户名,密码,性别,将实体类放于新建的包com.imooc.entity下;
Employee:

package com.imooc.entity;

/**
 * 员工实体类
 * @author ha
 *
 */
public class Employee {

    private int empId;
    private String empName;
    private String password;
    private String gender;
    public int getEmpId() {
        return empId;
    }
    public void setEmpId(int empId) {
        this.empId = empId;
    }
    public String getEmpName() {
        return empName;
    }
    public void setEmpName(String empName) {
        this.empName = empName;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public String getGender() {
        return gender;
    }
    public void setGender(String gender) {
        this.gender = gender;
    }

}

22.实体类写完之后,我们在创建hibernate映射文件hbm.xml。在我们刚刚创建的com.imooc.entity包上右键新建选择hbm文件。

一路点击next,最后finish,这里为hibernate自动生成的hbm文件,我们将id的生成方法改为native。到时候这个文件会帮我们自动生成数据库文件。

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-7-2 17:08:46 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
    <class name="com.imooc.entity.Employee" table="EMPLOYEE">
        <id name="empId" type="int">
            <column name="EMPID" />
            <generator class="native" />
        </id>
        <property name="empName" type="java.lang.String">
            <column name="EMPNAME" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="PASSWORD" />
        </property>
        <property name="gender" type="java.lang.String">
            <column name="GENDER" />
        </property>
    </class>
</hibernate-mapping>

23.接下来在spring配置文件中配置数据库的相关属性,这里也可以将连接数据库的信息单独写成一个properties文件。将下面这些内容添加至spring配置文件的beans标签之间。

<!-- 配置hibernate属性 -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource"></property>
        <!-- 配置hibernate属性 -->
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dielect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.show_sql"> true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
            </props>
        </property>
        <!-- 加载映射文件 -->
        <property name="mappingResources">
            <list>
                <value>com/imooc/entity/Employee.hbm.xml</value>
            </list>
        </property>

    </bean>

24.验证这些配置文件是否配置无误。我们现在数据库中先创建一个ssh-test数据库。然后部署这个项目,如果自动生成了数据表则配置正确。我这里成功生成employee的数据表,表明数据库连接正常,配置成功。

25.接下来我们尝试保存一个员工信息。先更改action类的编写。这里我们让action类继承actionsupport类,实现modelDriven接口。实现model Driven接口,需要实现getModel方法,这样可以传递页面的员工信息。
action类:

package com.imooc.action;

import com.imooc.entity.Employee;
import com.imooc.service.EmployeeService;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
/**
 * 保存员工的action
 * @author ha
 *
 */
public class EmployeeAction extends ActionSupport implements ModelDriven<Employee>{

    Employee employee = new Employee();

    @Override
    public Employee getModel() {
        // TODO Auto-generated method stub
        return employee;
    }

    //使用spring传入EmployeeService实例
    EmployeeService employeeService;

    public void setEmployeeService(EmployeeService employeeService) {
        this.employeeService = employeeService;
    }

    public String save(){
        System.out.println("action执行了");
        employeeService.saveEmployee();

        return "success";
    }

}

26.这时候就需要修改service和dao的保存方法了。修改dao类的同时我们需要给dao注入一个sessionFactory对象,只需要在spring配置文件种配置一下即可。添加这项内容即可。<property name="sessionFactory" ref="sessionFactory"></property>

service类:

package com.imooc.service;

import com.imooc.dao.EmployeeDao;
import com.imooc.entity.Employee;

/**
 * 保存员工service类
 * @author ha
 *
 */
public class EmployeeService {

    //使用spring自动注入EmployeeDao实例
    EmployeeDao employeeDao;

    public void setEmployeeDao(EmployeeDao employeeDao) {
        this.employeeDao = employeeDao;
    }

    public void saveEmployee(Employee employee) {
        // TODO Auto-generated method stub
        System.out.println("service执行了");
        employeeDao.saveEmployee(employee);

    }

}

dao类:

package com.imooc.dao;

import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import com.imooc.entity.Employee;

public class EmployeeDao extends HibernateDaoSupport{

    public void saveEmployee(Employee employee) {
        // TODO Auto-generated method stub

        System.out.println("dao层执行了");
        this.getHibernateTemplate().save(employee);
    }

}

27.然后测试员工保存方法。在初始index.jsp页面上写一个form表单,然后提交员工信息,查看是否可以保存至数据库。这里是index.jsp页面。

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>

<form action="employee" method="post">
    用户名:<input type="text" name="empName"/><br>
    密码:<input type="password" name="password"/><br>
    性别:<input type="text" name="gender"/><br>
    <input type="submit" value="提交"/>
</form>
</body>
</html>

28.部署项目运行。填写员工信息。

29.打开数据库查看信息是否存在。

30.经验证数据库中的信息与我们在页面填写的信息一致。
这个项目我已经上传至百度云,可以下载源码观看。链接:http://pan.baidu.com/s/1mhXT2v2 密码:n9cw
此次SSH整合项目完成,实现了保存员工到数据库的方法,然后便可以进行增删改查的编写。

19人推荐
随时随地看视频
慕课网APP

热门评论

敲了几遍,终于成功了!写的很详细,超赞

你好,请问一下走到第20步测试的时候          Action里的保存报了空指针异常是怎么回事        

404 怎么回事?

查看全部评论