市级医药集中采购系统(二)

项目中使用JavaBean

1.1 PO类

  •  提供给hibernate使用,与数据库中的表对应关系,并通过映射文件(*.hbm.xml)关联。
  • l  一般情况,PO类和映射文件都已准备好了。我们可以通过工具生成。

1.1.1反向工程:自动生成

  • l  实际开发中的编写步骤:
    •  1)使用 PowerDesigner 绘制表与表之间的关系,获得bdm文件。例如:yycg2.0.pdm
    •  2)通过PowerDesigner 将pdm文件转换成sql语句。(就可以创建表了)
    •  3)通过“逆向工程”通过数据库的表,生成PO类(javabean)和映射文件(hbm.xml)

1.1.2手动编写:

  •  编写PO类时,必须清楚表与表之间的关系。
  • PO类编写:类+映射文件
    • 类和hbm.xml配置文件同目录
    •   类名和文件名相同

1.2使用JavaBean

  • PO类:以SysUser为例
  • 每一个PO类都对应多个JavaBean,用于处理不同的情况
    • 查询条件封装类(处理后),query类:SysUserQuery(*Query)
    • PO类的自定义类:用于封装表单提交或回显基本数据:SysUserCustom(*Custom)
    • 查询条件封装类自定义类(处理前),由页面提交查询条件:SysUserQueryCustom(*QueryCustom)
    • 提供组合JavaBean(所有的自定义),用于接收浏览器发送的所有数据:SysUserVo(*Vo)---value object
  • 各个JavaBean之间关系

        202713_eS8e_2892414.png

  • 各个JavaBean继承的关系202747_oOud_2892414.png

  • 各个JavaBean的位置,以SysUser为例

  • PO类(SysUser):位置:yycg-domain-0808---àcn.itcast.yycg.domain.po

  • Vo类(SysUserVo):位置:yycg-web-0808----àcn.itcast.yycg.user.web.vo

  • 查询对象(SysUserQuery):位置:yycg-dao-0808--àcn.itcast.yycg.user.dao.query

  • 自定义对象:位置:yycg-service-0808---àcn.itcast.yycg.user.pojo

    • PO类的自定义类(SysUserCustom)

    • 查询条件封装类的自定义类(SysUserQueryCustom)

  • 查询对象:
  • 202932_NyQL_2892414.png
  • 自定义对象:

    • PO类自定义

    • 查询的自定义对象

            203031_XKIm_2892414.png

  • VO对象:yycg-web-0808---àcn.itcast.yycg.user.web.vo203106_5n65_2892414.png
  • 203120_aj1A_2892414.png

2、SSH整合:

2.1domain项目

  • 根据数据库的表,反向生成PO类和hbm.xml映射文件(使用hibernateTools工具)
  • 把生成的po类复制到domain项目中:
    • 位置

                    203212_stEy_2892414.png

  • 把生成的映射文件复制到domain项目中
    • 位置

                203322_4wBG_2892414.png

2.2framework项目

2.2.1config配置:

  • 复制config信息到项目中
    • 文件位置:

              203409_62yT_2892414.png  

  •    该类是系统参数配置类,配置了系统用到的参数,主要是对用于定义个模块名称

2.2.2spring的配置

配置位置:

203500_IfjZ_2892414.png

spring核心配置文件-àapplicationContext.xml

  •  导入约束

<!--1、导入约束  -->
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
		http://www.springframework.org/schema/beans/spring-beans.xsd 
		http://www.springframework.org/schema/mvc 
		http://www.springframework.org/schema/mvc/spring-mvc.xsd 
		http://www.springframework.org/schema/context 
		http://www.springframework.org/schema/context/spring-context.xsd 
		http://www.springframework.org/schema/aop 
		http://www.springframework.org/schema/aop/spring-aop.xsd 
		http://www.springframework.org/schema/tx 
		http://www.springframework.org/schema/tx/spring-tx.xsd ">
  • 本项目使用注解,所以配置扫描注解包

     

<!-- 2、注解扫描 -->
<context:component-scanbase-package="cn.itcast.yycg"></context:component-scan>
  • 加载db.properties配置文件,该配置文件主要用于配置数据库基本信息
<!-- 3、加载配置文件db.properties -->
<context:property-placeholder location="classpath:config/db.properties"/>
  • 配置数据源,本项目使用c3p0数据源
<!--4、 配置数据源,使用c3p0 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="${jdbc.driver}" />
		<property name="jdbcUrl" value="${jdbc.url}" />
		<property name="user" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />
		<!-- 最大连接数,建议在开发环境中设置小一点,够用即可 -->
		<property name="maxPoolSize" value="3" />
		<!-- 最小连接数 -->
		<property name="minPoolSize" value="1" />
</bean>
  • 配置sessionFactory,加载hibernate映射文件

