Book Image

Developing Middleware in Java EE 8

Book Image

Developing Middleware in Java EE 8

Overview of this book

Middleware is the infrastructure in software based applications that enables businesses to solve problems, operate more efficiently, and make money. As the use of middleware extends beyond a single application, the importance of having it written by experts increases substantially. This book will help you become an expert in developing middleware for a variety of applications. The book starts off by exploring the latest Java EE 8 APIs with newer features and managing dependencies with CDI 2.0. You will learn to implement object-to-relational mapping using JPA 2.1 and validate data using bean validation. You will also work with different types of EJB to develop business logic, and with design RESTful APIs by utilizing different HTTP methods and activating JAX-RS features in enterprise applications. You will learn to secure your middleware with Java Security 1.0 and implement various authentication techniques, such as OAuth authentication. In the concluding chapters, you will use various test technologies, such as JUnit and Mockito, to test applications, and Docker to deploy your enterprise applications. By the end of the book, you will be proficient in developing robust, effective, and distributed middleware for your business.
Table of Contents (18 chapters)
Title Page
Copyright and Credits
Dedication
Packt Upsell
Contributors
Preface
Index

Maintaining user state


It's very likely that you may want to store some user state associated with each session. In this case, you can safely use instance variables to maintain this state, as each connection creates a unique instance of the endpoint class.

Moreover, there is an extra associated map with the session object, where you can store and retrieve user state. Although instance variables will do, the session object is useful in cases where you need to expose those states to other sessions of the same endpoint. In situations such as chatting, you may loop over all open sessions and examine each session's username, to check whether this message should be delivered to them or not.

Let's look at how can we use this extra map in practice. Suppose we are designing a WebSockets endpoint for a chat room; we will accept connections on /rooms/{roomName}/{username}. For each new user joining a room, we will send him/her the names of all the users in this room (including themselves). We will extend...