2014-07-09 15:35:42 +02:00
# Awesome Java
2014-07-09 12:12:44 +02:00
2014-08-05 09:50:31 +02:00
A curated list of awesome Java frameworks, libraries and software. Inspired by other [awesome lists ](https://github.com/bayandin/awesome-awesomeness ).
2014-07-09 15:35:42 +02:00
- [Awesome Java ](#awesome-java )
2014-07-10 12:10:22 +02:00
- [Build Tool ](#build-tool )
2014-08-21 15:48:37 +02:00
- [Bytecode Manipulation ](#bytecode-manipulation )
2014-07-10 10:31:54 +02:00
- [Code Analysis ](#code-analysis )
2014-07-10 18:39:10 +02:00
- [Compiler-compiler ](#compiler-compiler )
2014-07-10 10:13:02 +02:00
- [Continuous Integration ](#continuous-integration )
2014-07-12 01:33:46 +02:00
- [Database ](#database )
2014-07-09 15:35:42 +02:00
- [Date and Time ](#date-and-time )
2014-07-10 10:31:54 +02:00
- [Dependency Injection ](#dependency-injection )
2014-07-12 09:27:13 +02:00
- [Development ](#development )
2014-07-10 11:20:21 -04:00
- [Distributed Applications ](#distributed-applications )
2014-07-16 22:05:38 +02:00
- [Distribution ](#distribution )
2014-07-24 14:27:49 +02:00
- [Document Processing ](#document-processing )
2014-07-09 15:35:42 +02:00
- [Game Development ](#game-development )
2014-08-05 10:00:37 +02:00
- [GUI ](#gui )
2014-07-10 15:19:28 +02:00
- [High Performance ](#high-performance )
2014-07-10 10:31:54 +02:00
- [IDE ](#ide )
2014-07-28 15:34:50 +02:00
- [Imagery ](#imagery )
2014-07-10 14:31:20 +02:00
- [JSON ](#json )
2014-08-05 10:00:37 +02:00
- [JVM and JDK ](#jvm-and-jdk )
2014-07-09 15:35:42 +02:00
- [Logging ](#logging )
- [Machine Learning ](#machine-learning )
- [Messaging ](#messaging )
- [Miscellaneous ](#miscellaneous )
- [Natural Language Processing ](#natural-language-processing )
2014-07-16 09:41:46 +01:00
- [Networking ](#networking )
2014-07-10 14:12:40 +02:00
- [ORM ](#orm )
2014-07-11 10:17:43 +02:00
- [PDF ](#pdf )
2014-08-05 10:00:37 +02:00
- [REST Frameworks ](#rest-frameworks )
2014-07-12 01:33:46 +02:00
- [Science ](#science )
2014-08-05 10:09:08 +02:00
- [Search ](#search )
2014-08-05 10:00:37 +02:00
- [Security ](#security )
2014-08-17 20:47:41 +02:00
- [Serialization ](#serialization )
2014-07-10 20:23:11 +02:00
- [Server ](#server )
2014-07-09 15:35:42 +02:00
- [Template Engine ](#template-engine )
- [Testing ](#testing )
- [Utility ](#utility )
- [Web Crawling ](#web-crawling )
- [Web Frameworks ](#web-frameworks )
- [Resources ](#resources )
2014-07-10 20:16:54 +02:00
- [Communities ](#communities )
2014-07-15 20:48:28 +02:00
- [Influential Books ](#influential-books )
2014-07-14 21:48:12 +02:00
- [Podcasts ](#podcasts )
- [Twitter ](#twitter )
- [Websites ](#websites )
2014-07-09 15:35:42 +02:00
- [Contributing ](#contributing )
2014-07-10 12:10:22 +02:00
## Build Tool
2014-07-15 20:15:25 +02:00
*Tools which handle the buildcycle of an application.*
2014-07-10 12:10:22 +02:00
2014-08-05 09:52:46 +02:00
* [Apache Maven ](http://maven.apache.org/ ) - Declarative build and dependency management which favors convention over configuration. It's preferable to Apache Ant which uses a rather procedural approach and can be difficult to maintain.
2014-07-15 20:15:25 +02:00
* [Gradle ](http://www.gradle.org/ ) - Incremental builds which are programmed via Groovy instead of declaring XML. Works well with Maven's dependency management and treats Ant scripts as first-class citizens.
2014-07-09 16:08:42 +02:00
2014-08-21 15:48:37 +02:00
## Bytecode Manipulation
*Libraries to manipulate Java bytecode programmatically.*
2014-09-01 10:50:46 +02:00
* [ASM ](http://asm.ow2.org/ ) - All purpose, low level, bytecode manipulation and analysis.
2014-09-19 12:14:53 +02:00
* [Javassist ](http://www.csg.ci.i.u-tokyo.ac.jp/~chiba/javassist/ ) - Tries to simplify the editing of bytecode.
2014-08-21 15:48:37 +02:00
2014-07-10 10:31:54 +02:00
## Code Analysis
2014-07-10 10:13:02 +02:00
2014-09-22 09:19:26 +02:00
*Tools that provide metrics and quality measurements.*
2014-07-10 12:10:22 +02:00
2014-09-01 10:50:46 +02:00
* [Checkstyle ](http://checkstyle.sourceforge.net/ ) - Static analysis of coding conventions and standards.
2014-07-15 20:42:16 +02:00
* [FindBugs ](http://findbugs.sourceforge.net/ ) - Static analysis of bytecode to find potential bugs.
2014-09-01 10:50:46 +02:00
* [PMD ](http://pmd.sourceforge.net/ ) - Source code analysis of bad coding practices.
2014-09-01 15:07:30 +02:00
* [SonarQube ](http://www.sonarqube.org/ ) - Integrates other analysis components via plugins and provides an overview of the metrics over time.
2014-07-10 10:13:02 +02:00
2014-07-10 18:39:10 +02:00
## Compiler-compiler
2014-09-22 09:19:26 +02:00
*Frameworks that help to create parsers, interpreters or compilers.*
2014-07-10 18:39:10 +02:00
2014-07-15 20:42:16 +02:00
* [ANTLR ](http://www.antlr.org/ ) - Complex full-featured framework for top-down parsing.
2014-07-16 09:35:46 +02:00
* [JavaCC ](https://javacc.java.net/ ) - More specific and slightly easier to learn. Has syntactic lookahead.
2014-07-10 18:39:10 +02:00
2014-07-10 10:13:02 +02:00
## Continuous Integration
2014-07-15 20:15:25 +02:00
*Tools which support continuously building, testing and releasing applications.*
2014-07-10 12:10:22 +02:00
2014-09-22 12:23:00 +02:00
* [Bamboo ](https://www.atlassian.com/software/bamboo ) Atlassian's CI solution with good integration of other products.
* [CircleCI ](https://circleci.com/ ) - Hosted service with a free trial.
* [Codeship ](https://www.codeship.io/features ) - Hosted services with a limited free plan.
2014-09-22 09:19:26 +02:00
* [Go ](http://www.thoughtworks.com/products/go-continuous-delivery ) ThoughtWork's CI open source solution.
2014-09-01 15:07:30 +02:00
* [Jenkins ](http://jenkins-ci.org/ ) - Provides server-based deployment services.
2014-09-22 12:23:00 +02:00
* [TeamCity ](http://www.jetbrains.com/teamcity/ ) JetBrain's CI solution with a free version.
2014-09-22 09:19:26 +02:00
* [Travis ](https://travis-ci.org ) - Hosted service often used for open source projects.
2014-07-10 14:12:40 +02:00
2014-07-12 01:33:46 +02:00
## Database
2014-07-10 14:12:40 +02:00
2014-07-15 20:15:25 +02:00
*Everything which simplifies interactions with the database.*
2014-07-10 14:12:40 +02:00
2014-09-22 12:23:00 +02:00
* [Flyway ](http://flywaydb.org/ ) - Simple database migration with Java API.
2014-07-28 15:34:50 +02:00
* [JDBI ](http://jdbi.org/ ) - Convenient abstraction of JDBC.
2014-07-11 21:53:41 +02:00
* [jOOQ ](http://www.jooq.org/ ) - Generates typesafe code based on SQL schema.
2014-09-22 09:19:26 +02:00
* [Presto ](https://github.com/facebook/presto ) - Distributed SQL query engine for big data.
2014-09-01 10:50:46 +02:00
* [Querydsl ](http://www.querydsl.com/ ) - Typesafe unified queries for Java.
2014-07-10 10:13:02 +02:00
2014-07-09 15:35:42 +02:00
## Date and Time
2014-07-09 16:08:42 +02:00
2014-09-22 09:37:37 +02:00
*Libraries related to handling date and time.*
2014-07-10 10:13:02 +02:00
2014-09-22 09:37:37 +02:00
* [Joda-Time ](http://www.joda.org/joda-time/ ) - De facto standard date/time-library before Java 8.
2014-08-17 21:16:38 +02:00
* [Time4J ](https://github.com/MenoData/Time4J ) - Advanced date and time library for Java.
2014-07-09 16:08:42 +02:00
2014-07-10 10:13:02 +02:00
## Dependency Injection
2014-07-15 20:48:28 +02:00
*Libraries that help to realize the [Inversion of Control ](http://en.wikipedia.org/wiki/Inversion_of_control ) paradigm.*
2014-07-10 12:10:22 +02:00
2014-07-11 21:53:41 +02:00
* [Dagger ](http://square.github.io/dagger/ ) - Compile-time injection framework without reflection, mainly for Android.
2014-09-22 09:37:37 +02:00
* [Guice ](https://github.com/google/guice ) - Lightweight but powerful framework that completes Dagger.
2014-07-10 10:13:02 +02:00
2014-07-12 09:27:13 +02:00
## Development
2014-09-22 12:20:29 +02:00
*Augmentation of the development process at a fundamental level.*
2014-07-10 20:16:54 +02:00
2014-09-22 12:32:40 +02:00
* [AspectJ ](https://eclipse.org/aspectj/ ) - Seamless aspect-oriented programming extension.
* [Auto ](https://github.com/google/auto ) - Collection of source code generators.
2014-09-22 09:37:37 +02:00
* [DCEVM ](http://ssw.jku.at/dcevm/ ) - Modification of the JVM that allows unlimited redefinition of loaded classes at runtime. OpenJDK 7/8 are supported by [this fork ](http://dcevm.github.io/ ).
2014-09-01 15:07:30 +02:00
* [JRebel ](http://zeroturnaround.com/software/jrebel/ ) - Commercial software that instantly reloads code and configuration changes without redeploys.
2014-09-22 12:23:00 +02:00
* [Lombok ](http://projectlombok.org/ ) - Code-generator which aims to reduce the verbosity of Java.
2014-07-28 15:34:50 +02:00
* [RxJava ](https://github.com/Netflix/RxJava ) - Library for composing asynchronous and event-based programs using observable sequences from the JVM.
2014-09-22 12:23:00 +02:00
* [Spring Loaded ](https://github.com/spring-projects/spring-loaded ) - Another class reloading agent for the JVM.
2014-07-28 15:34:50 +02:00
* [vert.x ](http://vertx.io/ ) - Polyglot event-driven application framework for the JVM.
2014-07-10 20:16:54 +02:00
2014-07-10 11:20:21 -04:00
## Distributed Applications
2014-07-16 09:35:46 +02:00
2014-09-22 12:20:29 +02:00
*Libraries and frameworks for writing distributed and fault-tolerant applications.*
2014-07-10 11:20:21 -04:00
2014-09-01 15:07:30 +02:00
* [Akka ](http://akka.io ) - Toolkit and runtime for building concurrent, distributed, and fault tolerant event-driven applications.
2014-07-28 15:34:50 +02:00
* [Apache Storm ](http://storm.incubator.apache.org/ ) - Distributed realtime computation system.
2014-07-12 01:33:46 +02:00
* [Apache ZooKeeper ](http://zookeeper.apache.org/ ) - Coordination service with distributed configuration, synchronization, and naming registry for large distributed systems.
2014-09-22 12:20:29 +02:00
* [Hazelcast ](http://hazelcast.org/ ) - Distributed and highly scalable in-memory datagrid.
* [Hystrix ](https://github.com/Netflix/Hystrix ) - Latency and Fault Tolerance for Distributed Systems.
2014-08-05 10:00:37 +02:00
* [JGroups ](http://www.jgroups.org/ ) - Toolkit for reliable messaging and creating clusters whose nodes can send messages to each other.
2014-09-22 12:20:29 +02:00
* [Quasar ](http://www.paralleluniverse.co/quasar/ ) - Lightweight threads and actors for the JVM.
2014-07-10 11:20:21 -04:00
2014-07-16 22:05:38 +02:00
## Distribution
*Tools which handle the distribution of Java applications in native formats.*
2014-08-05 10:00:37 +02:00
* [Bintray ](https://bintray.com/ ) - Version control for your binaries which handles the publishing. Can also be used with Maven or Gradle.
2014-09-22 12:36:46 +02:00
* [IzPack ](http://izpack.org/ ) - Setup authoring tool for cross-platform deployments.
2014-07-16 22:05:38 +02:00
* [Launch4j ](http://launch4j.sourceforge.net/ ) - Wraps JARs in lightweight and native Windows executables.
* [packr ](https://github.com/libgdx/packr#packr ) - Packs your JAR, assets and JVM for native distribution on Windows, Linux and Mac OS X.
2014-07-24 14:27:49 +02:00
## Document Processing
2014-07-24 14:28:50 +02:00
*Libraries that assist with processing office document formats.*
2014-07-24 14:27:49 +02:00
2014-09-22 12:36:46 +02:00
* [Apache POI ](http://poi.apache.org/ ) - Supports OOXML (XLSX, DOCX, PPTX) as well as OLE2 (XLS, DOC or PPT).
2014-07-24 14:27:49 +02:00
* [jOpenDocument ](http://www.jopendocument.org/ ) - Processes the OpenDocument format.
2014-07-09 15:35:42 +02:00
## Game Development
2014-07-09 16:08:42 +02:00
2014-07-15 20:15:25 +02:00
*Frameworks that support the development of games.*
2014-07-10 12:10:22 +02:00
2014-07-16 09:43:32 +02:00
* [jMonkeyEngine ](http://jmonkeyengine.org/ ) - Game engine for modern 3D development.
2014-07-15 20:48:28 +02:00
* [libGDX ](http://libgdx.badlogicgames.com/ ) - All-round cross-platform, high-level framework.
2014-08-05 10:00:37 +02:00
* [LWJGL ](http://lwjgl.org/ ) - Robust framework that abstracts libraries like OpenGL/CL/AL.
2014-07-09 16:08:42 +02:00
2014-08-05 10:09:08 +02:00
## GUI
*Libraries to create modern graphical user interfaces.*
* [JavaFX ](http://www.oracle.com/technetwork/java/javase/overview/javafx-overview-2158620.html ) - The successor of Swing.
* [Scene Builder ](http://www.oracle.com/technetwork/java/javase/downloads/javafxscenebuilder-info-2157684.html ) - Visual layout tool for JavaFX applications.
2014-07-10 15:19:28 +02:00
## High Performance
2014-07-15 20:15:25 +02:00
*Everything about high performance computation, from collections to specific libraries.*
2014-07-10 15:19:28 +02:00
2014-07-11 21:53:41 +02:00
* [Disruptor ](http://lmax-exchange.github.io/disruptor/ ) - Inter-thread messaging library.
2014-07-28 15:52:38 +02:00
* [fastutil ](http://fastutil.di.unimi.it/ ) - Fast and compact type-specific collections for Java.
* [GS Collections ](https://github.com/goldmansachs/gs-collections ) - Collection framework inspired by Smalltalk.
* [hftc ](https://github.com/OpenHFT/hftc ) - Hash sets and hash maps.
* [HPPC ](http://labs.carrotsearch.com/hppc.html ) - Primitive collections.
2014-07-29 18:29:21 +02:00
* [Javolution ](http://javolution.org/ ) - Library for real-time and embedded systems.
2014-07-28 15:52:38 +02:00
* [Trove ](http://trove.starlight-systems.com/ ) - Primitive collections.
2014-07-10 15:19:28 +02:00
2014-07-10 10:31:54 +02:00
## IDE
2014-07-09 22:56:32 +02:00
2014-07-15 20:15:25 +02:00
*Integrated development environments that try to simplify several aspects of development.*
2014-07-10 12:10:22 +02:00
2014-07-12 09:19:27 +02:00
* [Eclipse ](http://www.eclipse.org/ ) - Does a lot of things in the background. Noteworthy are its large amount of plugins.
* [IntelliJ IDEA ](http://www.jetbrains.com/idea/ ) - Supports a lot of JVM languages and provides good options for Android development. The commercial edition targets the enterprise sector.
2014-08-05 10:00:37 +02:00
* [NetBeans ](https://netbeans.org/ ) - Provides integration for several Java SE and EE features starting with database access and servers to HTML5 and AngularJS.
2014-07-09 22:56:32 +02:00
2014-07-28 15:34:50 +02:00
## Imagery
2014-07-29 18:29:21 +02:00
*Libraries that assist with the creation, evaluation or manipulation of graphical images.*
2014-07-28 15:34:50 +02:00
* [Picasso ](http://square.github.io/picasso/ ) - Image downloading and caching library for Android.
* [ZXing ](https://github.com/zxing/zxing ) - Multi-format 1D/2D barcode image processing library.
2014-08-05 10:09:08 +02:00
## JSON
*Libraries that simplify JSON processing.*
2014-09-22 12:20:29 +02:00
* [Gson ](https://code.google.com/p/google-gson/ ) - Serializes Java objects to JSON and vice versa. Good performance with on-the-fly usage.
2014-08-05 10:09:08 +02:00
* [Jackson ](http://wiki.fasterxml.com/JacksonHome ) - Similar to GSON but has performance gains if you need to instantiate the library more often.
2014-07-12 01:33:46 +02:00
## JVM and JDK
2014-07-10 22:42:49 +02:00
2014-09-22 12:20:29 +02:00
*Current implementations of the JVM/JDK.*
2014-07-10 22:42:49 +02:00
2014-07-11 21:53:41 +02:00
* [JDK 9 ](https://jdk9.java.net/ ) - Early access releases of JDK 9.
* [OpenJDK ](http://openjdk.java.net/ ) - Open source implementation.
2014-07-10 22:42:49 +02:00
2014-07-09 15:35:42 +02:00
## Logging
2014-07-09 22:56:32 +02:00
2014-07-15 20:15:25 +02:00
*Libraries that log the behavior of an application.*
2014-07-10 12:10:22 +02:00
2014-07-16 09:35:46 +02:00
* [Apache Log4j 2 ](http://logging.apache.org/log4j/ ) - Complete rewrite of the previous version. Now has a powerful plugin and configuration architecture.
2014-09-22 12:23:00 +02:00
* [kibana ](http://www.elasticsearch.org/overview/kibana/ ) - Analyzes and visualizes log files.
2014-07-12 09:19:27 +02:00
* [Logback ](http://logback.qos.ch/ ) - Founded by the same developer as Log4j and proves to be a robust logging library with interesting configuration options via Groovy.
2014-08-05 09:07:08 +02:00
* [logstash ](http://logstash.net/ ) - Tool for managing log files.
2014-07-12 01:33:46 +02:00
* [SLF4J ](http://www.slf4j.org/ ) - Abstraction layer which is to be used with an implementation.
2014-07-09 22:56:32 +02:00
2014-07-09 15:35:42 +02:00
## Machine Learning
2014-07-09 16:08:42 +02:00
2014-07-16 09:35:46 +02:00
*Tools that provide specific statistical algorithms which allow to learn from data.*
2014-07-10 12:10:22 +02:00
2014-07-12 01:33:46 +02:00
* [Apache Hadoop ](http://hadoop.apache.org/ ) - Open-source software framework for storage and large-scale processing of data-sets on clusters of commodity hardware.
2014-07-11 21:53:41 +02:00
* [Apache Mahout ](https://mahout.apache.org/ ) - Scalable algorithms focused on collaborative filtering, clustering and classification.
* [Apache Spark ](http://spark.apache.org/ ) - Open-source data analytics cluster computing framework.
2014-08-06 08:39:56 +02:00
* [h2o ](http://0xdata.github.io/h2o/ ) - Analytics engine for statistics over big data.
2014-07-11 21:53:41 +02:00
* [Weka ](http://www.cs.waikato.ac.nz/ml/weka/ ) - Collection of algorithms for data mining tasks ranging from pre-processing to visualization.
2014-07-09 16:08:42 +02:00
2014-07-09 15:35:42 +02:00
## Messaging
2014-07-10 10:31:54 +02:00
2014-07-15 20:15:25 +02:00
*Tools that help sending messages between clients to ensure protocol independency.*
2014-07-10 12:10:22 +02:00
2014-07-16 10:07:15 +02:00
* [Apache ActiveMQ ](http://activemq.apache.org/ ) - Open-source message broker that implements JMS and converts synchronous to asynchronous communication.
* [Apache Kafka ](http://kafka.apache.org/ ) - High-throughput distributed messaging system.
2014-07-12 09:19:27 +02:00
* [JBoss HornetQ ](http://hornetq.jboss.org/ ) - Clear, concise, modular and made to be embedded.
2014-07-10 10:31:54 +02:00
2014-07-09 15:35:42 +02:00
## Miscellaneous
2014-07-10 10:13:02 +02:00
2014-07-15 20:15:25 +02:00
*Everything else.*
2014-07-10 12:10:22 +02:00
2014-09-19 10:19:49 +02:00
* [Design Patterns ](https://github.com/iluwatar/java-design-patterns ) - Implementation and explanation of the most common design patterns.
2014-07-11 21:53:41 +02:00
* [Jimfs ](https://github.com/google/jimfs ) - In-memory file system.
2014-07-16 21:48:25 +02:00
* [Lanterna ](https://code.google.com/p/lanterna/ ) - Easy console text GUI library similar to curses.
2014-09-22 12:20:29 +02:00
* [Metrics ](http://metrics.codahale.com/ ) - Create your own metrics or add them for supported frameworks, then expose them via JMX or HTTP, or send them to a database.
* [OpenRefine ](http://openrefine.org/ ) - Tool for working with messy data: cleaning, transforming, extending it with web services and linking it to databases.
2014-07-16 09:50:02 +02:00
* [RoboVM ](http://www.robovm.org/ ) - Write native iOS apps in Java.
2014-07-10 10:13:02 +02:00
2014-07-09 15:35:42 +02:00
## Natural Language Processing
2014-07-09 16:08:42 +02:00
2014-07-16 09:35:46 +02:00
*Libraries that specialize on processing text.*
2014-07-10 12:10:22 +02:00
2014-07-12 09:25:32 +02:00
* [Apache OpenNLP ](https://opennlp.apache.org/ ) - Toolkit for common tasks like tokenization.
2014-07-11 21:53:41 +02:00
* [LingPipe ](http://alias-i.com/lingpipe/ ) - Toolkit for a variety of tasks ranging from POS tagging to sentiment analysis.
2014-09-22 12:20:29 +02:00
* [Mallet ](http://mallet.cs.umass.edu/ ) - Statistical natural language processing, document classification, clustering, topic modeling and more.
2014-07-09 16:08:42 +02:00
2014-07-16 09:41:46 +01:00
## Networking
*Libraries for network programming.*
* [Netty ](http://netty.io/ ) - A framework for building high performance network applications.
2014-09-22 12:20:29 +02:00
* [OkHttp ](http://square.github.io/okhttp/ ) - An HTTP+SPDY client for Android and Java applications.
2014-09-22 12:23:00 +02:00
* [Ratpack ](http://www.ratpack.io/ ) - A set of Java libraries that facilitate fast, efficient, evolvable and well tested HTTP applications.
2014-07-16 09:41:46 +01:00
2014-07-10 14:12:40 +02:00
## ORM
2014-07-15 20:15:25 +02:00
*APIs which handle the persistence of objects.*
2014-07-10 14:12:40 +02:00
2014-07-16 09:35:46 +02:00
* [EclipseLink ](https://www.eclipse.org/eclipselink/ ) - Supports a number of persistence standards: JPA, JAXB, JCA and SDO.
2014-07-12 09:25:32 +02:00
* [Hibernate ](http://hibernate.org/orm/ ) - Robust and widely used with an active community.
2014-07-10 14:12:40 +02:00
2014-07-11 10:17:43 +02:00
## PDF
2014-07-15 20:15:25 +02:00
*Everything that helps with the creation of PDF files.*
2014-07-11 10:17:43 +02:00
2014-07-11 21:53:41 +02:00
* [Apache FOP ](http://xmlgraphics.apache.org/fop/ ) - Creates PDF from XSL-FO.
* [Apache PDFBox ](http://pdfbox.apache.org/ ) - Toolbox for creating and manipulating PDF.
* [DynamicReports ](http://dynamicreports.org/ ) - Simplifies JasperReports.
2014-07-12 01:35:41 +02:00
* [iText ](http://itextpdf.com/ ) - Easy to use PDF library which creates PDF files programmatically but requires a license for commercial purposes.
2014-08-05 10:00:37 +02:00
* [JasperReports ](http://community.jaspersoft.com/project/jasperreports-library ) - Complex reporting engine.
2014-07-11 10:17:43 +02:00
2014-08-05 10:09:08 +02:00
## REST Frameworks
2014-07-09 22:56:32 +02:00
2014-08-05 10:09:08 +02:00
*Frameworks specifically for creating RESTful services.*
2014-07-10 12:10:22 +02:00
2014-08-05 10:09:08 +02:00
* [Dropwizard ](https://dropwizard.github.io/dropwizard/ ) - Opinionated framework for setting up modern web applications, includes Jetty, Jackson, Jersey and Metrics.
* [Jersey ](https://jersey.java.net/ ) - JAX-RS reference implementation.
* [RESTEasy ](http://resteasy.jboss.org/ ) - Fully certified and portable implementation of the JAX-RS specification.
* [Retrofit ](http://square.github.io/retrofit/ ) - A type-safe REST client for Java.
2014-08-17 21:02:44 +02:00
* [Swagger ](https://helloreverb.com/developers/swagger ) - Swagger is a specification and complete framework implementation for describing, producing, consuming, and visualizing RESTful web services.
2014-07-09 22:56:32 +02:00
2014-07-12 01:33:46 +02:00
## Science
2014-07-10 08:02:08 -05:00
2014-07-15 20:15:25 +02:00
*Libraries for scientific computing and analysis.*
2014-07-10 08:02:08 -05:00
2014-07-12 01:33:46 +02:00
* [SCaVis ](http://jwork.org/scavis/ ) - Environment for scientific computation, data analysis and data visualization.
2014-07-10 22:24:51 +02:00
2014-07-28 15:34:50 +02:00
## Search
*Engines which index documents for search and analysis.*
* [Apache Solr ](http://lucene.apache.org/solr/ ) - Full enterprise search engine optimized for high volume traffic.
2014-08-06 08:39:56 +02:00
* [Elasticsearch ](http://www.elasticsearch.org/ ) - Distributed, multitenant-capable full-text search engine with a RESTful web interface and schema-free JSON documents.
2014-07-28 15:34:50 +02:00
2014-08-05 10:09:08 +02:00
## Security
*Libraries that handle security, authentication, authorization or session management.*
* [Apache Shiro ](http://shiro.apache.org/ ) - Performs authentication, authorization, cryptography and session management.
* [Keycloak ](http://keycloak.jboss.org/ ) - Integrated SSO and IDM for browser apps and RESTful web services. Currently in beta but looks very promising.
* [PicketLink ](http://picketlink.org/ ) - PicketLink is an umbrella project for security and identity management for Java applications.
* [Spring Security ](http://projects.spring.io/spring-security/ ) - Focuses on authentication/authorization and protects against several attack vectors.
2014-08-17 20:47:41 +02:00
## Serialization
2014-09-22 12:20:29 +02:00
*Libraries that handle serialization with high efficiency.*
* [FlatBuffers ](https://github.com/google/flatbuffers ) - Memory efficient serialization library that can access serialized data without unpacking and parsing it.
* [Kryo ](https://github.com/EsotericSoftware/kryo ) - Fast and efficient object graph serialization framework.
* [MessagePack ](https://github.com/msgpack/msgpack-java ) - Efficient binary serialization format.
2014-08-17 20:47:41 +02:00
2014-07-10 20:23:47 +02:00
## Server
2014-07-10 20:23:11 +02:00
2014-07-15 20:15:25 +02:00
*Servers which are specifically used to deploy applications.*
2014-07-10 20:23:11 +02:00
2014-07-15 20:48:28 +02:00
* [Apache Tomcat ](http://tomcat.apache.org/ ) - Robust all-round server for Servlet and JSP.
2014-07-11 21:53:41 +02:00
* [Apache TomEE ](http://tomee.apache.org/ ) - Tomcat plus Java EE.
2014-08-05 10:00:37 +02:00
* [GlassFish ](https://glassfish.java.net/ ) - Open source reference implementation for Java EE sponsored by Oracle.
* [Jetty ](http://www.eclipse.org/jetty/ ) - Lightweight, small server, often embedded in projects.
* [WildFly ](http://www.wildfly.org/ ) - Formerly known as JBoss and developed by Red Hat with extensive Java EE support.
2014-07-10 20:23:11 +02:00
2014-07-09 15:35:42 +02:00
## Template Engine
2014-07-09 22:56:32 +02:00
2014-07-15 20:15:25 +02:00
*Tools which substitute expressions in a template.*
2014-07-10 12:10:22 +02:00
2014-07-14 21:40:52 +02:00
* [Apache Velocity ](http://velocity.apache.org/ ) - Templates for HTML pages, emails or source code generation in general.
* [FreeMarker ](http://freemarker.org/ ) - General templating engine without any heavyweight or opinionated dependencies.
2014-09-19 10:21:29 +02:00
* [Handlebars.java ](http://jknack.github.io/handlebars.java/ ) - Logic-less and semantic Mustache templates with Java.
2014-09-22 12:20:29 +02:00
* [JavaServer Pages ](https://jsp.java.net/ ) - Common templating for websites with custom tag libraries.
2014-07-14 21:40:52 +02:00
* [Thymeleaf ](http://www.thymeleaf.org/ ) - Aims to be a substitute for JSP and works for XML files in general.
2014-07-09 22:56:32 +02:00
2014-07-09 15:35:42 +02:00
## Testing
2014-07-09 16:08:42 +02:00
2014-07-15 20:15:25 +02:00
*Tools that test from object to interface level including performance and other benchmarks.*
2014-07-10 12:10:22 +02:00
2014-07-12 01:33:46 +02:00
* [Apache JMeter ](http://jmeter.apache.org/ ) - Functional testing and performance measurements.
* [Arquillian ](http://arquillian.org/ ) - Integration and functional testing platform with integration of Java EE containers.
2014-09-22 12:20:29 +02:00
* [AssertJ ](http://joel-costigliola.github.io/assertj/ ) - Fluent assertions that improve readability.
* [JMH ](http://openjdk.java.net/projects/code-tools/jmh/ ) - Microbenchmarking tool for the JVM.
* [JUnit ](http://junit.org/ ) - Common testing framework.
2014-07-12 01:33:46 +02:00
* [Mockito ](http://code.google.com/p/mockito/ ) - Creation of test double objects in automated unit tests for the purpose of TDD or BDD.
* [Selenium ](http://docs.seleniumhq.org/ ) - Portable software testing framework for web applications.
* [TestNG ](http://testng.org/ ) - Testing framework.
2014-09-22 12:20:29 +02:00
* [VisualVM ](http://visualvm.java.net/ ) - Visual interface for detailed information about running applications.
2014-07-09 16:08:42 +02:00
2014-07-09 15:35:42 +02:00
## Utility
2014-07-10 10:13:02 +02:00
2014-09-22 12:20:29 +02:00
*Libraries which provide general utility functions.*
2014-07-10 12:10:22 +02:00
2014-07-16 09:35:46 +02:00
* [Apache Commons ](http://commons.apache.org/ ) - Provides different general purpose functions like configuration, validation, collections, file upload or XML processing.
2014-09-22 12:20:29 +02:00
* [Guava ](http://code.google.com/p/guava-libraries/ ) - Collections, caching, primitives support, concurrency libraries, common annotations, string processing, I/O, and so forth.
2014-07-16 21:56:42 +02:00
* [javatuples ](http://www.javatuples.org/ ) - Does what it says, although the concept of tuples in general is debatable.
2014-07-14 21:40:52 +02:00
2014-07-09 15:35:42 +02:00
## Web Crawling
2014-07-09 22:56:32 +02:00
2014-07-15 20:15:25 +02:00
*Libraries that analyze the content of websites.*
2014-07-10 12:10:22 +02:00
2014-07-14 21:40:52 +02:00
* [Apache Nutch ](http://nutch.apache.org/ ) - Highly extensible, highly scalable Web crawler for production environment.
* [Crawler4j ](https://code.google.com/p/crawler4j/ ) - Simple lightweight alternative.
2014-09-22 12:20:29 +02:00
* [JSoup ](http://jsoup.org/ ) - Scrapes, parses, manipulates and cleans HTML.
2014-07-09 22:56:32 +02:00
2014-07-09 15:35:42 +02:00
## Web Frameworks
2014-07-09 16:08:42 +02:00
2014-07-15 20:15:25 +02:00
*Frameworks that handle the communication between the layers of an web application.*
2014-09-19 10:21:29 +02:00
h
2014-07-14 21:40:52 +02:00
* [Apache Tapestry ](http://tapestry.apache.org/ ) - Component oriented framework for creating dynamic, robust, highly scalable web applications in Java.
2014-08-05 10:00:37 +02:00
* [Apache Wicket ](http://wicket.apache.org/ ) - Component-based web application framework similar to Tapestry with a stateful GUI.
2014-07-14 21:40:52 +02:00
* [Google Web Toolkit ](http://www.gwtproject.org/ ) - Toolbox which includes a Java-to-JavaScript compiler for client-side code, XML parser, API for RPC, JUnit integration, internationalization support and widgets for the GUI.
2014-07-18 09:42:36 +02:00
* [Grails ](https://grails.org/ ) - Groovy framework with the aim to provide a highly productive environment by favoring convention over configuration, no XML and support for mixins.
2014-07-14 21:40:52 +02:00
* [Play ](http://www.playframework.com/ ) - Uses convention over configuration, hot code reloading and display of errors in the browser.
* [PrimeFaces ](http://primefaces.org/ ) - JSF framework which has a free and a commercial version with support. Provides several frontend components.
2014-09-22 12:20:29 +02:00
* [Spark ](http://www.sparkjava.com/ ) - Unique framework which focuses not on complex MVC patterns but on rapid development.
2014-08-05 10:00:37 +02:00
* [Spring Boot ](http://projects.spring.io/spring-boot/ ) - Microframework which simplifies the development of new Spring applications.
* [Spring ](http://projects.spring.io/spring-framework/ ) - Aims to simplify the development with Java EE and provides packages for dependency injection and aspect-oriented programming.
* [Vaadin ](https://vaadin.com/ ) - Event-driven framework build on top of GWT. Uses server-side architecture with Ajax on the client-side.
2014-07-09 16:08:42 +02:00
2014-07-10 20:16:54 +02:00
# Resources
2014-07-10 19:05:51 +08:00
2014-07-14 21:48:12 +02:00
## Communities
2014-07-15 20:15:25 +02:00
*Active discussions.*
2014-07-14 21:48:12 +02:00
* [r/java ](http://www.reddit.com/r/java ) - Subreddit for the Java community.
2014-07-16 09:35:46 +02:00
* [stackoverflow ](http://stackoverflow.com/questions/tagged/java ) - Question/answer platform.
2014-07-14 21:48:12 +02:00
2014-07-15 20:48:28 +02:00
## Influential Books
2014-07-14 21:48:12 +02:00
2014-07-15 20:15:25 +02:00
*Books about Java that had a high impact and are still worth reading.*
2014-07-14 21:48:12 +02:00
* [Effective Java (2nd Edition) ](http://www.amazon.com/Effective-Java-Edition-Joshua-Bloch/dp/0321356683 )
* [Java Concurrency in Practice ](http://www.amazon.com/Java-Concurrency-Practice-Brian-Goetz/dp/0321349601 )
* [Thinking in Java ](http://www.amazon.com/Thinking-Java-Edition-Bruce-Eckel/dp/0131872486 )
## Podcasts
2014-07-15 20:15:25 +02:00
*Something to listen to while programming.*
2014-07-14 21:48:12 +02:00
* [The Java Posse ](http://www.javaposse.com/ )
2014-07-09 15:35:42 +02:00
## Twitter
2014-07-09 21:47:53 +02:00
2014-09-19 11:02:22 +02:00
*Active accounts to follow.*
* [Adam Bien ](https://twitter.com/AdamBien/ ) - Freelancer: Author, JavaONE Rockstar Speaker, Consultant, Java Champion.
* [Antonio Goncalves ](https://twitter.com/agoncal/ ) - Java Champion, JUG Leader, Devoxx France, Java EE 6/7, JCP, Author.
* [Arun Gupta ](https://twitter.com/arungupta/ ) - Java Champion, JavaOne Rockstar, UG Leader, Devoxx4Kids-er, Red Hatter.
* [Bruno Borges ](https://twitter.com/brunoborges ) - Product Manager/Java Jock at Oracle.
* [Ed Burns ](https://twitter.com/edburns ) - Consulting Member of the Technical Staff at Oracle.
* [Eugen Paraschiv ](https://twitter.com/baeldung ) - Author of the Spring Security Course.
* [James Weaver ](https://twitter.com/JavaFXpert ) - Java/JavaFX/IoT developer, author and speaker.
* [Java EE ](https://twitter.com/Java_EE/ ) - Official Java EE Twitter account.
* [Java Magazine ](https://twitter.com/Oraclejavamag ) - Official Java Magazine account.
* [Java.net ](https://twitter.com/javanetbuzz/ ) - Official Java.net account.
* [Java ](https://twitter.com/java/ ) - Official Java Twitter account.
* [Javin Paul ](https://twitter.com/javinpaul ) - Well-known Java blogger.
* [Lukas Eder ](https://twitter.com/lukaseder ) - Founder and CEO Data Geekery (jOOQ).
2014-09-22 12:23:00 +02:00
* [Mario Fusco ](https://twitter.com/mariofusco ) - RedHatter, JUG coordinator, frequent speaker and author.
2014-09-19 11:02:22 +02:00
* [Mark Reinhold ](https://twitter.com/mreinhold ) - Chief Architect, Java Platform Group, Oracle.
* [Martijn Verburg ](https://twitter.com/karianna ) - London JUG co-leader, speaker, author, Java Champion and much more.
* [OpenJDK ](https://twitter.com/OpenJDK ) - Official OpenJDK account.
* [Reza Rahman ](https://twitter.com/reza_rahman ) - Java EE/GlassFish/WebLogic evangelist, author, speaker, open source hacker.
2014-09-19 12:12:01 +02:00
* [Simon Maple ](https://twitter.com/sjmaple ) - Java Champion, virtualJUG founder, LJC leader, RebelLabs author.
2014-09-19 11:02:22 +02:00
* [Stephen Colebourne ](https://twitter.com/jodastephen ) - Java Champion, speaker.
* [Tim Boudreau ](https://twitter.com/kablosna ) - Author and NetBeans guru.
* [Trisha Gee ](https://twitter.com/trisha_gee ) - Java Champion and speaker.
2014-07-09 21:47:53 +02:00
2014-07-09 15:35:42 +02:00
## Websites
2014-07-09 21:47:53 +02:00
2014-07-15 20:15:25 +02:00
*Sites to read.*
2014-07-10 12:10:22 +02:00
2014-09-22 12:23:00 +02:00
* [Google Java Style ](http://google-styleguide.googlecode.com/svn/trunk/javaguide.html )
2014-09-19 11:02:22 +02:00
* [InfoQ ](http://www.infoq.com/ )
2014-09-22 12:23:00 +02:00
* [Java Code Geeks ](http://www.javacodegeeks.com/ )
2014-07-09 21:47:53 +02:00
* [Java.net ](http://java.net/ )
2014-07-12 09:43:00 +02:00
* [Javalobby ](http://java.dzone.com/ )
2014-08-05 10:00:37 +02:00
* [JavaWorld ](http://www.javaworld.com/ )
2014-07-26 11:15:31 +02:00
* [RebelLabs ](http://zeroturnaround.com/rebellabs/ )
2014-09-22 12:20:29 +02:00
* [The Java Specialist' Newsletter ](http://www.javaspecialists.eu/archive/archive.jsp )
2014-09-22 12:23:00 +02:00
* [TheServerSide.com ](http://www.theserverside.com/ )
2014-09-22 12:20:29 +02:00
* [Thoughts On Java ](http://www.thoughts-on-java.org/ )
2014-07-09 21:47:53 +02:00
2014-07-09 15:35:42 +02:00
# Contributing
2014-07-11 21:54:27 +02:00
Contributions are very welcome!
2014-07-16 09:40:59 +01:00
Please have a look at [CONTRIBUTING ](https://github.com/akullpp/awesome-java/blob/master/CONTRIBUTING.md ) for guidelines.