百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Java开发主流框架是什么?

liuian 2024-12-03 16:32 22 浏览

一、如果看传统企业开发

Struts、Spring和Hibernate ,简称SSH。

在10多年前,SSH绝对是业内最流行的企业级开发框架。

SSH框架是以Struts框架进行MVC分离、控制业务跳转,同时使用Hibernate进行持久化,最后配合Spring的统一管理进行实现的开发框架。相对于传统的J2EE开发框架来讲性能相对较高、资源消耗相对较少。具体优势如下:

  • 框架进行了代码分层,将Java代码和HTML代码进行分层,大大降低了开发人员的技术难度,不需要同时精通Java后端知识和Web前端知识。
  • 由于使用了Struts框架进行了MVC分离,降低了各层代码间的耦合度。
  • 与Spring的AOP机制相互独立,互不影响。
  • 使用SSH框架开发项目,能够大大提高项目的开发效率与开发质量。
  • 良好的扩展性和维护性。

由于Hibernate比较重,所以SSH框架后来被替换成SSM。M是Mybatis,现在SSM框架还在用。

二、现在的 Web 项目开发,大部分都转向了 SpringBoot 了。使用 SpringBoot 有三个最大的好处:

  1. 配置非常少,可以说是即插即用
  2. 基于 Spring 构建,入手门槛非常低
  3. 直接运行,不需要再考虑 Web 容器的问题

SpringBoot 大部分人都很熟了,不再赘述了。

2.1 推荐一个用Spring Boot搭建的文档在线预览解决方案:

官网及文档 地址:https://kkfileview.keking.cn

kkFileView,一款成熟且开源的文件文档在线预览项目解决方案,对标业内付费产品有【永中office】【office365】【idocv】等,免费!也就是说通过 kkFileView,基本上可以在浏览器中预览常见的各种文件。

项目特性

  1. 支持 office, pdf, cad 等办公文档
  2. 支持 txt, xml(渲染), md(渲染), java, php, py, js, css 等所有纯文本
  3. 支持 zip, rar, jar, tar, gzip 等压缩包
  4. 支持 jpg, jpeg, png, gif, tif, tiff 等图片预览(翻转,缩放,镜像)
  5. 使用 spring-boot 开发,预览服务搭建部署非常简便
  6. rest 接口提供服务,跨语言、跨平台特性(java,php,python,go,php,....)都支持,应用接入简单方便
  7. 抽象预览服务接口,方便二次开发,非常方便添加其他类型文件预览支持
  8. 最最重要 Apache 协议开源,代码 pull 下来想干嘛就干嘛

2.2 再推荐一个Java接口快速开发框架-magic-api

magic-api 是一个基于 Java 的接口快速开发框架,编写接口将通过 magic-api 提供的 UI 界面完成,自动映射为 HTTP 接口,无需定义 Controller、Service、Dao、Mapper、XML、VO 等 Java 对象即可完成常见的 HTTP API 接口开发

访问 http://localhost:9999/magic/web 进行操作

文档地址:https://ssssssss.org

三、想掌握大型互联网分布式架构还需要知道的技术要点:

RPC的设计架构与思想,RPC架构完整调用流程,自定义RPC相应因素详情等;

Netty三大组件,ByteBuffer 之工作原理、应用模式、分配与释放机制、源码剖析等;

RPC工程设计与整体结构,完成RPC服务注册与发现功能;

ZK核心组件剖析,ZK工作流程剖析,网络通信组件、会话接收器、并发处理器等;

Dubbo源码结构、整体设计及层次结构与作用,SPI机制,Dubbo服务注册发现剖析,Dubbo服务高可用,Dubbo服务治理之调用过程、服务降级与限流剖析,网络通信协议详解。

黑马程序员2022最新SSM框架教程_Spring+SpringMVC+Maven高级+SpringBoot+MyBatisPlus企业实用开发技术_哔哩哔哩_bilibili
SSM框架课程是Java从业人员从基础学习阶段进阶到初级程序员的入门课程,也是走向成功的必经之路。 SSM框架课程中共包含5个课程模块,分别是Spring框架、SpringMVC框架、Maven高级、SpringBoot框架、MyBatis-Plus框架。通过本阶段课程的学习,学习者可以掌握大量实用开发技术,企业开发规范,最终实现基于SpringBoot技术实现SSM整合。

四、我称这里是框架能量补给部分,希望能对你们有一点帮助

110 个常用的组件和框架!!!

以下排序是按照从技术组件到开发框架到代码工具:

1.WEB 容器

Tomcat:https://tomcat.apache.org/

Jetty:https://www.jetty.com/

JBoss:https://www.jboss.org/

Resin:https://caucho.com/products/resin

2.数据库

H2:https://h2database.com/

SQLite:https://www.sqlite.org/

MySQL:https://www.mysql.com/

Oracle:https://www.oracle.com/index.html

SQL Server:https://www.microsoft.com/en-us/sql-server/sql-server-downloads

PostgreSQL:https://www.postgresql.org/

MariaDB:https://mariadb.org/

3.缓存

Redis:https://redis.io/

