框架基础知识_第1页
框架基础知识_第2页
框架基础知识_第3页
框架基础知识_第4页
框架基础知识_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

SSH基础Struts,Spring,Hibernate框架基础.Hibernate工作原理及为什么要用?原理:1.读取并解析配置文件2.读取并解析映射信息,创建SessionFactory3.打开Session4.创建事务Transation5.长久化操作6.提交事务7.关闭Session8.关闭SesstionFactory为什么要用:1.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。2.Hibernate是一个基于JDBC的主流长久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作3.hibernate使用Java反射机制,而不是字节码增加程序来实现透亮性。4.hibernate的性能特别好,由于它是个轻量级框架。映射的敏捷性很精彩。它支持各种关系数据库,从一对一到多对多的各种简单关系。.Hibernate是如何延迟加载?Hibernate2延迟加载实现:a)实体对象b)集合(Collection)Hibernate3供应了属性的延迟加载功能当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节约了服务器的内存开销,从而提高了服务器的性能。.Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系).Struts的validate框架是如何验证的?在struts配置文件中配置详细的错误提示,再在FormBean中的validate。方法详细调用。.说下Struts的设计模式MVC模式:web应用程序启动时就会加载并初始化ActionServlero用户提交表单时,一个配置好的ActionForm对象被创建,并被填入表单相应的数据,ActionServler依据Struts-config.xml文件配置好的设置打算是否需要表单验证,假如需要就调用ActionForm的Validate()验证后选择将恳求发送到哪个Action,假如Action不存在,ActionServlet会先创建这个对象,然后调用Action的execute()方法。Execute()从ActionForm对象中猎取数据,完成业务规律,返回一个ActionForward对象,ActionServlet再把客户恳求转发给ActionForward对象指定的jsp组件ActionForward对象指定的jsp生成动态的网页,返回给客户。.spring工作机制及为什么要用?l.springmvc请全部的恳求都提交给DispatcherServlet,它会托付应用系统的其他模块负责负责对恳求进行真正的处理工作。.DispatcherServlet查询一个或多个HandlerM叩ping我处处理恳求的Controller..DispatcherServlet请恳求提交到目标Controller.Controller进行业务规律处理后,会返回一个ModelAndView.Dispathcher查询一个或多个ViewResolver视图解析器,找至I」ModelAndView对象指定的视图对象.视图对象负责渲染返回给客户端。为什么用:{AOP让开发人员可以创建非行为性的关注点,称为横切关注点,并将它们插入到应用程序代码中。使用AOP后,公共服务(比如日志、长久性、事务等)就可以分解成方面并应用到域对象上,同时不会增加域对象的对象模型的简单性。IOC允许创建一个可以构造对象的应用环境,然后向这些对象传递它们的协作对象。正如单词倒置所表明的,IOC就像反过来的JNDIO没有使用一堆抽象工厂、服务定位器、单元素(singleton)和直接构造(straightconstruction),每一个对象都是用其协作对象构造的。因此是由容器管理协作对象(collaboratorXSpring即使一个AOP框架,也是一IOC容器。Spring最好的地方是它有助于您替换对象。有了Spring,只要用JavaBean属性和配置文件加入依靠性(协作对象)0然后可以很简洁地在需要时替换具有类似接口的协作对象。}其它学问点:不会涉及到2级缓存以及hql.Configuration读取.并把.hbm.xml文件交给HbmBinder做第一次处理,HbmBinder依据.hbm.xml解析出PersistentClass,Collection,然后在创建SessionFactory的时候,会对Collection做第2次处理塞入关联PersistentClass依据.hbm.xml产生的描述要长久化的类的信息的类.主要的实例变量包括List<Property>propertiesProperty对象里的有个Value属性value,通过value来描述该property和数据库里的哪些列对应以及获得该property对应的typeValue主要分为SimpleValue,Collection,Component,ToOneSimpleValue主要包括Table和Columns属性,用于描述简洁属性或单主键Collection主要属性包括collectionTable表示Collection里面element对象所对应的Tablekey表示CollectionTable里的哪几歹I」和Collectionowner所对应的表的主键做关联element,描述了主表(referencingTable),从表的EnityName,以及从表对应的PersistentClassComponent可以用来描述多主键,通过属性properties来表示ToOne包括被引用的属性名,被引用的实体名,columns4被引用的属性名不能和columns同时设置),用于OneToOne,ManyToOneSessionFactory在创建SessionFactory的时候,会依据Configuration里Classes和Collections,创建EntityPersister和CollectionPersister.SessionFactory会缓存这些persisters.EnityPersistenter的key是EntityName,CollectionPersister的key是entityName+propertyNameEntityPersister分为SingleTableEntityPersister(一个实体一个表/一个类继承结构一个表)通过一个字段做标识JoinedSubclassEntityPersister(每个子类一个表)UnionSubclassEntityPersister(每个详细类一个表)CollectionPersister封装对一个Collection的crud操作.不过做寸sert,update,delete,recreate的时候,会判Inverse是否为false.假如为false才会执行相应的操作,表示是由Collection维护关系.假如Inverse:=true,表示关联关系是由多端来维护(即直接通过操作Collection里的element来维护,而不是通过操作Collection来维护)则该CollectionPersister不会做任何操作Type主要包括对SqlTypes的封装,以及CollectionTyp^EntityType(ManyToOneTypeQneToOneType),主要接口有nullSafeGet(从ResultSet拼装出对象》nullSafeSet(给PreparedStatementsetParameter).可以通过Value.getType()获得Type对于EntityType,CollectionType,就是通过resolve方法从ResultSet中拼装出对象EntityType的nullSafeSet,就是猎取One端对象的主键所对应的Type进行nullSafeSetCollectionType没有实现nullSafeSet,通过保存时的Cascade或者CollectionPersister,^Collection的Element一个一个的set也可以自定义Type,实现UserType接口详细见封装对一个entity的crud操作,在创建EntityPersister实例过程中,会产生crud的sql,可以在以后的操作提高效率。不过假如是Dynamicinsert,DynamicUpdate则会依据对象修改的属性动态的生成sqlDAS不支持类继承的映射,因此只会用到SingleTableEntityPersisterStatefulPersistencecontextStatefulPersistenceContextSessionlmpl是对应的,会缓存通过Sessionlmpl操作过的对象,包括entity和collection.主要属性有EntitiesByKeykey=EntityKey,value=entity.(EntityKey=id+EntityPersister+EntityModeentityMode))entityEntrieskey=entity,value=EntityEntry.EntityEntry用于描述一个对象的长久化状态,如DELETED,MANAGED等等CollectionsByKeykey=CollectionKey,value=PersistentCollectionCollectionKey=CollectionPersister+key+EntityMode,这个Key是通过Collection,value.getType.nullSafeGet。得到的PersistentCollection是hibernate对于Collection的封装,主要用于实现延迟加载collectionEntrieskey=PersistentCollection,value=CollectionEntryStatefulPersistenceContext的主要用途可以实现对象之间的关联关系的设置,动态的更新,以及对缓存的数据无需显示调用save,update,delete的方法就可以实现这些操作,是由于在Tmit()的时候会调用session.flush(),会保证内存对象状态和数据库的全都性Cascade,CascadeStylezCascadingAction在Cascade执行级联操作的时候,会通过CascadeStyle.doCascade(CascadingAction)来推断是否可以执行cascade,并且当要保存的对象有外键约束的关联对象时候会通过ForeignKeyDirection来推断是应当在保存该对象之前要保存关联对象还是在保存该对象之后再保存关联对象Loader,CriteriaQueryTranslator,Criteria,QueryParameters,CriteriaJoinWalker用于Criteriaapi对实体的查询Criteria是一个查询entity的apio可以设置类似where条件的表达式,Select字段,order等等当使用Criteria查询时,首先会创建CriteriaLoaderzCriteriaLoader通过CriteriaQueryTranslator从Criteria中得到查询参数QueryParameters,通过CriteriaJoinWalker把Criteria变成sql,然后执行查询ActionQueue当调用session对实体进行insert,update,delete的时候,只是会创建相应的action放入ActionQueue,然后在session.flush。的时候才会真正操作数据库ActionQueue的执行挨次:executeActions(insertions);executeActions(updates);executeActions(collectionRemovals);executeActions(collectionllpdates);executeActions(collectionCreations);executeActions(deletions);Tuplizer用于依据entityname实例化出对象,以及set/getpropertyhibernate内置的有PojoEntityTuplizer,Dom4jEntityTuplizerDAS是在hibernate基础之上实现了DataObject的长久化,支持DataObject对象之间的关联,延迟加载,级联,掌握反转,不支持DataObject的继承1.新实现了一个SDOEntityTuplizer支持创建DataObject,以及set/getDataObject的属性SDOEntityTuplizer实现抽象类中规定的如下方法SDOEntityTuplizer类的buildlnstantiator方法用来依据mapping信息来为相应的实体建立不同的构造器,我们用SDOEntitylnstantiator来实现SDO的构造器:2其中SDOComponentlnstantiator是用来当实体有复合主键用于实例化表示主键的类3PropertyAccessor>Hibernate中定义的一个接口,用来表达在访问mapping的实体对象的属性的时候使用的"属性访问器"。它有两个相关的接口:Getter接口和Setter接口。类与类之间的关系主要体现在表与表之间的关系进行操作,它们都市对对象进行操作,我们程序中把全部的表与类都映射在一起,它们通过配置文件中的many-to-one.one-to-many、many-to-many4.Strutsl流程:1、客户端扫瞄器发出HTTP恳求。2、依据web.xml配置,该恳求被ActionServlet接收。3、依据struts-config.xml配置,ActionServlet先将恳求中的参数填充到ActionForm中,然后ActionServlet再将恳求发送到Action进行处理。4、是否验证,需要验证则调用ActionForm的validate方法,验证失败则跳转到input,胜利则连续。5、Action从ActionForm获得数据,调用javabean中的业务方法处理数据。6、Action返回ActionForward对象,跳转到相应JSP页面或Actiono7、返回HTTP响应到客户端扫瞄器。MVC设计模式:modal:"模型"也称业务规律,是正真完成任务的代码,相当与JavaBeanview:视图,其实就是显示界面,相当于JSPcontroller:掌握器,他掌握模型和视图的交互过程,相当于servletstrutsl是基于MVC设计模式hibernate是基于ORM对象关系映射5.struts是什么?strutsl是基于JSP和servlet的一个开源的Web应用框架,使用的是MVC的设计模式struts2是基于webwork技术的框架,是sun和webwork公司联手开发的一个功能特别齐全的框架,struts2和strutsl没有任何关系,是一个全新的框架DASPropertyAccessor的内部结构如下图所示:其中getGetter方法和getSetter方法是PropertyAccessor接口定的规格。DASGetter实现Getter接口,DASSetter类实现Setter接口。4自定义type,支持blob,clob的存储BlobFileType:从一个文件路径读取文件存入数据库blob字段.从数据库读取blob字段,生成文件放在临时名目,返回路径BlobByteArrayType:把一个byte□数组存入blob字段.从数据库读取blob字段放入byte[]ClobFileType:从一个文件路径读取文件存入数据库clob字段.从数据库读取clob字段,生成文件放在临时名目,返回路径ClobStringType把一个String存入blob字段.从数据库读取blob字段放入String5对查询实体的支持增加一个查询实体定义文件.dbquery.由于查询实体没有唯一标识,所以默认的id的是“$queryEntityId$二用户也可以自己指定一个列做唯一标识.在Loader.prepareQueryStatement()里增加转换带查询实体的Sql.SelectFragment.addColumnQ做了推断,假如列名是"$queryEntityId$”,查询的column就替换成'queryEntitylcT常量.在Loader.getRowQ增加推断假如key.getldentifier()>queryEntityld的话,则不做检查,看内存是否存在.AbstractEntityPersister.getDatabaseSnapshot。里修改生成的查询语句,假如有QueryEntity,则用定义的sql替换QueryEntity6.spring是什么?spring是一个集成了很多第三方框架的大杂烧,其核心技术是IOC(掌握反转,也称依靠注入)和AOP(面对切面编程)7.hibernate是什么?hibernate是基于ORM对象关系映射(完成对象数据到关系数据映射的机制)实现的,做数据长久化的工具8JSF是什么?JavaServerFace是基于组件的web开发框架,跟starts差不多的框架9.数据库里面的索引和约束是什么?索引是为了提高数据的检索速度,索引是建立在数据表上,依据一个或多个字段建立的约束是为了保持数据的完整性,约束有非空约束,主键约束,外键约束等等。lO.spring是什么这个问题,往往可以通过我们为什么要使用spring这个问题来切入:AOP让开发人员可以创建非行为性的关注点,称为横切关注点,并将它们插入到应用程序代码中。使用AOP后,公共服务(比如日志、长久性、事务等)就可以分解成方面并应用到域对象上,同时不会增加域对象的对象模型的简单性。IOC允许创建一个可以构造对象的应用环境,然后向这些对象传递它们的协作对象。正如单词倒置所表明的,IOC就像反过来的JNDIO没有使用一堆抽象工厂、服务定位器、单元素(singleton)和直接构造(straightconstruction),每一个对象都是用其协作对象构造的。因此是由容器管理协作对象(collaboratorXSpring即使一个AOP框架,也是一IOC容器。Spring最好的地方是它有助于您替换对象。有了Spring,只要用JavaBean属性和配置文件加入依靠性(协作对象X然后可以很简洁地在需要时替换具有类似接口的协作对象。11.用自己的话简要阐述struts2的执行流程。Struts2框架本身大致可以分为3个部分:核心掌握器FilterDispatcher,业务掌握器Action和用户实现的企业业务规律组件。核心掌握器FilterDispatcher是Struts2框架的基础,包含了框架内部的掌握流程和处理机制。业务掌握器Action和业务规律组件是需要用户来自己实现的。用户在开发Action和业务规律组件的同时,还需要编写相关的配置文件,供核心掌握器FilterDispatcher来使用。Struts2的工作流程相对于Struts1要简洁,与WebWork框架基本相同,所以说Struts2是WebWork的升级版本。基本简要流程如下:L客户端扫瞄器发出HTTP恳求。2.依据web.xml配置,该恳求被FilterDispatcher接收。3.依据struts.xml配置,找到需要调用的Action类和方法,并通过IoC方式,将值注入给Acitono4.Action调用业务规律组件处理业务规律,这一步包含表单验证。5.Action执行完毕,依据struts.xmlstruts.xml中的配置找到对应的返struts.xml中的配置找到对应的返结果resultstruts.xml中的配置找到对应的返结果result,并跳转到相应页面。6.返HTTP响Hibernate工作原理及为什么要用?原理:.读取并解析配置文件.读取并解析映射信息,创建SessionFactory.打开Sesssion.创建事务Transation.长久化操作6才是交事务.关闭Session.关闭SesstionFactory为什么要用:对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。Hibernate是一个基于JDBC的主流长久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作hibernate使用Java反射机制,而不是字节码增加程序来实现透亮性。hibernate的性能特别好,由于它是个轻量级框架。映射的敏捷性很精彩。它支持各种关系数据库,从一对一到多对多的各种简单关系。.Hibernate是如何延迟加载?.Hibernate2延迟加载实现:a)实体对象b)集合(Collection).Hibernate3供应了属性的延迟加载功能当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节约了服务器的内存开销,从而提高了服务器的性能。.Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系)类与类之间的关系主要体现在表与表之间的关系进行操作,它们都市对对象进行操作,我们程序中把全部的表与类都映射在一起,它们通过配置文件中的many-to-one.one-to-many、many-to-manys.说下Hibernate的缓存机制.内部缓存存在Hibernate中又叫一级缓存,属于应用事物级缓存.二级缓存:a)应用及缓存b)分布式缓存条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论