java ee中ssh学后感_学习SSH,SSM框架有感

JSP/Servlet基础

许多同学学习框架的时候,往往会忽视这部分内容,有的甚至没学JSP直接学习了框架,导致基础知识不扎实,只是会用框架,最后连JSP一共有几个内置对象都不知道。自己当时学的时候也没怎么学这部分知识,就开始学Struts了,也是最近几天又认真地把这部分知识看了一遍。

JSP和Servlet,区别上一个是Servlet没有内置对象,还有就是JSP可以在HTML中嵌入Java代码。而实际上,我们都知道,JSP最后也会被翻译为Servlet.所以广义的Servlet也可以指JSP+Servlet. 而JSP中的7个动作指令,9种内置对象,还有EL表达式,以及EL表达式的11个内置对象。都是我们必须要掌握的。

1.关于Cookie

Cookie用于网站记录用户的某些信息,它和session的区别在于:session是存放在服务器中,超出服务器设置的失效时间就会失效,而Cookie会一直存放在客户端机器上,除非超出Cookie的生命期限。增加Cookie也是使用response内置对象完成的。事实上,用来实现session的sessionId也是存放在Cookie上,如果浏览器禁用了Cookie,同样session也会失效。

(1)jQuery中操作Cookie

jQuery中操作Cookie非常简单,要先下载jQuery的Cookie插件jquery.cookie.js.

增加Cookie:$.cookie("c1","zhazha"); 将值"zhzha"写入cookie名为c1的cookie中。

$.cookie后面还有其他参数,用来设置有效期,路径等。

例如:$.cookie("c1","zhazha",{path: "/", expiress: 7}); 创建一个有效期为7天,路径与创建页路径一致的cookie.

删除Cookie:$.cookie("c1",NULL); 销毁名称为c1的cookie.

得到Cookie:$.cookie("c1"); 得到cookie名为c1的cookie的value值。

注:对于Chrome,使用本地测试时,cookie是基于域名来储存的。要放到测试服务器上或者本地localhost服务器上才会生效。cookie具有不同域名下储存不可共享的特性。单纯的本地一个html页面打开获取cookie是无效的。可以使用IE浏览器或者火狐浏览器。

(2)利用response增加,删除Cookie

Cookie c=new Cookie("username","name");

c.setMaxAge(24 * 3600);//设置生存期为24小时

response.addCookie(c);//增加Cookie

c.setMaxAge(0);//删除Cookie

Struts

Struts是Web框架,学习Struts首先要理解MVC思想,即Model(模型)、View(视图)和Controller(控制器)。学习Struts时间最长,也是在spring mvc之前用得最多的。Struts 2框架本身大致可以分为3个部分:核心控制器FilterDispatcher、业务控制器Action和用户实现的企业业务逻辑组件。三个组件相互配合,完成各个逻辑功能。

1.Struts的MVC结构

刚想学习Struts的时候,常常有人要把之前用的三层结构和MVC对应起来。其实没有必要,之前的三层架构和MVC结构还是有区别的。那么Struts的MVC分别指什么呢。

Model模型:这里的Model不只指我们项目Model层里的POJO对象。还包括Action对象,以及action调用的业务逻辑组件。

View视图:显然,视图就是指我们的JSP页面,以及Struts提供的标签库能够与我们的ActionFrom(包括request,session)进行交互。

Controller控制器:控制其主要就是指Struts的ActionServlet和ActionMapping,也就是我们配置的struts.xml.

2.ValueStack和StackContext

学习OGNL的时候,对这两个概念经常搞不清,总容易混淆。

ValueStack 称之为值栈,可以理解为StackContext的根对象,在Action里,要有set和get方法。在使用OGNL时,若访问的属性属于根对象,可以直接访问该属性,不用加'#'.

StackContext 叫做Stack的上下文,是整个OGNL的计算和求值的Context. 除了包含ValueStack这个根对象外,还包含一系列对象,包括request/session/application等。而访问这些命名对象时,要加'#'.

3.jstl和struts标签库

