java web开发概要

java web开发大致有这么几个历程:

CGI 程序

基于java web的api和程序包,自己开发CGI程序,这样做的好处是完全自己控制网络的监听、请求、响应,坏处是没有任何规范,开发量大,并且容易产生各种问题,等于是抛弃java web的发展成果,一切从头开始。

Servlet程序

为了解决CGI阶段的问题,比如低开发效率,无规范,问题多。sun在j2ee标准中,添加了Servet Api,为Java Web开发提供了一个统一、规范的解决方案。其Api的包名为javax.servlet。

其中javax.servlet.http包提供了Servet基于Http协议的实现,也是我们最常用的Api接口。

定义了Servlet规范之后,就出现了很多Servlet容器,能够基于配置自动装载、运行Servet程序。其中包括Tomcat、Netty等。

在这个阶段,底层的网络通信协议实现和接口封装由容器来实现,web程序专注于调用Servlet Api,来完成业务逻辑。

Servlet阶段和CGI阶段比较,一方面简化了应用开发,一方面提供了Java Web程序的Api标准,一方面解决了CGI阶段容易产生的性能等问题。

Spring 框架

基于Servlet Api开发的Web 应用,依然会存在很多常见的问题。

  • 软件耦合,难以扩展
  • 接口复杂,一些通用功能,比如日志、事务、审计、鉴权等在每个业务接口里都要实现
  • 数据库操作复杂,每个数据请求接口都要实现对应业务逻辑的数据库的操作、数据的转换
  • 业务逻辑混杂,视图操作、模型定义、业务逻辑控制等都在一起实现,难以维护

针对这些问题,Spring框架提供了它的解决方案。

  • Spring IOC
  • Spring AOP
  • Spring Data
  • Spring MVC

除此之外,Spring框架还有一些其他的Core技术:

  • Spring Resource
  • Spring Validation
  • Spring DataBinding
  • Spring TypeConversion
  • Spring Expression Language SpringEL

除了Spring的核心框架,Spring还开发或整合了很多Java Web中常用的组件,便于集成和使用,避免二次开发。详情见
Spring Projects。

Spring 可以说是Java Web的全能小王子,为各种需求都整合了解决方案,并且基于框架,提供了丰富、完善的整合和配置能力,理解Spring的设计哲学有利于我们更好的使用这个框架,它包括:

Provide choice at every level.

Accommodate diverse perspectives.

Maintain strong backward compatibility. 

Care about API design. 

Set high standards for code quality.

翻译过来就是:

  • 在每一个层级上都提供选择
  • 适应多种不同的视角
  • 提供很好的后向兼容性
  • 仔细设计API
  • 保证高代码质量

如果想看原文链接,可以点
这里。

Spring Boot

Spring在提供了强大的框架功能和资源整合能力的同时,也带来一个弊端。一个完整的Spring的项目,可能需要配置非常多的信息,才能实现整合和运行。特别是基于IOC机制的Bean配置和整合,实现起来是非常繁琐的。

基于这个问题,Spring Boot框架提供了Spring各个模块的默认配置,基于默认大于配置的思想,提供了自己的Web框架,让Web应用开发启动,变得更加的快速和方便。它甚至整合了Servlet容器,提供了内置的Tomcat、Netty、Undertow等容器实现,只要打包SpringBoot程序为Jar,就可以直接在服务器上部署。

Spring Boot同样提供了CLI工具,支持在命令行里直接运行程序,并通过参数进行定制化。

Spring 和 Spring Boot都提供了 maven 、 Gradle 工程管理工具的插件,可以直接使用管理工具运行应用程序,添加仓库依赖。

Spring Boot并没有重新实现Spring中的功能模块,并且也支持Spring的各种配置功能,它只是针对框架和功能模块,提供了一个合理的配置,在Spring框架要求显示声明配置的地方,提供了缺省时,由框架推测用户意图,直接基于默认配置运行的能力。

使用SpringBoot有利有弊,弊端是需要理解SpringBoot的缺省配置逻辑,要学习怎样替换缺省配置。有点是可以快速启动开发,项目配置简洁。总体来说,如果先使用Spring框架,了解各种配置方式的话,是利大于弊的。

Spring Cloud

Spring Could 是基于Spring Boot框架扩展的一个微服务框架。它是在Spring原有的功能模块上,增加了微服务所需的功能模块,主要包括:

  • Eureka 云端服务发现
  • Feign 远程服务调用
  • Hystrix 熔断器、容错管理工具
  • Zuul 动态路由
  • Ribbon 云端负载均衡

Spring Could主攻的微服务框架,在国内也有一款,就是阿里退出的Dubbo框架,不过他的维护者称,相对于Spring Could而言, Dubbo 功能更加的简单,只专注实现远程服务调用框架,相当于 Eureka + Feign,不过在国内貌似使用的更多。

Spring Clound的原理解释推荐一篇文章拜托!面试请不要再问我Spring Cloud底层原理!。

再推荐一个学习路线总结:

  • java后端学习路线

其他

对于一个Android开发来学java web开发的同学而言,要是从Spring Could快速开始,貌似磕磕绊绊也能行的通。要是从Servlet程序学习,慢慢用框架进行优化,这样则基础更加扎实。

在研究了一段时间之后,包括研究github上的一个原生Servlet Resty框架源码,Servlet资料和Spring相关的资料,以及大量的其他相关资料,以及手动实现一些简单的例子。才弄清楚文章总结的这个技术栈轮廓。

总得来说,要使用Spring全家桶,Spring框架肯定是要了解的。但是要熟悉掌握还是需要实践。如果从Servlet开始写起,逐步替换对比,则花费的时间会多一些,但掌握的会更牢固。学习方向上总体有两个建议,前提是要了对Servlet和Spring框架有基础了解。

  1. 根据自己的需求,用Spring Could框架和文档,搭建一个后台,边实现,边学习。在后台设计的时候,有意识地包含各种功能模块,最终掌握大部分的技术点。
  2. 参考Spring Boot 文档,针对不同的功能,采用Servlet、Spring、Spring Could等不同的方式实现,进行对比学习。最后再回到1,实现自己真正的后台需求。

总体来说,要根据自己的情况来定,并且也应该及时调整学习策略。

最后贴几个快速参考链接:

Spring Cloud中国社区

Spring Framework Documentation

Spring官网

Thymeleaf 一个流行的快速启动的JavaWeb脚手架

你可能感兴趣的:(java web开发概要)