<!--5、 配置sessionFactory -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
		<!—5.1 注入数据源 -->
		<property name="dataSource" ref="dataSource"></property>
		<!—5.2 设置hibernate属性 -->
		<property name="hibernateProperties">
			<props>
				<!-- 方言 -->
				<prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
				<!-- 日志输出显示sql -->
				<prop key="hibernate.show_sql">true</prop>
				<!-- 日志输出中格式化sql -->
				<prop key="hibernate.format_sql">false</prop>
				<!-- 从hbm文件到数据库定义策略,建议设置为none,不检查po类和表结构是否一致 -->
				<prop key="hibernate.hbm2ddl.auto">none</prop>
				<!-- 配置Hibernate的session管理机制,spring与hibernate整合后采用当session与当前线程绑定 -->
				<prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate5.SpringSessionContext</prop>
			</props>
		</property>
		<!—5.3 加载映射文件 -->
		<property name="mappingLocations">
			<list>
				<value>classpath:cn/itcast/yycg/domain/po/*.hbm.xml</value>
				<value>classpath:cn/itcast/yycg/province/po/*.hbm.xml</value>
			</list>
		</property>
	</bean>
  • 配置HibernateTemplate模板,需要注入给dao层

<!--6、 配置hibernateTemplate,可以不用配置,这里主要是为了配置checkWriteOperations属性 -->
	<bean id="hibernateTemplate" class="org.springframework.orm.hibernate5.HibernateTemplate">
	<!-- spring与hibernate整合后默认必须在事务下对数据库执行写操作 ,如果将checkWriteOperations设置为false则没有事务也可以写数据库,这样是为了单独测试dao方便 -->
		<property name="checkWriteOperations" value="false"/>
		<property name="sessionFactory" ref="sessionFactory"/>
</bean>
  • spring事务配置文件-àapplicationContext-transaction.xml
    • 导入约束
  • 配置事务管理器

<!--1、 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
	<!-- 注入sessionFactory -->
	<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
  • 配置通知

<!--2、 配置通知 -->
	<tx:advice id="txAdvice" transaction-manager="transactionManager">
		<tx:attributes>
			<!-- 配置传播行为 -->
			<tx:method name="save*" propagation="REQUIRED"/>
			<tx:method name="insert*" propagation="REQUIRED"/>
			<tx:method name="delete*" propagation="REQUIRED"/>
			<tx:method name="update*" propagation="REQUIRED"/>
			<tx:method name="edit*" propagation="REQUIRED"/>
			<tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
			<tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
		</tx:attributes>
	</tx:advice>
  • 配置aop切面

<!--3、 aop切面
			proxy-target-class="true" cglib代理;   默认是false,jdk动态代理
 -->
	<aop:config proxy-target-class="true">
	<!-- 配置切入点:符合切点的类会被aop,生成代理对象-->
	<aop:advisor advice-ref="txAdvice" pointcut="execution(* cn.itcast.yycg.*.service.impl.*.*(..))"/>
	</aop:config>

2.2.4struts配置:

配置位置:

204706_ACy5_2892414.png

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
       <!-- 引入其他位置的配置文件 -->
<include file="struts/struts-*.xml"></include>
</struts>

注意:framework项目中只配置主要的配置文件--àstruts.xml

2.3 dao项目

位置:

204803_KjHe_2892414.png

2.3.1声明接口:SysUserDao,子包必须user(规定的)

/**
 * 用户持久层接口
 * @author xiaoqiang
 */
public interface SysUserDao{
}

2.3.2编写实现类:

  • 继承HibernateDaoSupport
  • 实现SySUserDao接口
  • 添加注解@Repository,将dao实现类交予spring

@Repository
public class SysUserDaoImpl extends HibernateDaoSupport implements SysUserDao {

	/* 如果采用注解,我们不能直接给父类注入内容,将间接的通过自己的方法给父类注入
	 * 1.提供setter方法,并使用@Autowired自动按照类型注入
	 * 2.手动调用父类的setter方法将需要内容注入给父类。
	 * * @Autowired注解:可以给字段注入,也可以给属性注入(setter方法)
	 */
	@Autowired
	public void setHT(HibernateTemplate hibernateTemplate){
		super.setHibernateTemplate(hibernateTemplate);
	}
	
	@Override
	public SysUser findById(String id) {
		return this.getHibernateTemplate().get(SysUser.class, id);
	}
}

2.4service项目

位置:

204942_RqIM_2892414.png

2.4.1接口:

/**
 * 用户业务层接口
 * @author xiaoqiang
 */
public interface SysUserService {
	/**
	 * 根据id查询用户信息
	 * @param id
	 * @return
	 */
public SysUser findById(String id);
}

2.4.2实现类:

@Service
public class SysUserServiceImpl implements SysUserService {
	
	@Autowired
	private SysUserDao sysUserDao;
	
