欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

项目OA之框架搭建整合基于SSH,Jquery,MySQL

程序员文章站 2024-01-14 15:05:10
...

1.重中之重项目的开始一些的准备工作是很多的,比如数据库的创建,表的设计,需求的分析,框架环境的搭建等等,其实OA系统是很锻炼大家的知识整合在这里我们用到了很多的知识比如SSH包括如何整合如何搭建环境,前端包括Jquery JS html css,数据库运用的MySQ

1.重中之重项目的开始一些的准备工作是很多的,比如数据库的创建,表的设计,需求的分析,框架环境的搭建等等,其实OA系统是很锻炼大家的知识整合在这里我们用到了很多的知识比如SSH包括如何整合如何搭建环境,前端包括Jquery JS html css,数据库运用的MySQL,系统中涉及工作流的支持,论坛,MD5加密技术等等很多使用的模块,具体的设计思想上传到附件。

2.首先项目的第一步就是环境的搭建和测试,一个良好的项目结构是成功的一半,从老师的讲解中明白了很多的东西也学到很多,结构和所需的jar包如下:

项目OA之框架搭建整合基于SSH,Jquery,MySQL

jar包是第一步之后add一下,一个都不能少。

3.第三步首先添加struts2的支持,web.xml struts.xml这2个文件首先添加到项目中,具体的代码如下:

web.xml 默认拦截所有请求

org.springframework.web.context.ContextLoaderListenercontextConfigLocationclasspath:applicationContext*.xmlstruts2org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilterstruts2/*index.jsp
struts.xml 下面已经配置好了一个action是因为测试需要用到
/success.jsp
4.第四步添加Hibernate支持 首先是Hibernate.cfg.xml 数据库的连接信息单独写在jdbc.properties文件中,是因为大家都是用这不同的DB方便更换DB,然后就是添加一个User.hbm.xml文件

Hibernate.cfg.xml 为了方便测试已经写了一个hbm文件映射


org.hibernate.dialect.MySQL5Dialecttrueupdate
jdbc.properties
jdbcUrl		= jdbc:mysql:///oa
driverClass	= com.mysql.jdbc.Driver
username	= root
password	= 123

User.hbm.xml


5.第五步也是最重要的一步添加spring支持,首先是applicationContext.xml文件

applicationContext.xml 内容比较多哟C3p0连接池,自动扫描,加载外部属性文件,配置sessionFactory,事务管理,基于注解的

6.至此SSH环境搭建好,下面需要通过测试在投入到项目下一步,具体测试代码如下,首先测试最重要的sessionFactory和Transcation(以上同时也已经将Hibernate与Spring整合完毕,整合的主要是将sessionFactory交给spring容器管理,其实Hibernate的配置文件都可以不要也行,都交给spring)

建立SpringTest.java

package com.icss.spring;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.SessionFactory;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class SpringTest {

	private ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");

	

	// 测试SessionFactory
	@Test
	public void testSessionFactory() throws Exception {
		SessionFactory sessionFactory = (SessionFactory) ac.getBean("sessionFactory");
		System.out.println(sessionFactory);

	}
   //    测试事务
	@Test
	public void testTranscation(){
		
		UserService userService=(UserService) ac.getBean("userService");
		userService.saveTwoUsers();
	}
	
}
使用junit运行testSessionFactory打印台如果能打印出sessionFactory信息则成功:

项目OA之框架搭建整合基于SSH,Jquery,MySQL

下面测试事务,事务需要与数据库有关系,首先建立一个保存2个User的方法,利用Service层,建立一个User实体类

package com.icss.spring;

public class User {
   
	private Integer id;
	private String name;
	
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	
	
}
在建立UserService 需要注意的是因为我们采用的是基于注解的方式,所以对于各种注解应该熟悉
package com.icss.spring;

import javax.annotation.Resource;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
public class UserService {
	
	@Resource
	private SessionFactory sessionFactory ;
	@Transactional
	public void saveTwoUsers(){
	Session session=	sessionFactory.getCurrentSession();
	session.save(new User());
	session.save(new User());
		
	}

}
下面就到SpringTest调用,运行保存方法,如果在数据库中看到数据则成功,因为是new没设值,所以name为空。

项目OA之框架搭建整合基于SSH,Jquery,MySQL

7.下面可以测试下Struts2支持,同时也整合spring与struts2

首先建立TestAction 此处直接整合spring基于注解的,其中Scope是让其变成多例因为你不可能一个action只new一次,resource注入Service层

package com.icss.spring;

import javax.annotation.Resource;

import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;

import com.opensymphony.xwork2.ActionSupport;

@Controller
@Scope("prototype")
public class TestAction extends ActionSupport {

	@Resource
	private TestService testService;

	@Override
	public String execute() throws Exception {
		System.out.println("--------> TestAction.execute()");
		testService.saveTwoUsers();
		return "success";
	}
}

很重的一点需要在web.xml文件中设置spring监听器
	org.springframework.web.context.ContextLoaderListenercontextConfigLocationclasspath:applicationContext*.xml
当与Spring整合后,class属性写的就是Spring中bean的名称(默认是类名的第一个字母小写本文中为testAction)

建立相对应的success.jsp页面,部署项目,在浏览器中输入http;//localhost8080/OA/test.action,如果能显示success页面中的内容并且控制台打印,则所有后台整合搭建成功,明天整理设计思路!

"--------> TestAction.execute()


整体的结构如下:(可以建立一个文件夹config专门用来放置配置文件)项目OA之框架搭建整合基于SSH,Jquery,MySQL

项目OA之框架搭建整合基于SSH,Jquery,MySQL