1.先建张表
用的是mysql数据库..
文章表.
		
				
				 
				CREATE
				   
				TABLE
				  `t_article` (
  `a_id`  
				int
				 ( 
				11
				 )  
				NOT
				   
				NULL
				  auto_increment,
  `a_sort`  
				int
				 ( 
				11
				 )  
				NOT
				   
				NULL
				   
				default
				   
				'
				 0 
				'
				 ,
  `a_title`  
				varchar
				 ( 
				50
				 )  
				default
				   
				NULL
				 ,
  `a_body`  
				text
				 ,
  `a_author`  
				varchar
				 ( 
				11
				 )  
				default
				   
				''
				 ,
  `a_hit`  
				int
				 ( 
				11
				 )  
				NOT
				   
				NULL
				   
				default
				   
				'
				 0 
				'
				 ,
  `c_id`  
				int
				 ( 
				11
				 )  
				default
				   
				'
				 0 
				'
				 ,
  `a_date`  
				varchar
				 ( 
				20
				 )  
				default
				   
				NULL
				 ,
   
				PRIMARY
				   
				KEY
				   (`a_id`)
)  
		 
		2:写vo
		
				
				package
				 firstspring.vo;

				public
				 
				class
				 articleVO 
				
						
				
				
						{
    
						private
						 
						int
						 a_id;
    
						private
						 
						int
						 a_sort;
    
						private
						 
						int
						 a_hit;
    
						private
						 
						int
						 c_id;
    
						private
						 String a_title;
    
						private
						 String a_body;
    
						private
						 String a_author;
    
						private
						 String a_date;



    
						public
						 articleVO() 
						
								
						
						
								{
    }
						
						
								
								
   
						//
						写上get() set()方法
				
		 
		3 写VO映射文件
		
				
				<?
				xml version="1.0" encoding="UTF-8"
				?>
				
						
						
				
				<!
				DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"
				>
				
						
						
				
				<
				hibernate-mapping
				>
				
						
						
    
				<
				class 
				name
				="firstspring.vo.articleVO"
				 table
				="t_article"
				 
				>
				
						
						
    
				<
				id 
				name
				="a_id"
				 column
				="a_id"
				 unsaved-value
				="0"
				 
				>
				
						
						
      
				<
				generator 
				class
				="native"
				/>
				
						
						
 
				</
				id
				>
				
						
						
     
				<
				property 
				name
				="c_id"
				    column
				="c_id"
				/>
				
						
						
     
				<
				property 
				name
				="a_title"
				 column
				="a_title"
				/>
				
						
						
     
				<
				property 
				name
				="a_sort"
				  column
				="a_sort"
				/>
				
						
						
     
				<
				property 
				name
				="a_date"
				  column
				="a_date"
				/>
				
						
						
     
				<
				property 
				name
				="a_body"
				  column
				="a_body"
				/>
				
						
						
     
				<
				property 
				name
				="a_hit"
				   column
				="a_hit"
				/>
				
						
						
     
				<
				property 
				name
				="a_author"
				 column
				="a_author"
				/>
				   
  
				</
				class
				>
				
						
						
				
				</
				hibernate-mapping
				>
		 
		4: 写dao层接口和bll层接口
  4.1 dao层接口
		
				
				package
				 firstspring.idao;
				import
				 firstspring.vo.articleVO;

				public
				 
				interface
				 ArticleIdao 
				
						
				
				
						{
    
    
						void
						 addArticle(articleVO vo);         
}
				
		 
		4.2 bll层接口
		
				
				package
				 firstspring.idao;
				import
				 firstspring.vo.articleVO;

				public
				 
				interface
				 IArticleBLL 
				
						
				
				
						{
     
						void
						 addArticle(articleVO vo);  
}
				
		 
		5:写Articledao类
		
				
				package
				 firstspring.dao;
				import
				 org.springframework.orm.hibernate.support.HibernateDaoSupport;
				import
				 firstspring.idao.ArticleIdao;
				import
				 firstspring.vo.articleVO;

				public
				 
				class
				 ArticleDal 
				extends
				 HibernateDaoSupport 
				implements
				 ArticleIdao 
				
						
				
				
						{

    
						public
						 ArticleDal() 
						
								
						
						
								{
    }
						
						
								
								
    
						public
						 
						void
						 addArticle(articleVO vo)

    
						
								
						
						
								{
        
								this
								.getHibernateTemplate().save(vo);
        
								this
								.getHibernateTemplate().flush();
        
    }
						
						
								
								
}
				
		 
		6.写Articlebll类
package firstspring.bll;
import firstspring.idao.ArticleIdao;
import firstspring.idao.IArticleBLL;
import firstspring.vo.articleVO;


public class ArticleBll implements IArticleBLL 
{
   private ArticleIdao dal=null;

    public ArticleBll() 
{
    }
    public void addArticle(articleVO vo)

    
{
        dal.addArticle(vo);
    }


    public ArticleIdao getDal() 
{
        return dal;
    }


    public void setDal(ArticleIdao dal) 
{
        this.dal = dal;
    }
}7:添加struts框架。
  7.1 建个BaseAction类继承Action
package firstspring.struts;

import org.apache.struts.action.*;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
import javax.servlet.ServletContext;


public abstract class BaseAction extends Action 
{
    
    private WebApplicationContext wac;

    public BaseAction() 
{
    }
    public void setServlet(ActionServlet actionServlet)

    
{
        super.setServlet(actionServlet);
        ServletContext servletContext=actionServlet.getServletContext();
       wac=WebApplicationContextUtils.getRequiredWebApplicationContext(servletContext);
       //wac.get
    }
    public WebApplicationContext getweb()

    
{
        return wac;
    }
  
}8:添加articleForm
package firstspring.struts;

import javax.servlet.*;
import javax.servlet.http.*;

import org.apache.commons.validator.*;
import org.apache.struts.action.*;
import org.apache.struts.validator.*;


public class articleForm extends ValidatorForm 
{
    private String a_auhor;
    private String a_body;
    private String a_date;
    private Integer a_hit;
    private Integer a_id;
    private Integer a_sort;
    private String a_title;
    private Integer c_id;


    public String getA_auhor() 
{
        return a_auhor;
    }


    public void setA_auhor(String a_auhor) 
{
        this.a_auhor = a_auhor;
    }


    public void setC_id(Integer c_id) 
{
        this.c_id = c_id;
    }


    public void setA_title(String a_title) 
{
        this.a_title = a_title;
    }


    public void setA_sort(Integer a_sort) 
{
        this.a_sort = a_sort;
    }


    public void setA_id(Integer a_id) 
{
        this.a_id = a_id;
    }


    public void setA_hit(Integer a_hit) 
{
        this.a_hit = a_hit;
    }


    public void setA_date(String a_date) 
{
        this.a_date = a_date;
    }


    public void setA_body(String a_body) 
{
        this.a_body = a_body;
    }


    public String getA_body() 
{
        return a_body;
    }


    public String getA_date() 
{
        return a_date;
    }


    public Integer getA_hit() 
{
        return a_hit;
    }


    public Integer getA_id() 
{
        return a_id;
    }


    public Integer getA_sort() 
{
        return a_sort;
    }


    public String getA_title() 
{
        return a_title;
    }


    public Integer getC_id() 
{
        return c_id;
    }

    public ActionErrors validate(ActionMapping actionMapping,

                                 HttpServletRequest httpServletRequest) 
{
        ServletContext application=this.getServlet().getServletContext();
        ActionErrors errors=new ActionErrors();
        String validationKey=this.getValidationKey(actionMapping,httpServletRequest);
        Validator validator=Resources.initValidator(validationKey,this,application,httpServletRequest,errors,page);//String,Object,ServletContext,HttpServletRequest,ActionMessages,int
        try

        
{
            validatorResults=validator.validate();
        }
        catch(ValidatorException e)

        
{
            //log.error(e.getMessage(),e);
        }
        return null ;

    }

    public void reset(ActionMapping actionMapping,

                      HttpServletRequest servletRequest) 
{
    }
}

9:添加ArticleAction继承刚刚建的BaseAction
package firstspring.struts;

import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionForm;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.ActionForward;
import firstspring.vo.articleVO;
import firstspring.idao.IArticleBLL;


public class articleAction extends BaseAction 
{
    public ActionForward execute(ActionMapping mapping, ActionForm form,
                                 HttpServletRequest request,
                          HttpServletResponse response) {
                                //这里有几个数据直接写上了,没有从前台表单取。。     
        articleForm f = (articleForm) form;
        articleVO vo=new articleVO();
        vo.setA_author(f.getA_auhor());
        vo.setA_body(f.getA_body());
        vo.setA_hit(100);
        vo.setA_date(f.getA_date());
        vo.setA_sort(0);
        vo.setC_id(1);
        vo.setA_title(f.getA_title());
        //IArticleBLL 
     IArticleBLL ibll=(IArticleBLL)this.getweb().getBean("articlebll");
     ibll.addArticle(vo);
     
       return null;
    }
}

好了。到这就快差不多了。。还有个重要的东西。写个appcontext.xml配置文件。工厂就在这了。。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
    "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>


<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName"><value>org.gjt.mm.mysql.Driver</value></property>
  <property name="url"><value>jdbc:mysql://localhost:3306/wjcms</value></property>
  <property name="username"><value>root</value></property>
  <property name="password"><value>wujun</value></property>
</bean>


    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate.LocalSessionFactoryBean">

        <property name="dataSource">
            <ref local="dataSource"/>
        </property>


        <property name="mappingResources">
            <list>
                <value>
                    articleVO.hbm.xml
                </value>
       
            </list>
            
        </property>

        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">
                    net.sf.hibernate.dialect.MySQLDialect
                </prop>
                <prop key="hibernate.show_sql">
                    true
                </prop>
            </props>
        </property>
    </bean>

    <bean id="articledal" class="firstspring.dao.ArticleDal">
       <property name="sessionFactory"><ref local="sessionFactory"/></property>
    </bean>
    
    <bean id="articlebll" class="firstspring.bll.ArticleBll">
       <property name="dal"><ref local="articledal"/></property>   
    </bean>
</beans>

建个jsp页面。测试添加一条记录看看。这是前台的代码。。
<html:form action="/articleAction.do" method="POST">
<html:text property="a_auhor"/>
<br>
<html:text property="a_body"/>
<br>
<html:text property="a_date"/>
<br>
<br>
<br>
<br>
<html:text property="a_title"/>
<br>
<br>
<html:submit property="submit" value="Submit"/><br>
<html:reset value ="Reset"/>
</html:form>到这就快差不多了。还有一个小事情,在web.xml里记的加上一句
 <servlet>
    <servlet-name>context</servlet-name>
    <servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>好,运行一下。。OK 。数据进数据库了。
专家多指点。。......