	@Override
	public SysUser findById(String id) {
		return sysUserDao.findById(id);
	}
}

2.5web项目

2.5.1导入html页面(jsp页面)

  • 位置

    205054_xIWl_2892414.png

2.5.2web.xml配置

  • 位置:上边webapp中自己创建一个WEB-INF文件夹,在里边创建一个web.xml配置文件
  • 配置spring监听器,用于确定spring配置文件的位置,从而在启动时,初始化spring容器

<listener>
	<!-- 配置spring框架提供的监听器,用于创建spring容器,保证一个应用只有一个容器 它默认加载的是WEB-INF目录下的applicationContext.xml文件 -->
	<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 配置全局初始化参数, 告知监听器spring配置文件位置 -->
<context-param>
	<param-name>contextConfigLocation</param-name>
	<!-- spring配置文件,可以采用加载多个文件,中间以逗号分隔,也可以使用通配符 -->
	<param-value>classpath:spring/applicationContext.xml,classpath*:spring/applicationContext-*.xml</param-value>
</context-param>
  • 配置spring延迟关闭session

<!-- OpenSessionInView ,解决延迟加载session在web层不可用的问题,将session的生命周期延长到和request一致 -->
<filter>
	<filter-name>OpenSessionInView</filter-name>
	<filter-class>org.springframework.orm.hibernate5.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>		
<filter-name>OpenSessionInView</filter-name>
	<url-pattern>/*</url-pattern>
</filter-mapping>
  • 配置struts核心控制器

<!-- 配置Struts的核心控制器:过滤器 过滤器默认只会去类的的根路径下去加载struts.xml的配置文件 -->
<filter>
	<filter-name>struts2</filter-name>
	<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
	<filter-name>struts2</filter-name>
	<url-pattern>/*</url-pattern>
</filter-mapping>

2.5.3struts.xml配置

位置:

205255_X6iQ_2892414.png

  • struts-base.xml,基本配置文件,常用的常量,公共内容

<!-- 配置常量 -->
	<constant name="struts.devMode" value="false" />
	<!-- ui主题 -->
	<constant name="struts.ui.theme" value="simple"></constant>
	<!-- 访问action的扩展名是.action -->
	<constant name="struts.action.extension" value="action" />
	<!-- 修改struts2文件上传的大小,默认2097152 -->
	<constant name="struts.multipart.maxSize" value="20971520"></constant>
	<!-- 设置struts2从jar包中搜索action,用于注解开发 
	<constant name="struts.convention.package.locators.basePackage" value="cn.itcast.yycg"/> 
	-->


<!-- 配置公共package -->
	<package name="base" extends="struts-default">
		<!-- <interceptors>
			<interceptor name="exceptionInterceptor" class="cn.itcast.yycg.framework.exception.ExceptionInterceptor"></interceptor>
			设置 拦截器栈
			<interceptor-stack name="customStack">
				<interceptor-ref name="exceptionInterceptor"/>
				<interceptor-ref name="defaultStack"/>
			</interceptor-stack>
		</interceptors>
		<default-interceptor-ref name="customStack"/> -->
		<!-- 公用 result -->
		<global-results>
			<result name="error_jsp" >
				/common/error.jsp
			</result>
			<!-- 拒绝访问 -->
			<result name="refuse" >
				/common/refuse.jsp
			</result>
		</global-results>
	</package>

注意:之后所有的struts-xxx.xml中的<package>需要继承base

  • struts-user.xml配置
<struts>
	 <package name="user" extends="base" namespace="/user">
	 	<action name="*" class="sysUserAction" method="{1}">
	 		<result name="findById">/business/user/findSysUserById.jsp</result>
	 	</action>
	 </package>
</struts>

2.5.4action类

  • 注解和模型驱动使用
  • Action中数据封装和获取

@Controller
@Scope("prototype")
public class UserAction extends ActionSupport implements ModelDriven<SysUserVo> {

	private SysUserVo sysUserVo = new SysUserVo();
	@Override
	public SysUserVo getModel() {
		return sysUserVo;
	}
	
	@Autowired
	private SysUserService sysUserService;
	
	public String findById(){
		//从vo获得请求参数id
		String id = sysUserVo.getSysUserQueryCustom().getId();
		
		//查询数据
		SysUser sysUser = sysUserService.findById(id);
		
		
		//将数据 request作用域 ,值栈
		//ActionContext.getContext().getValueStack().push(sysUser);
		
		//将查询结果,封装到vo中
		SysUserCustom sysUserCustom = new SysUserCustom();
		// * 拷贝数据
		BeanUtils.copyProperties(sysUser, sysUserCustom);
		sysUserVo.setSysUserCustom(sysUserCustom);
		
		return "findById";
	}
}

2.5.5启动项目,访问首页,显示用户信息

 

转载于:https://my.oschina.net/changenow/blog/785280

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值