zoukankan      html  css  js  c++  java
  • eclipse整合ssh框架基础

    导语

    最近在学习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. 创建包结构,如图:
      包结构

    3. 编写简单的添加商品的业务功能,编写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下。(有什么问题可留言)
      • 欢迎伙伴们一起快乐学习交流
      • github源码地址
    清风徐来,水波不兴
  • 相关阅读:
    KL散度与反向KL散度
    matplotlib 清除axis plt.cla()、plt.clf()、plt.close()
    fig,ax = plt.subplots()
    python matplotlib 中ax.legend()用法解释
    Tensorflow 创建神经网络(二)可视化
    Tensorflow 创建神经网络(一)
    Tensorflow add_layer
    Tensorflow feed_dict={}
    Tensorflow tf.assign的使用
    百度编辑器去掉本地保存
  • 原文地址:https://www.cnblogs.com/it-xiaojun/p/6814755.html
Copyright © 2011-2022 走看看