Memcached:https://memcached.org/

4. 消息队列

Kafka:https://kafka.apache.org/

RocketMQ:https://rocketmq.apache.org/

Pulsar:https://pulsar.apache.org/

RabbitMQ:https://www.rabbitmq.com/

5.负载均衡

LVS:http://www.linuxvirtualserver.org/

NGINX:https://www.nginx.com/

6.分布式存储

Ceph:https://docs.ceph.com/

HDFS:https://hadoop.apache.org/docs/r1.2.1/hdfs_design.html

7.数据库集群

MHA:https://github.com/yoshinorim/mha4mysql-manager

8.分布式协调

ZooKeeper:https://zookeeper.apache.org/

9.大数据相关

Storm:https://storm.apache.org/

Flink:https://flink.apache.org/

Spark:https://spark.apache.org/

HBase:https://hbase.apache.org/

Flink:https://flink.apache.org/

ClickHouse:https://clickhouse.com/

Doris:https://doris.apache.org/

9.日志收集与分析

Filebeat:https://www.elastic.co/beats/filebeat

Logstash:https://www.elastic.co/logstash/

Kibana:https://www.elastic.co/kibana

10.搜索

Elasticsearch:https://www.elastic.co/

11.系统监控

SkyWalking;https://skywalking.apache.org/

zipkin:https://zipkin.io/

12.分库分表

ShardingSphere:https://shardingsphere.apache.org/

Mycat2:http://mycatone.top/

13.微服务

Spring Cloud;https://spring.io/projects/spring-cloud

14.RPC 框架

Dubbo;https://github.com/apache/dubbo

gRPC:https://github.com/grpc/grpc-java

15.网络框架

Netty:https://netty.io/

16.MVC 框架

Spring Framework:https://spring.io/projects/spring-framework

Spring Boot:https://spring.io/projects/spring-boot

17.数据层框架

MyBatis:https://github.com/mybatis/mybatis-3

MyBatis-Plus:https://github.com/baomidou/mybatis-plus

Hibernate:http://hibernate.org/orm/

18.数据库连接池

HikariCP:https://github.com/brettwooldridge/HikariCP

Druid:https://github.com/alibaba/druid

19.Redis 客户端

Jedis;https://github.com/xetorthio/jedis

Redisson:https://github.com/redisson/redisson

20.Rest 接口设计与开发

Swagger:https://swagger.io/

21.数据参数校验

Hibernate Validator:https://hibernate.org/validator/

22.安全相关

Shiro:https://shiro.apache.org/

Bouncy Castle:https://www.bouncycastle.org/java.html

jjwt:https://github.com/jwtk/jjwt

23.Reactive 编程

Akka:https://akka.io/

RxJava:https://github.com/ReactiveX/RxJava

vert.x:https://vertx.io/

24.单元测试

JUnit:https://junit.org/junit5/

25.测试辅助

JMockit:http://jmockit.github.io/

Mockito:https://github.com/mockito/mockito

JMeter:http://jmeter.apache.org/

Selenium:https://www.selenium.dev/

26.日志记录

Log4j2:https://logging.apache.org/log4j/

Logback:http://logback.qos.ch/

SLF4J;http://www.slf4j.org/

27.代码质量检查

Checkstyle;https://github.com/checkstyle/checkstyle

Spotbugs;https://github.com/spotbugs/spotbugs

28.代码生成

Lombok:https://projectlombok.org/

29.领域语言定制

ANTLR:https://www.antlr.org/

30.配置文件解析

config;https://github.com/lightbend/config

31.序列化格式

Avro:https://avro.apache.org/

Thrift:https://thrift.apache.org/

Protobuf:https://github.com/protocolbuffers/protobuf

32.模板引擎

Freemarker:https://freemarker.apache.org/

Thymeleaf:https://www.thymeleaf.org/

33.Office 文档处理

POI

https://poi.apache.org/

34.PDF 处理

iText:https://itextpdf.com/en

Apache PDFBox:https://pdfbox.apache.org/

35.高性能队列

Disruptor:https://lmax-exchange.github.io/disruptor/

36.HTTP 客户端

Async Http Client:https://github.com/AsyncHttpClient/async-http-client

Feign:https://github.com/OpenFeign/feign

Retrofit:https://square.github.io/retrofit/

37.二维码解析

ZXing:https://github.com/zxing/zxing

38.定时任务调度

Quartz:https://github.com/quartz-scheduler/quartz

39.JSON 解析

Gson:https://github.com/google/gson

Jackson:https://github.com/FasterXML/jackson

fastjson:https://github.com/alibaba/fastjson

40.分布式事务

Seata:https://github.com/seata/seata

41.属性映射

MapStruct:https://github.com/mapstruct/mapstruct

42.本地缓存

Ehcache:http://www.ehcache.org/

Caffeine:https://github.com/ben-manes/caffeine

43.系统排错与调优

JMH:http://openjdk.java.net/projects/code-tools/jmh/

Arthas:https://github.com/alibaba/arthas

44.命令行参数解析

JCommander:http://jcommander.org/

45.计算机视觉

JavaCV:https://github.com/bytedeco/javacv

