继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

eclipse整合ssh框架基础

心似一片青苔
关注TA
已关注
手记 27
粉丝 38
获赞 476
导语

最近在学习ssh框架,期间遇到各种错误,各种坑,挖坑填坑,生活还是美滋滋。为了日后重温旧梦,也为了遇到问题的伙伴能多些方法填坑,整理思路,梳理ssh

开发环境
  • 开发环境:window7
  • eclipse: Mars.2 Release (4.5.2)(插件:springsource-tool,hibernatetools-Update插件下载过期私我)。至于怎么装这两个插件(百度),为什么不用Myeclipse,不要问我/(ㄒoㄒ)/
  • Mysql 5.5.1
  • Tocat7.0 对ssh的初步理解

    ssh

    创建Dynamic Web项目
  • 创建web项目EMSystem,注意自动生成web.xml
    如图:(next->就能看见)
    web.xml
    web.xml

  • 添加项目所需jar包下载地址 过期私我 ,版本:Stuts2.3.24, Spring3.2.5, Hibernate3.0,怎么添加就交给小聪明你了O(∩_∩)O Struts2整合Spring
    1. 在Web容器中添加Spring核心监听器及Struts过滤器:
      web.xml
      <!-- 配置Spring核心监听器 -->
      <listener>
      <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
      </listener>
      <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:applicationContext.xml</param-value>
      </context-param>
      <!-- 配置Struts核心过滤器 -->
      <filter>
      <filter-name>struts</filter-name>
      <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
      </filter>
      <filter-mapping>
      <filter-name>struts</filter-name>
      <url-pattern>/*</url-pattern>
      </filter-mapping>
    2. 创建包结构,如图:
      包结构
  1. 编写简单的添加商品的业务功能,编写action,service,dao,entity类
    • 商品实体:Product.java

package com.ssh.entity;

/**
 * 表示商品的实体类
 * @author Administrator
 */
public class Product {
    // 商品id
    private Integer pid;
    // 商品名
    private String pname;
    // 商品价格
    private Double price;
    // getter,setter方法自动生成
}
  • 商品action:ProductAction.java
package com.ssh.action;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
import com.ssh.entity.Product;
import com.ssh.service.ProductService;
/**
 * 控制层
 * 采用模型驱动方式
 * @author Administrator
 */
public class ProductAction extends ActionSupport implements ModelDriven<Product>{
    // 模型驱动使用的类
    private Product product = new Product();
    // struts和spring整合自动注入的业务层类
    private ProductService productService;
    public void setProductService(ProductService productService) {
        this.productService = productService;
    }
    @Override
    public Product getModel() {
        // TODO Auto-generated method stub
        return product;
    }
    // 容易出错save()没有参数
    public String save(){
        System.out.println("ProductAction.save()方法被执行");
        productService.save(product);
        return NONE;
    }
}
  • service:ProductService.java
package com.ssh.service;
import org.springframework.transaction.annotation.Transactional;
import com.ssh.dao.ProductDao;
import com.ssh.entity.Product;
/**
 * 管理业务层的类
 * @author Administrator
 */
@Transactional
public class ProductService {
    // 业务层注入dao
    private ProductDao productDao;
    // setter方法注入bean
    public void setProductDao(ProductDao productDao) {
        this.productDao = productDao;
    }
    public boolean save(Product product){
        System.out.println("ProductService.save()方法被执行");
        productDao.save(product);
        return true;
    }
}
  • Dao:ProductDao.java
package com.ssh.dao;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.ssh.entity.Product;
/**
 * Dao层,持久层
 * @author Administrator
 */
public class ProductDao extends HibernateDaoSupport{
  public boolean save(Product product){
      System.out.println("ProductDao.save()被执行");
      return true;
  }
  //hibernate  框架  获取配置文件,configuration,sessionFactory,session,
}
  • 配置action,service,dao
    • 配置applicationContext.xml
      <!-- 配置注入Action bean 这时Action类交由spring进行管理 -->
      <bean id="productAction" class="com.ssh.action.ProductAction"
      scope="prototype">
      <property name="productService" ref="productService"></property>
      </bean>
      <!-- 配置注入productService bean -->
      <bean id="productService" class="com.ssh.service.ProductService" scope="prototype">
      <property name="productDao" ref="productDao"></property>
      </bean>
      <!-- 配置注入productDao bean -->
      <bean id="productDao" class="com.ssh.dao.ProductDao">
      <!-- 继承hibernateDaoSupport直接注入 -->
      <property name="sessionFactory" ref="sessionFactory"></property>
      </bean>

      struct.xml

    <package name="EmployeeManagementSystem" extends="struts-default" namespace="/">
        <action name="product_*" class="productAction" method="{1}">
        <!-- class="spring配置文件beanId" -->
        </action>
    </package>
  • 在WebContent下添加用于添加商品的addProduct.jsp页面