一直纠结这两个到底哪个好用,当然struts标签库只用应用与struts项目中。先学习过jstl,后来做项目的时候又一直用的struts的标签库,用起来感觉没什么差别,后来结合富文本编辑器从后台取数据的时候才发现,二者的取值方式不同。jstl取值的时候会转换里面的html标签,而struts标签取值的时候只是把值当做字符串输出到页面。(后来发现struts标签也可以通过设置escape='1',对html字符经行转义,当然jstl也可设置对html不进行转义,只是二者默认方式不同。但是Struts标签的访问速度要比jstl慢,效率低)

4.Struts的Ajax支持

自己做项目的时候最多用的就是jQuery中的Ajax的post函数,来实现异步请求。

用法:$.post("",{},function(data,textStatus){})

第一个引号里面传一个URL,一般就是一个action路径,第二个{}中传一个JSON对象,如{a:1,b:2}这样,把这个对象传给后台Action,后台通过set和get方法得到a和b的值,第三个function是方法实现体。用来处理后台传送回的数据和前台经行交互。

后台通过response.getWriter.print("")来向前台传递数据,存放到function中的data里。这样就实现了简单的Ajax的异步请求。

Hibernate

Hibernate是位于持久层的ORM框架,ORM即对象/关系数据库映射。Hibernate工作就是将数据库中的关系型数据映射成Java对象。

由于Hibernate过于厚重,学习成本高,导致其逐渐被Mybatis取代。

当然Hibernate也有优点,比如一套hql可以适配所有数据库,还有其缓存机制等都是优点。

由于Hibernate门槛较高,还是建议直接学习Mybatis.

Spring

作为应用范围最广的容器框架,无论走到哪基本都会用到Spring. Spring可以说是企业应用开发的不二之选,Spring贯穿表现层,业务层,持久层。并且能以高度的开放性与他们无缝整合。

Spring的核心是IOC(控制反转),DI(依赖注入)和AOP(面向切面的编程)。实际上,IOC和DI是同一个概念,只是spring设计者认为DI能更准确表示Spring核心技术。

1.IOC/DI

IOC的思想最核心的地方在于,资源不由使用资源的双方管理,而由不使用资源的第三方管理,这可以带来很多好处。第一,资源集中管理,实现资源的可配置和易管理。第二,降低了使用资源双方的依赖程度,也就是耦合度。

2.AOP

AOP思想能从程序运行角度考虑程序的流程,提取业务处理过程的切面。其有着各个步骤之间有良好的隔离性,源代码无关性的特性。可以这样理解,可以把代码看成一坨面,同样用刀来切面,切完了,想在前面、中间、后面或者四周放些“香料”什么的随便你。你只要把这把刀实现好就行了。AOP面向的是程序运行中各个步骤,希望以更好的方式来组合业务处理的各个步骤。

SSH 整合开发

1.Spring整合Struts2

Spring整合Struts2有两种策略,一种是让Spring管理控制器,一种是使用Spring的自动装备。两种方式各有优缺点。本人应用的是第二种,即使用自动装备策略。

(1)首先载入配置文件

在web.xml中加入以下信息。当然如果你使用IDEA开发时,这些都是已经自动生成好的。

contextConfigLocation

/WEB-INF/applicationContext.xml

org.springframework.web.context.ContextLoaderListener

(2)配置struts.xml

由于使用自动装配策略,所以struts.xml的配置方式和原来一模一样。即和在没有Spring整合之前的配置方式一样。

(3)注入Action中的Service组件。

在applicationContext.xml中配置Service的Bean,其中Bean的id与Action定义的Service中其getService中的名字一样。例如:

public UserService us;

public UserService getUs() {

return us;

}

public void setUs(UserService us) {

this.us = us;

}

如果定义了这样一个Service,那么bean id也应该设置为us,即:

2.Spring整合Hibernate

(1)配置管理SessionFactory.

在applicationContext.xml中配置以下信息,例子中包含两个POJO,即User和Friend.

destroy-method="close"

p:driverClass="com.mysql.jdbc.Driver"

p:jdbcUrl="jdbc:mysql://localhost/friends"

p:user="root"

p:password="123"

p:maxPoolSize="40"

p:minPoolSize="2"

