暑假项目总结

这个暑假待在学校十几个人分组做了几个项目,其中一个项目是这学期一直在搞的,从明确产品目标,需求分析,到UI设计,再到后期的开发,是我大学两年以来从没做过的一个完整流程,总算是对软件开发有一个初步的了解,前二十天左右做的是其中一个项目的详细设计,后十天是另一个的后端代码开发,说实话,由于对第二个项目不了解,所以一开始将其中两个表搞混了,导致写了之后还要改动,也比较麻烦,这就是一个教训吧,所以以后开发时一定要了解清楚产品需求,使用流程,逻辑实现等等。

1.表与表之间的关系一定要理清。后面写代码就很快了,出错的概率也少一些。

2.每个实体类对应数据库中的一个表,那么数据类型一定要一致,往表里存数据时也要满足相应字段的类型,我在测试时,就因为一个字段的数据类型没对应,导致出错,找了好久,浪费挺多时间

3.数据表字段一定要设计好,减少数据冗余

我们的设计框架就是ssh

什么是SSH?

SSH是JavaEE中三种框架(Struts+Spring+Hibernate)的集成框架,是目前比较流行的一种Java Web开源框架。

Struts Spring Hibernate各起什么作用?

Struts:控制逻辑关系。

Spring:解耦。

Hibernate:操作数据库。

Struts

Struts框架,它是一个MVC实现,它有一个中央控制类(一个 Servlet),针对不同的业务,我们需要一个Action类负责页面跳转和后台逻辑运算,一个或几个JSP页面负责数据的输入和输出显示,还有一个 Form类负责传递Action和JSP中间的数据。JSP中可以使用Struts框架提供的一组标签,就像使用HTML标签一样简单,但是可以完成非常复杂的逻辑。从此JSP页面中不需要出现一行包围的Java代码了。

可是所有的运算逻辑都放在Struts的Action里将使得 Action类复用度低和逻辑混乱,所以通常人们会把整个Web应用程序分为三层,Struts负责显示层,它调用业务层完成运算逻辑,业务层再调用持久层完成数据库的读写。

Hibernate

使用JDBC连接来读写数据库,我们最常见的就是打开数据库连接、使用复杂的SQL语句进行读写、关闭连接,获得的数据又需要转换或封装后往外传,这是一个非常烦琐的过程。

所以我们用 Hibernate框架,它需要你创建一系列的持久化类,每个类的属性都可以简单的看做和一张数据库表的属性一一对应,当然也可以实现关系数据库的各种表件关联的对应。当我们需要相关操作是,不用再关注数据库表。我们不用再去一行行的查询数据库,只需要持久化类就可以完成增删改查的功能。使我们的软件开发真正面向对象,而不是面向混乱的代码。

现在我们有三个层了,可是每层之间的调用是怎样的呢?比如显示层的Struts需要调用一个业务类,就需要new一个业务类出来,然后使用;业务层需要调用持久层的类,也需要new一个持久层类出来用。通过这种new的方式互相调用就是软件开发中最糟糕设计的体现。简单的说,就是调用者依赖被调用者,它们之间形成了强耦合,如果我想在其他地方复用某个类,则这个类依赖的其他类也需要包含。程序就变得很混乱,每个类互相依赖互相调用,复用度极低。如果一个类做了修改,则依赖它的很多类都会受到牵连。为此,出现Spring框架。

Spring

Spring的作用就是完全解耦类之间的依赖关系,一个类如果要依赖什么,那就是一个接口。至于如何实现这个接口,这都不重要了。只要拿到一个实现了这个接口的类,就可以轻松的通过xml配置文件把实现类注射到调用接口的那个类里。所有类之间的这种依赖关系就完全通过配置文件的方式替代了。所以 Spring框架最核心的就是所谓的依赖注射和控制反转。

现在的结构是,Struts负责显示层,Hibernate负责持久层,Spring负责中间的业务层,另外,由于Spring使用的依赖注射以及AOP(面向方面编程),所以它的这种内部模式非常优秀,以至于Spring自己也实现了一个使用依赖注射的MVC框架,叫做Spring MVC,同时为了很好的处理事物,Spring集成了Hibernate,使事物管理从Hibernate的持久层提升到了业务层,使用更加方便和强大。

 

上面说到了Struts实现了MVC,那么是什么

MVC,即Model、View、Controller

View层是界面,Controller层是业务逻辑,Model层是数据库访问
①模型层(model),用Hibernate框架让来JavaBean在数据库生成表及关联,通过对JavaBean的操作来对数据库进行操作; 
② 控制层(control),用Struts框架来连接数据层和视图层的,接收、处理、发送数据并控制流程; 
③ 视图层(view),用JSP模板把页面展现给用户以及提供 与用户的交互。 
而Spring框架粘合了Hibernate和Struts,透明的管理了整个架构,提供IOC容器使代码松耦合以及AOP框架的切面功能 等等。

 

MVC要实现的目标是将软件用户界面和业务逻辑分离以使代码可扩展性、可复用性、可维护性、灵活性加强。

 

简单的把这三个比作一支笔,view是笔写出来的颜色,controller是笔壳,Model是笔芯,当我们想换笔写出的颜色时,只需把笔芯换了是吧,没必要去更改笔壳。这种设计模式就把前后端分离了。

比如有一个View会提交数据给Model进行处理以实现具体的行为,View通常不会直接提交数据给Model,它会先把数据提交给Controller,然后Controller再将数据转发给Model。假如此时程序业务逻辑的处理方式有变化,那么只需要在Controller中将原来的Model换成新实现的Model就可以了,控制器的作用就是这么简单, 用来将不同的View和不同的Model组织在一起,顺便替双方传递消息,仅此而已。

一般controller不会像dao层一样有个父类baseDao,如果通过继承父控制器的方式复用业务逻辑时,往往会出现为了用一个方法而继承来一大堆用不到的方法,所以,控制层一定要简单。

entity,Dao,Service,control

entity就是实体类,每一个对应数据库中的一张表;

Dao主要是对数据库中的一些查询,基本的查询在BaseDao里面已经写好,比如删除,通过主键查找,更新,每一个Dao对应一个entity,我们每个Dao只要继承BaseDao里面的基本查询方法,再添加我们自己所需的方法就行,方便。

Service是服务 层,主要调用一个或多个Dao里面的方法,还有一些算法,比如登录,在loginservice中先调用UserDao中的findPasswordByUserName通过username找到对应的密码进行比对,返回Boolean

control是控制层,进行前后端连接,通过前端传过来的请求调用相应的service

还没写完,后面补上

 

 

 

 

你可能感兴趣的:(暑假项目总结)