45.工具集合

Guava:https://github.com/google/guava

Hutool:https://hutool.cn/

46.构建工具

Maven:https://maven.apache.org/

Gradle:https://gradle.org/

Bazel:https://bazel.build/

47.本地系统开发

JNA:https://github.com/java-native-access/jna

48.JVM

Adopt Open JDK:https://adoptopenjdk.net/

Graal:https://github.com/oracle/graal

Open JDK:https://openjdk.java.net/

49.多版本 Java 支持

jenv:https://github.com/jenv/jenv

50.爬虫相关

Nutch:https://nutch.apache.org/

Crawler4j:https://github.com/yasserg/crawler4j

jsoup:https://jsoup.org/

webmagic:https://github.com/code4craft/webmagic

相关推荐

Python tkinter学习笔记(七):Notebook和Treeview

‘Pythontkinter’是Python自带的GUI工具包,非常适合开发小型的GUI应用。最近使用‘tkinter’开发了一些自己日常使用的小工具,效果不错,于是把开发过程中学习到的一些tkin...

如何用 Python实现简单的表格界面

Excel有表格编辑功能,为什么我还要弄一个,不是多此一举么。道理是对的,但是很多会员功能才更加强大,不是吗?我们学语言,一来可以练习编码熟练的,巩固知识点,更重要的是你熟悉开发,以后如果你想实现一...

土地增值税清算中的施工合同进行判断是否有重复施工的情况

对土地增值税清算中的施工合同进行判断是否有重复施工的情况,使用Python中的Pandas库对施工合同的相关数据进行处理,基于文本相似度进行判断。1.读取施工内容数据:将施工内容数据存储在一个...

大模型时代必备技能:Embedding与向量数据库开发完全指南

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在官网-聚客AI学院大模型应用开发微调项目实践课程学习平台一.Embeddings与向量数据库1.1Embeddings的...

分布式实时搜索和分析引擎——Elasticsearch

一、概述Elasticsearch是一个基于Lucene的搜索引擎。它提供了具有HTTPWeb界面和无架构JSON文档的分布式,多租户能力的全文搜索引擎。Elasticsearch是用Java开发的...

elasticsearch v9.0.0重磅发布!解锁最新核心特性与性能飞跃!

时隔3年,Elasticsearch迎来重大版本更新!基于Lucene10.1.0构建,9.0.0版本在AI搜索、安全分析、向量计算、集群管理等多个领域实现突破性升级版本亮点o新...

Java中间件-Elasticsearch(java中间件技术及其应用开发)

Elasticsearch是一个非常强大的搜索引擎。它目前被广泛地使用于各个IT公司。Elasticsearch是由Elastic公司创建。它的代码位于GitHub-elastic/...

知名互联网公司和程序员都看好的数据库是什么?

2017年数据库领域的最大趋势是什么?什么是最热的数据处理技术?学什么数据库最有前途?程序员们普遍不喜欢的数据库是什么?本文都会一一揭秘。大数据时代,数据库的选择备受关注,此前本号就曾揭秘国内知名互联...

快速了解Elasticsearch(快速了解词语浑话的读音、释义等知识点)

Elasticsearch是一款基于Lucene的开源分布式全文搜索引擎,它支持实时搜索,具有优秀的可扩展性和可靠性。作为一款搜索引擎,Elasticsearch提供了丰富的API,使得开发人员可以通...

面试官:Kafka和ES选主有什么区别?

Kafka和ES都是用来处理大数据的中间件,一个是消息中间件的代表(Kafka),另一个是大数据搜索引擎的代表(ES)。它们在Java领域的使用非常广泛,在大数据方面就更不用说了,但它们的选...

ElasticSearch 23 种映射参数详解

ElasticSearch系列教程我们前面已经连着发了四篇了,今天第五篇,我们来聊一聊Es中的23种常见的映射参数。针对这23种常见的映射参数,松哥专门录制了一个视频教程:视频链接:...

还不会Elasticsearch?看这些知识入门刚刚好

作者:MacroZheng链接:https://juejin.im/post/5e8c7d65518825736512d097记得刚接触Elasticsearch的时候,没找啥资料,直接看了遍Ela...

Elasticsearch学习,请先看这一篇!

题记:Elasticsearch研究有一段时间了,现特将Elasticsearch相关核心知识、原理从初学者认知、学习的角度,从以下9个方面进行详细梳理。欢迎讨论……0.带着问题上路——ES是如何产...

Elasticsearch企业级应用全景图:原理/场景/优化/避坑四重奏

一、核心概念与架构原理1.基本定义Elasticsearch是基于ApacheLucene构建的分布式实时搜索与分析引擎,具有以下核心特性:分布式架构:支持PB级数据水平扩展近实时(NRT):数据...

ELK Stack系列之基础篇(八) - Elasticsearch原理总结(图示)

前言通过前面的知识,我们已经了解到了ELk到底是什么、以及他们的工作原理、ES集群架构、专有名词的一些解释。在进入下一阶段ES实操学习环节前,那么今天我将以图解的方式将ELK重点以及ES的相关逻辑进行...