p:initialPoolSize="2"

p:maxIdleTime="30"/>

p:dataSource-ref="dataSource">

com.models.User

com.models.Friend

org.hibernate.dialect.MySQL5InnoDBDialect

update

(2)定义DAO组件,并将SessionFactory注入DAO组件。

以下代码含有两个DAO组件,即UserDao和FriendDao.

(3)定义Service组件,并将DAO组件注入Service组件。

同理,以下代码含有两个Service组件,UserService和FriendService

(4)配置事务管理器

注:若写入tx报错,说明你没有导入相应的xmlns.

p:sessionFactory-ref="sessionFactory"/>

这样只要在Action中定义Service组件,在Service中定义DAO组件,生成set和get方法,这样,一个SSH项目就搭建好了。

Mybatis

相对于厚重的Hibernate, Mybatis就比较好掌握了。就算没看过Hibernate的新手,看看文档,读读Demo,两天基本就可以掌握上手了。Mybatis实际上是一个不完全的ORM框架,他主要完成的可以说是输入和输出映射。需要手动写sql语句,就简单的增删改查来说,个人更喜欢Hibernate. 觉得比Mybatis操作简单,能让让人更加专注于写业务逻辑。而学习了Mybatis的高级映射和缓存机制后,确实感觉很简单,比Hibernate容易理解。尤其是学完逆向工程之后,发现Mybatis也可以如此轻松。

1.Mybatis与Hibernate的比较

Mybatis优势

(1).MyBatis可以进行更为细致的SQL优化,可以减少查询字段。

(2).MyBatis容易掌握,而Hibernate门槛较高。

Hibernate优势

(1).Hibernate的DAO层开发比MyBatis简单,Mybatis需要维护SQL和结果映射。

(2).Hibernate对对象的维护和缓存要比MyBatis好,对增删改查的对象的维护要方便。

(3).Hibernate数据库移植性很好,MyBatis的数据库移植性不好,不同的数据库需要写不同SQL。

(4).Hibernate有更好的二级缓存机制,可以使用第三方缓存。MyBatis本身提供的缓存机制不佳。

他人总结

(1).Hibernate功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。

(2).Hibernate的缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。

(3).Mybatis入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

(4).Mybatis的缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。

注:以上内容摘自知乎

2.Mybatis的分页

分页是Mybatis的一个弱项,不能像Hibernate那样直接有分页的方法供你调用。而自己通过写sql语句来写分页也是个苦力活,很麻烦,所以我强烈向大家推荐一款插件:PageHelper. 来自OSChina社区的某位自己写的插件,无论是配置还是操作都超级简单,爱不释手。

3.Mybatis的逆向工程

Mybatis需要我们自己写sql语句,每张表的增删改查无疑给我们带来了巨大的工作量,所以项目中一般使用Mybatis的逆向工程工具,自动生成Java代码,为我们提供丰富的操作数据库的功能。

(1)使用之前需要先下载用于支持逆向工程的jar包

点击下载,网上的方法都是基于Maven或者用的是Eclipse的插件。自己使用IDEA开发的,所以用的是第三种方法,通过配置xml文件,通过运行它提供主程序生成Java代码。当然,用第一种方法也行。

(2)配置generatorConfig.xml

配置要求以下代码中注释写的很清楚

/p>

PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

connectionURL="jdbc:mysql://localhost:3306/friends" userId="root"

password="123">

targetProject=".\src">

targetProject=".\src">

targetPackage="com.mapper"

targetProject=".\src">

(3)运行GeneratorSqlmap

以下代码只需要修改generatorConfig.xml的位置

package com.service;

import java.io.File;

import java.util.ArrayList;

import java.util.List;

import org.mybatis.generator.api.MyBatisGenerator;

import org.mybatis.generator.config.Configuration;

import org.mybatis.generator.config.xml.ConfigurationParser;

import org.mybatis.generator.internal.DefaultShellCallback;