<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!-- 使用strut2标签库 -->
<%@ taglib uri="/struts-tags" prefix="s" %>
<!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>addProduct</title>
</head>
<body>
<h1>保存商品的页面</h1>
<s:form action="product_save.action" method="post" theme="simple">
    <table border="1" width="500">
        <tr>
            <td>商品名称</td>
            <td> <s:textfield name="pname"/> </td>
        </tr>
        <tr>
            <td>商品价格</td>
            <td> <s:textfield name="price"/> </td>
        </tr>
        <tr>
            <td colspan="2"> <s:submit value="添加"/> </td>
        </tr>
    </table>
</s:form>
</body>
</html>
  • 好了,struts整合到此为止,可以试试看有没有点成就感,出错要耐心′`
    测试 Spring整合Hibernate

    * 先做基础,创建ssh数据库,添加jdbc.properties,log4j.properties 源码里面有
    jdbc.properties

jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://localhost\:3306/ssh?useUnicode\=true&characterEncoding\=utf-8
#jdbc:mysql://localhost:3306/ssh
jdbc.username=root
jdbc.password=123456
  • 利用插件或myeclipse自动生成映射文件Product.hbm.xml
<?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-4-6 16:29:10 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
    <class name="com.ssh.entity.Product" table="PRODUCT">
        <id name="pid" type="java.lang.Integer">
            <column name="PID" />
            <generator class="native" />
        </id>
        <property name="pname" type="java.lang.String">
            <column name="PNAME" />
        </property>
        <property name="price" type="java.lang.Double">
            <column name="PRICE" />
        </property>
    </class>
</hibernate-mapping>
  • 再次配置applicationContext.xml,完成真正的连接数据
    <!-- 引入外部属性文件 -->
    <context:property-placeholder location="classpath:jdbc.properties" />

    <!-- 配置连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driverClass}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>     

    <!-- 配置hibernate的相关属性 -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource"></property>
        <!-- 配置hibernate属性 -->
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">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>
        <!-- 配置mapping -->
        <property name="mappingResources">
            <list>
                <value>com/ssh/entity/Product.hbm.xml</value>
            </list>
        </property>
    </bean>
  • 测试下自动创建表是否成功,执行项目即可
  • 添加持久层代码,将商品信息保存到数据库(红色注释下方代码)
    ProductDao.java
public class ProductDao extends HibernateDaoSupport{
  public boolean save(Product product){
      System.out.println("ProductDao.save()被执行");
      // 获取配置文件,configuration,sessionFactory,session,简化了操作
      this.getHibernateTemplate().save(product);
      return true;
  }
}
  • 添加数据库操作的事务处理
    applicationContext.xml
    <!-- 配置事务管理器 -->
    <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

    <!-- 开启注解事务 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>
  • 整合就完成了,做最后的测试,喝杯水压压惊,测试开始(我这里数据库是可视化操作)oh,如果出错了,一步一步拍错呗
    测试
    测试 常见问题及解决方案
  • 错误代码
there is no Action mapped for namespace[/] and action name [product_save] associated with context path[/ssh]
  1. 检查,struts.xml和applicationContext.xml中关于action的配置,name 和class是否正确
  2. 检查action类,save()方法是否写对,(save()是没有参数的,我就错在这)。
  • 出现一些奇怪的错误可以试试clean下。(有什么问题可留言)
  • 欢迎伙伴们一起快乐学习交流
打开App,阅读手记
64人推荐
发表评论
随时随地看视频慕课网APP

热门评论

项目源码:https://github.com/kkxiaojun/SSH/tree/master/sshM

博主dalao,过期啦网盘

非常有帮助,大赞。。。

查看全部评论