public class GeneratorSqlmap {

public void generator() throws Exception{

List warnings = new ArrayList();

boolean overwrite = true;

//指定 逆向工程配置文件

File configFile = new File("generatorConfig.xml");

ConfigurationParser cp = new ConfigurationParser(warnings);

Configuration config = cp.parseConfiguration(configFile);

DefaultShellCallback callback = new DefaultShellCallback(overwrite);

MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,

callback, warnings);

myBatisGenerator.generate(null);

}

public static void main(String[] args) throws Exception {

try {

GeneratorSqlmap generatorSqlmap = new GeneratorSqlmap();

generatorSqlmap.generator();

} catch (Exception e) {

e.printStackTrace();

}

}

}

这样所有的model和mapping就自动生成好了,具体的用法看代码,有的看方法名就能直接看出他的用法,其中的selectByExample类似于Hibernate的Criteria, 也就是按条件查询。用法也很简单,就不演示了。

Spring mvc

作为替代Struts2的另一个web框架,Spring mvc当然有它的优势。刚接触Spring mvc时,为了理解Spring mvc的结构,要接触许多名词,往往搞得我们头疼。包括前端控制器,处理器映射器,处理器适配器,以及视图解析器。所以我们首先要了解Spring mvc的工作流程。

1.Spring mvc的工作流程

(1)浏览器发起请求到前端控制器(DispatcherServlet)

(2)前端控制器请求HandlerMapping查找 Handler

(3)处理器映射器HandlerMapping向前端控制器返回Handler

(4)处理器适配器执行Handler并返回ModelAndView

(5)视图解析器向前端控制器返回View

(6)前端控制器进行视图渲染

2.关于@RequestParam

真正做项目时,@RequestParam是必须配置的,即使你传入的参数名和你的形参名一样也配置,因为在Eclipse的Debug模式下编译时,参数名都会保留在class文件中,spring由此可以反射绑定。而自己使用的IDEA,无论怎么调试怎样都得不到前面传过来的值,调了很长时间,只有加上@RequestParam(value = "username") String username这样的同名注解才行,即使文档里说可以省略。

3.Spring mvc的优势

(1)学习完Spring mvc之后可以发现,Spring mvc是基于于方法开发的,所有需要的参数都通过Controller里面的方法形参进行传递,而Struts是基于于类开发的。这种基于方法的Controller开发更类似于Service开发,逻辑上更符合我们的编程逻辑。

(2)由于Struts的标签库,导致Struts的效率要低于Spring mvc.

(3)Struts有安全漏洞,Spring mvc没有发现安全隐患。

SSM 整合开发

项目结构:src下一共四个包,com.models, com.mapper, com.service, com.controller. 其中com.models包含两个POJO对象User和Friend. com.models和com.mapper均由mybatis逆向工程自动生成。

1.配置web.xml

这个很简单,如果使用IDEA开发,这些都是自动生成好的。例子中除了Mapper的xml一共包含三个xml,即WEB-INF下的applicationContext.xml和dispatcher-servlet.xml. 以及src下的sqlMapConfig.xml.

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"

version="3.1">

contextConfigLocation

/WEB-INF/applicationContext.xml

org.springframework.web.context.ContextLoaderListener

dispatcher

org.springframework.web.servlet.DispatcherServlet

1

dispatcher

*.form

dispatcher

*.action

2.配置sqlMapConfig.xml

这里我只给model配置了一个别名,可以根据需要自行配制,例如可以配置二级缓存。

/p>

PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-config.dtd">

3.配置applicationContext.xml

这里的配置方式和整合SSH的配置方式类似

destroy-method="close"

p:driverClass="com.mysql.jdbc.Driver"

p:jdbcUrl="jdbc:mysql://localhost/friends"

p:user="root"

p:password="123"

p:maxPoolSize="40"

p:minPoolSize="2"

p:initialPoolSize="2"

p:maxIdleTime="30"/>

3.配置dispatcher-servlet.xml

这样配置好之后,同样的,只要在Service层添加Mapper对象,在Controller层添加Service对象,这样一个SSM项目就搭建好了。

总结:

利用这个假期把Spring,Mybatis,Spring mvc过了一遍,有些感悟与体会。希望上面的内容能对看的人有所帮助,还有上面关于概念的理解与对比也是经常被问,经常让人困惑的,愿学有所成。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值