Maturing your security with Seam. Dan Allen Senior Software Engineer JBoss, a division of Red Hat

Size: px
Start display at page:

Download "Maturing your security with Seam. Dan Allen Senior Software Engineer JBoss, a division of Red Hat"

Transcription

1 Maturing your security with Seam Dan Allen Senior Software Engineer JBoss, a division of Red Hat

2 Who am I? Author of Seam in Action Member of Seam project JSF user from the trenches Linux, Java and Open Source advocate

3 Outline Why JAAS left us hanging Security principles Authentication in 3 steps Declarative authentication Open ID: delegation of trust Four styles of authorization Permissions: targets and actions

4 Seam security assumptions You are looking for a better security solution You are using Seam, JSF or both You'll want to use Seam after this talk ;) Contrary to popular belief... Seam is not invasive or heavyweight Seam works on any major application server or servlet container

5 JAAS, a surviving remnant of J2EE Entirely too complicated to setup Too container dependent Obscure configuration formats Poorly documented (in terms of examples) Pluggable? At what cost? Let's get back to basics Borrow the APIs generic enough to reuse

6 The security needs of a developer It should be simple to setup It should be easy to manage The application should not outgrow it

7 Security principles Identity Who you are (security principal) Isolates you from the guests Accompanied by a set of grants (roles and groups) Authentication Proving that you are you Based on a secret you know Authorization Resource control based on credentials

8 Authentication in 3 steps Switch on authentication in Seam Specify an authentication method declaratively Create a JSF login form Captures the user's credentials Submit button kicks off authentication routine Write the authentication method Cross reference user's credentials against database Assign user a security principal and mark user as logged in

9 Step 0: No prerequisites Security is a core concern in Seam Includes built-in support for routing user to login page Ties into event system Customized using navigation rules Authentication already setup in seam-gen projects

10 Step 1: Switching on authentication Declare an authentication method in components.xml <security:identity authentication-method="#{authenticator.authenticate}"/> Authentication method requirements: No arguments Return boolean indicating if credentials are valid Must be accessible via the EL Otherwise, the method can: Have any name Reside on any class (doesn't have to implement any special interfaces) Called behind the scenes by JAAS

11 Step 2: Create a JSF login form Native JSF support! No more j_username, j_password, and /j_security_check Can be used for eager or lazy authentication Bind credentials to built-in identity component <h:form id="login"> <h:panelgrid columns="2"> <h:outputlabel for="username">username</h:outputlabel> <h:inputtext id="username" value="#{identity.username}"/> <h:outputlabel for="password">password</h:outputlabel> <h:inputsecret id="password" value="#{identity.password}"/> </h:panelgrid> <div> <h:commandbutton value="login" action="#{identity.login}"/> </div> </h:form>

12 Step 3: Write an authentication method Adapts to any authentication backend The only catch is that you have to do the delegation Start with a simple strategy on Day 1 Basic procedure Identity component delivers credentials to be validated You validate credentials (username and password) and grant public class Authenticator protected Identity identity; public boolean authenticate() { out.println("login attempt by " + identity.getusername()); identity.addrole("admin"); return true; } }

13 Data-driven authentication method Query database using JPA public class Authenticator protected Identity protected EntityManager em; public boolean authenticate() { try { User user = (User) em.createquery("select u from User u " + "where u.username = #{identity.username}").getsingleresult(); if (user.getpassword().equals(identity.getpassword())) { identity.addrole("member"); return true; } } catch (NoResultException) {} return false; } }

14 Authentication Demo

15 Turning authentication over to Seam Identity management framework Annotation-based Pluggable identity store (JPA and LDAP supported out of the box) Built-in CRUD operations for users and roles/groups Eliminates authentication method <security:identity/> The catch: some addition configuration is required

16 Identity configuration Select identity store implementation (JPA or LDAP) Identify User and Role classes <security:jpa-identity-store user-class="com.company.app.model.user" role-class="com.company.app.model.userrole"/> Annotate User and Role public class User public String getusername() {... = "MD5") public String getpasswordhash() {... public Set<UserRole> getroles() {... public class UserRole public String getname() {... } }

17 Delegating authentication to a third party Open ID Eliminates the need for multiple usernames across different websites Users gets to choose who to trust with their credentials You don t have the burden of maintaining authentication secrets Seam has a built-in openid component Negotiates with third party to assign user an identity principal Used in place of identity component on login page; no password! You may still want to create a local profile for the user Can redirect new user to registration page after login

18 Open ID login page User chooses provider Seam negotiates hand-off (using openid4java) <h:form id="login"> <h:outputlabel for="openid">open ID</h:outputLabel> <h:inputtext id="openid" value="#{openid.id}"/> <h:commandbutton value="login" action="#{openid.login}"/> </h:form> Returns to /openid.xhtml pseudo-view after login Using navigation rules, you can... Transfer Open ID account to user principal Route user to registration page

19 Authorization styles Binary Separates members from the guests Role-based Stereotypes users Rule-based Declarative and contextual rules Access Control Lists (ACLs) Typically stored in database

20 Binary authorization Often first requirement Requires user to have an identity Identity component reports logged in state Java if (identity.isloggedin()) {... } Seam page descriptor <page view-id="/membersonly.xhtml" login-required="true">... </page> EL <h:panelgroup rendered="#{identity.loggedin}"> Rate this post... </h:panelgroup>

21 Role-based authorization Coarse-grained security Good for sectioning off areas of application Roles are assigned during authentication identity.addrole("role name") for custom mapping when using identity store Seam doesn't dictate a naming convention for roles Java if (identity.hasrole("admin")) {... } JBoss EL <s:link view="/admin/home.xhtml" rendered="#{identity.hasrole("admin")}" value="admin Area"/>

22 Declarative restrictions Mark resource as secured Classes and annotation JSF views (i.e., pages) <restrict> element If no criteria specified, permission implied Permission has 2 parts Target object or view ID Action method or life cycle phase Can override with a specific <restrict>#{identity.hasrole("admin")}</restrict>

23 Resolving a permission Permission(target, action) User identity Permission resolver chain Persistence permission resolver Rule-based permission resolver Grant?

24 Rule-based security Rules are the raison d'être of security You cannot enter the room with key You cannot buy alcohol unless you are 21 You cannot fly if you have illegal weapons or 4 oz of shampoo You cannot cash check unless it s endorsed Unique aspect of Seam security Based on Drools Expressive Hot swappable (if configured correctly) Can eliminate a lot of spaghetti business logic

25 Drools crash course Implementation of Rete algorithm Efficient pattern matching Anatomy of a rule Left-hand side (LHS) Facts which must prove true Right-hand side (RHS) Action to take if they do Expressed using a Drools rule language DRL Drools Rule Language DSL Human readable rule XML Legacy format; primarily for exchange Rules executed against objects in working memory Rules fire continuously until no new facts are matched

26 Example Drools rule Only admins can modify private or resort facilities rule ModifyPrivateFacility no-loop when $perm: PermissionCheck(name == "facilityhome", action in ("update", "remove"), granted == false) Role(name == "admin") Facility(type == "PRIVATE" == "RESORT") then $perm.grant(); end LHS public class Facility implements public void public void preremove() {} }

27 Rule-based Security Demo

28 Access control lists (ACLs) Permission with a specific target Granted to a user or a role/group Can be managed by the application Typically stored in a database

29 Managing permissions in Seam Includes a framework to manage Permission objects A Permission object represents A target An action A recipient (java.security.principal) Built-in permissionmanager component List Grant Revoke Very easy to integrate into application

30 Permission Management Demo

31 Summary Seam security is easy to adopt Configuration is kept to a minimum Built-in security components Often eliminates need to write any code at all Makes management of users and permissions easy Lots of options for authorization The security model matures with your application

32 Questions?

33 Resources Seam in Action, Manning Chapter 11: Securing Seam Applications In Relation To... Blog Seam, Hibernate, Web Beans, JBoss Tools, RichFaces Seam community forums & wiki Seam issue tracker

Maturing your application s security with Seam Security. Dan Allen Senior Software Engineer JBoss, by Red Hat

Maturing your application s security with Seam Security. Dan Allen Senior Software Engineer JBoss, by Red Hat Maturing your application s security with Seam Security Dan Allen Senior Software Engineer JBoss, by Red Hat Who am I? 2 Author of Seam in Action, Manning 2008 Seam and Weld project member JSR-314 (JSF

More information

TheServerSide.com. Dependency Injection in Java EE 6 - Part 5

TheServerSide.com. Dependency Injection in Java EE 6 - Part 5 TheServerSide.com Dependency Injection in Java EE 6 - Part 5 This series of articles introduces Contexts and Dependency Injection for Java EE (CDI), a key part of the Java EE 6 platform. Standardized via

More information

Refactoring to Seam. NetBeans. Brian Leonard Sun Microsystems, Inc. 14o

Refactoring to Seam. NetBeans. Brian Leonard Sun Microsystems, Inc. 14o Refactoring to Seam NetBeans Brian Leonard Sun Microsystems, Inc. 14o AGENDA 2 > The Java EE 5 Programming Model > Introduction to Seam > Refactor to use the Seam Framework > Seam Portability > Q&A Java

More information

Seam. Pete Muir JBoss, a Division of Red Hat.

Seam. Pete Muir JBoss, a Division of Red Hat. Seam Pete Muir JBoss, a Division of Red Hat http://in.relation.to/bloggers/pete pete.muir@jboss.org Road Map What is Seam? The future Why should I care about atomic conversations? How do I quickly build

More information

Improve and Expand JavaServer Faces Technology with JBoss Seam

Improve and Expand JavaServer Faces Technology with JBoss Seam Improve and Expand JavaServer Faces Technology with JBoss Seam Michael Yuan Kito D. Mann Product Manager, Red Hat Author, JSF in Action http://www.michaelyuan.com/seam/ Principal Consultant Virtua, Inc.

More information

Seam 3. Pete Muir JBoss, a Division of Red Hat

Seam 3. Pete Muir JBoss, a Division of Red Hat Seam 3 Pete Muir JBoss, a Division of Red Hat Road Map Introduction Java EE 6 Java Contexts and Dependency Injection Seam 3 Mission Statement To provide a fully integrated development platform for building

More information

JBoss Seam Integration with intent to use. Dan Allen Software Consultant Author, Seam in Action

JBoss Seam Integration with intent to use. Dan Allen Software Consultant Author, Seam in Action JBoss Seam Integration with intent to use Dan Allen Software Consultant Author, Seam in Action Who am I? Author of Seam in Action Author of the Seamless JSF series Committer on the JBoss Seam Project Software

More information

Metawidget UI Generation done right

Metawidget UI Generation done right Metawidget UI Generation done right http://metawidget.org What we will cover A common requirement Current practices A better way Common Requirement An everyday problem Most enterprise applications require

More information

object/relational persistence What is persistence? 5

object/relational persistence What is persistence? 5 contents foreword to the revised edition xix foreword to the first edition xxi preface to the revised edition xxiii preface to the first edition xxv acknowledgments xxviii about this book xxix about the

More information

JSR 299: Web Beans. Web Beans Expert Group. Version: Public Review

JSR 299: Web Beans. Web Beans Expert Group. Version: Public Review JSR 299: Web Beans Web Beans Expert Group Version: Public Review Table of Contents 1. Architecture... 1 1.1. Contracts... 1 1.2. Supported environments... 1 1.3. Relationship to other specifications...

More information

Seam & Web Beans. Pete Muir JBoss, a division of Red Hat.

Seam & Web Beans. Pete Muir JBoss, a division of Red Hat. Seam & Web Beans Pete Muir JBoss, a division of Red Hat http://in.relation.to/bloggers/pete pete.muir@jboss.org 1 Road Map Background Seam Web Beans 2 Advantages of JSF/JPA over Struts/EJB 2 Fewer, finer

More information

Seam Tools Tutorial. Version: Final-SNAPSHOT

Seam Tools Tutorial. Version: Final-SNAPSHOT Seam Tools Tutorial Version: 4.2.0.Final-SNAPSHOT 1. Create a Seam Application... 1 1.1. Start Development Database... 1 2. 3. 4. 5. 1.2. Create and deploy Seam Web Project... 3 1.3. Start JBoss Application

More information

Shale and the Java Persistence Architecture. Craig McClanahan Gary Van Matre. ApacheCon US 2006 Austin, TX

Shale and the Java Persistence Architecture. Craig McClanahan Gary Van Matre. ApacheCon US 2006 Austin, TX Shale and the Java Persistence Architecture Craig McClanahan Gary Van Matre ApacheCon US 2006 Austin, TX 1 Agenda The Apache Shale Framework Java Persistence Architecture Design Patterns for Combining

More information

Introduction to Seam. Pete Muir. JBoss, a division of Red Hat

Introduction to Seam. Pete Muir. JBoss, a division of Red Hat Introduction to Seam Pete Muir JBoss, a division of Red Hat Road Map Background Seam concepts Seam with Wicket (at the BOF) Seam Extras 2 Advantages of JSF/JPA over Struts/EJB 2 Fewer, finer grained artifacts

More information

Session 24. Introduction to Java Server Faces (JSF) Robert Kelly, Reading.

Session 24. Introduction to Java Server Faces (JSF) Robert Kelly, Reading. Session 24 Introduction to Java Server Faces (JSF) 1 Reading Reading IBM Article - www.ibm.com/developerworks/java/library/jjsf2fu1/index.html Reference Sun Tutorial (chapters 4-9) download.oracle.com/javaee/6/tutorial/doc/

More information

APPLICATION SECURITY ENHANCEMENTS IN JAVA EE 6

APPLICATION SECURITY ENHANCEMENTS IN JAVA EE 6 APPLICATION SECURITY ENHANCEMENTS IN JAVA EE 6 SRINI PENCHIKALA JavaOne 2010 Conference ABOUT THE SPEAKER Security Architect Certified Scrum Master Author, Editor (InfoQ) IASA Austin Chapter Leader Detroit

More information

Fast Track to EJB 3.0 and the JPA Using JBoss

Fast Track to EJB 3.0 and the JPA Using JBoss Fast Track to EJB 3.0 and the JPA Using JBoss The Enterprise JavaBeans 3.0 specification is a deep overhaul of the EJB specification that is intended to improve the EJB architecture by reducing its complexity

More information

JBoss Seam. Michael Yuan, PhD Ezee Inc.

JBoss Seam. Michael Yuan, PhD Ezee Inc. JBoss Seam Michael Yuan, PhD Ezee Inc. http://www.michaelyuan.com/ Who am I Seam core dev team member Asynchronous method and Quartz integration Performance analysis Support for non-jboss servers Tools

More information

Developing Applications with Java EE 6 on WebLogic Server 12c

Developing Applications with Java EE 6 on WebLogic Server 12c Developing Applications with Java EE 6 on WebLogic Server 12c Duration: 5 Days What you will learn The Developing Applications with Java EE 6 on WebLogic Server 12c course teaches you the skills you need

More information

At present we use several collaboration (web) tools, like SuperB website Wiki SVN Document management system etc.

At present we use several collaboration (web) tools, like SuperB website Wiki SVN Document management system etc. At present we use several collaboration (web) tools, like SuperB website Wiki SVN Document management system etc. Each tool is a stand-alone service. Should we try to «consolidate» applications? 2/10 From

More information

PicketLink Reference Documentation. PicketLink [

PicketLink Reference Documentation. PicketLink [ PicketLink Reference Documentation PicketLink [http://www.picketlink.org] PicketLink Reference Documentation by Version 2.6.0.CR1 1. Overview... 1 1.1. What is PicketLink?... 1 1.2. Where do I get started?...

More information

Seam. Pete Muir JBoss, a Division of Red Hat.

Seam. Pete Muir JBoss, a Division of Red Hat. Seam Pete Muir JBoss, a Division of Red Hat http://in.relation.to/bloggers/pete pete.muir@jboss.org 1 Road Map Background Seam Future 2 Advantages of JSF/JPA over Struts/EJB 2 Fewer, finer grained artifacts

More information

Migrating traditional Java EE applications to mobile

Migrating traditional Java EE applications to mobile Migrating traditional Java EE applications to mobile Serge Pagop Sr. Channel MW Solution Architect, Red Hat spagop@redhat.com Burr Sutter Product Management Director, Red Hat bsutter@redhat.com 2014-04-16

More information

Mastering JavaServer Faces

Mastering JavaServer Faces Mastering JavaServer Faces Bryan Basham Software Alchemist basham47@gmail.com http://www.linkedin.com/in/softwarealchemist Bryan Basham Mastering JavaServer Faces Slide 1 Topics Mind Map Introduction to

More information

Oracle Fusion Middleware 11g: Build Applications with ADF I

Oracle Fusion Middleware 11g: Build Applications with ADF I Oracle University Contact Us: +966 1 1 2739 894 Oracle Fusion Middleware 11g: Build Applications with ADF I Duration: 5 Days What you will learn This course is aimed at developers who want to build Java

More information

Java EE 6: Develop Web Applications with JSF

Java EE 6: Develop Web Applications with JSF Oracle University Contact Us: +966 1 1 2739 894 Java EE 6: Develop Web Applications with JSF Duration: 4 Days What you will learn JavaServer Faces technology, the server-side component framework designed

More information

"Web Age Speaks!" Webinar Series

Web Age Speaks! Webinar Series "Web Age Speaks!" Webinar Series Java EE Patterns Revisited WebAgeSolutions.com 1 Introduction Bibhas Bhattacharya CTO bibhas@webagesolutions.com Web Age Solutions Premier provider of Java & Java EE training

More information

Oracle - Developing Applications for the Java EE 7 Platform Ed 1 (Training On Demand)

Oracle - Developing Applications for the Java EE 7 Platform Ed 1 (Training On Demand) Oracle - Developing Applications for the Java EE 7 Platform Ed 1 (Training On Demand) Code: URL: D101074GC10 View Online The Developing Applications for the Java EE 7 Platform training teaches you how

More information

A Red Hat Perspective

A Red Hat Perspective TITLE JSR-314: SLIDE: JavaServer HEADLINE Faces 2.0 Presenter A Red Hat Perspective name Title, Red Hat Date Dan Allen Senior Software Engineer, RedHat JSR-314 Expert Group Member October 8, 2009 1 Roadmap

More information

Module 8 The Java Persistence API

Module 8 The Java Persistence API Module 8 The Java Persistence API Objectives Describe the role of the Java Persistence API (JPA) in a Java EE application Describe the basics of Object Relational Mapping Describe the elements and environment

More information

Object-relational mapping EJB and Hibernate

Object-relational mapping EJB and Hibernate T A R T U Ü L I K O O L MATEMAATIKA-INFORMAATIKATEADUSKOND Arvutiteaduse instituut Infotehnoloogia eriala Aleksandr Tkatšenko Object-relational mapping EJB and Hibernate Referaat aines Tarkvaratehnika

More information

JSR-303 Bean Validation. Emmanuel Bernard Doer JBoss, a Division of Red Hat

JSR-303 Bean Validation. Emmanuel Bernard Doer JBoss, a Division of Red Hat JSR-303 Bean Validation Emmanuel Bernard Doer JBoss, a Division of Red Hat emmanuel@hibernate.org Emmanuel Bernard Hibernate Search in Action blog.emmanuelbernard.com twitter.com/emmanuelbernard Help the

More information

What is tackled in the Java EE Security API (Java EE 8)

What is tackled in the Java EE Security API (Java EE 8) What is tackled in the Java EE Security API (Java EE 8) WHY UPDATE? ALREADY AVAILABLE? AGENDA JAVA EE SECURITY JSR-375 SOTERIA CONCEPTS DEMO RUDY DE BUSSCHER C4J Senior Java Web Developer, Java Coach JSR-375

More information

foreword to the first edition preface xxi acknowledgments xxiii about this book xxv about the cover illustration

foreword to the first edition preface xxi acknowledgments xxiii about this book xxv about the cover illustration contents foreword to the first edition preface xxi acknowledgments xxiii about this book xxv about the cover illustration xix xxxii PART 1 GETTING STARTED WITH ORM...1 1 2 Understanding object/relational

More information

Java- EE Web Application Development with Enterprise JavaBeans and Web Services

Java- EE Web Application Development with Enterprise JavaBeans and Web Services Java- EE Web Application Development with Enterprise JavaBeans and Web Services Duration:60 HOURS Price: INR 8000 SAVE NOW! INR 7000 until December 1, 2011 Students Will Learn How to write Session, Message-Driven

More information

Model Driven Development with EMF and EclipseLink (experiences in MDD and generating user interfaces)

Model Driven Development with EMF and EclipseLink (experiences in MDD and generating user interfaces) Model Driven Development with EMF and EclipseLink (experiences in MDD and generating user interfaces) Suresh Krishna, Oracle Inc. EclipseCon, 03.20.2008. 1 Background : Model acts as the heart of the business

More information

JSR-299 (CDI), Weld and the Future of Seam. Dan Allen Principal Software Engineer JBoss by Red Hat

JSR-299 (CDI), Weld and the Future of Seam. Dan Allen Principal Software Engineer JBoss by Red Hat JSR-299 (CDI), Weld and the Future of Seam Dan Allen Principal Software Engineer JBoss by Red Hat Agenda 2 Java EE today Where JSR-299 fits in JSR-299 themes CDI programming model tour CDI extensions Weld

More information

CMP 436/774. Introduction to Java Enterprise Edition. Java Enterprise Edition

CMP 436/774. Introduction to Java Enterprise Edition. Java Enterprise Edition CMP 436/774 Introduction to Java Enterprise Edition Fall 2013 Department of Mathematics and Computer Science Lehman College, CUNY 1 Java Enterprise Edition Developers today increasingly recognize the need

More information

Integrating Seam and GWT

Integrating Seam and GWT Integrating Seam and GWT Integrating the JBoss Seam Framework with the GWT Toolkit : Use cases and patterns Ferda Tartanoglu Neox ia 6563 Who we are 2 > Ferda TARTANOGLU, PhD Consultant and Software Architect

More information

Connect-2-Everything SAML SSO (client documentation)

Connect-2-Everything SAML SSO (client documentation) Connect-2-Everything SAML SSO (client documentation) Table of Contents Summary Overview Refined tags Summary The Connect-2-Everything landing page by Refined Data allows Adobe Connect account holders to

More information

JVA-563. Developing RESTful Services in Java

JVA-563. Developing RESTful Services in Java JVA-563. Developing RESTful Services in Java Version 2.0.1 This course shows experienced Java programmers how to build RESTful web services using the Java API for RESTful Web Services, or JAX-RS. We develop

More information

Coveo Platform 7.0. Yammer Connector Guide

Coveo Platform 7.0. Yammer Connector Guide Coveo Platform 7.0 Yammer Connector Guide Notice The content in this document represents the current view of Coveo as of the date of publication. Because Coveo continually responds to changing market conditions,

More information

JSF Tags. This tutorial will cover a number of useful JSF tags. For a complete listing of available JSF tags consult the Oracle documentation at:

JSF Tags. This tutorial will cover a number of useful JSF tags. For a complete listing of available JSF tags consult the Oracle documentation at: Overview @author R.L. Martinez, Ph.D. Java EE 7 provides a comprehensive list of JSF tags to support JSF web development. The tags are represented in XHTML format on the server and are converted into HTML

More information

Business-Driven Software Engineering (6.Vorlesung) Bean Interaction, Configuration, Transactions, Security Thomas Gschwind <thg at zurich.ibm.

Business-Driven Software Engineering (6.Vorlesung) Bean Interaction, Configuration, Transactions, Security Thomas Gschwind <thg at zurich.ibm. Business-Driven Software Engineering (6.Vorlesung) Bean Interaction, Configuration, Transactions, Security Thomas Gschwind Agenda Bean Interaction and Configuration Bean Lookup

More information

JVA-163. Enterprise JavaBeans

JVA-163. Enterprise JavaBeans JVA-163. Enterprise JavaBeans Version 3.0.2 This course gives the experienced Java developer a thorough grounding in Enterprise JavaBeans -- the Java EE standard for scalable, secure, and transactional

More information

Comparative Analysis of EJB3 and Spring Framework

Comparative Analysis of EJB3 and Spring Framework Comparative Analysis of EJB3 and Spring Framework Janis Graudins, Larissa Zaitseva Abstract: The paper describes main facilities of EJB3 and Spring Framework as well as the results of their comparative

More information

More reading: A series about real world projects that use JavaServer Faces:

More reading: A series about real world projects that use JavaServer Faces: More reading: A series about real world projects that use JavaServer Faces: http://www.jsfcentral.com/trenches 137 This is just a revision slide. 138 Another revision slide. 139 What are some common tasks/problems

More information

MULTI FACTOR AUTHENTICATION USING THE NETOP PORTAL. 31 January 2017

MULTI FACTOR AUTHENTICATION USING THE NETOP PORTAL. 31 January 2017 MULTI FACTOR AUTHENTICATION USING THE NETOP PORTAL 31 January 2017 Contents 1 Introduction... 2 1.1 Prerequisite for configuring the multi-factor authentication:... 2 1.1.1 On the Guest side... 2 1.1.2

More information

JBoss Enterprise Application Platform 4.2

JBoss Enterprise Application Platform 4.2 JBoss Enterprise Application Platform 4.2 Hibernate Validator Reference Guide Edition 1.0 For use with JBoss Enterprise Application Platform 4.2 Last Updated: 2017-10-02 JBoss Enterprise Application Platform

More information

Enhancing cloud applications by using external authentication services. 2015, 2016 IBM Corporation

Enhancing cloud applications by using external authentication services. 2015, 2016 IBM Corporation Enhancing cloud applications by using external authentication services After you complete this section, you should understand: Terminology such as authentication, identity, and ID token The benefits of

More information

Enterprise Java Security Fundamentals

Enterprise Java Security Fundamentals Pistoia_ch03.fm Page 55 Tuesday, January 6, 2004 1:56 PM CHAPTER3 Enterprise Java Security Fundamentals THE J2EE platform has achieved remarkable success in meeting enterprise needs, resulting in its widespread

More information

Best Practices: Authentication & Authorization Infrastructure. Massimo Benini HPCAC - April,

Best Practices: Authentication & Authorization Infrastructure. Massimo Benini HPCAC - April, Best Practices: Authentication & Authorization Infrastructure Massimo Benini HPCAC - April, 03 2019 Agenda - Common Vocabulary - Keycloak Overview - OAUTH2 and OIDC - Microservices Auth/Authz techniques

More information

Portlet Application Development Webinar exercise using JSF and JPA with Rational Application Developer

Portlet Application Development Webinar exercise using JSF and JPA with Rational Application Developer Portlet Application Development Webinar exercise using JSF and JPA with Rational Application Developer This exercise demonstrates how to create an end-to-end Java Persistence API (JPA) enabled Java Server

More information

Introduction to Web Application Development Using JEE, Frameworks, Web Services and AJAX

Introduction to Web Application Development Using JEE, Frameworks, Web Services and AJAX Introduction to Web Application Development Using JEE, Frameworks, Web Services and AJAX Duration: 5 Days US Price: $2795 UK Price: 1,995 *Prices are subject to VAT CA Price: CDN$3,275 *Prices are subject

More information

Java Enterprise Edition

Java Enterprise Edition Java Enterprise Edition The Big Problem Enterprise Architecture: Critical, large-scale systems Performance Millions of requests per day Concurrency Thousands of users Transactions Large amounts of data

More information

Spotfire Security. Peter McKinnis July 2017

Spotfire Security. Peter McKinnis July 2017 Spotfire Security Peter McKinnis July 2017 Outline Authentication in Spotfire Spotfire Server 7.9 Sites Feature and Authentication Authorization in Spotfire Data Security Spotfire Statistics Services Security

More information

JSR-299: Contexts and Dependency Injection for Java EE

JSR-299: Contexts and Dependency Injection for Java EE JSR-299: Contexts and Dependency Injection for Java EE JSR-299 Expert Group Specification lead Gavin King, Red Hat Middleware, LLC Version Unofficial draft for community review 19 May 2009 Table of Contents

More information

Leverage Rational Application Developer v8 to develop Java EE6 application and test with WebSphere Application Server v8

Leverage Rational Application Developer v8 to develop Java EE6 application and test with WebSphere Application Server v8 Leverage Rational Application Developer v8 to develop Java EE6 application and test with WebSphere Application Server v8 Author: Ying Liu cdlliuy@cn.ibm.com Date: June 24, 2011 2011 IBM Corporation THE

More information

Apache OpenJPA. Bean Validation Integration in JPA 2.0. July 17, Copyright 2009, The Apache Software Foundation

Apache OpenJPA.  Bean Validation Integration in JPA 2.0. July 17, Copyright 2009, The Apache Software Foundation Apache OpenJPA http://openjpa.apache.org/ Bean Validation Integration in JPA 2.0 July 17, 2009 Copyright 2009, The Apache Software Foundation Legal This presentation is based on Early Access levels of

More information

Novell Access Manager 3.1

Novell Access Manager 3.1 Technical White Paper IDENTITY AND SECURITY www.novell.com Novell Access Manager 3.1 Access Control, Policy Management and Compliance Assurance Novell Access Manager 3.1 Table of Contents: 2..... Complete

More information

"Charting the Course... Mastering EJB 3.0 Applications. Course Summary

Charting the Course... Mastering EJB 3.0 Applications. Course Summary Course Summary Description Our training is technology centric. Although a specific application server product will be used throughout the course, the comprehensive labs and lessons geared towards teaching

More information

open source community experience distilled

open source community experience distilled Java EE 6 Development with NetBeans 7 Develop professional enterprise Java EE applications quickly and easily with this popular IDE David R. Heffelfinger [ open source community experience distilled PUBLISHING

More information

Java EE 6 New features in practice Part 2

Java EE 6 New features in practice Part 2 Java EE 6 New features in practice Part 2 Java and all Java-based marks are trademarks or registered trademarks of Sun Microsystems, Inc. in the U.S. and other countries. License for use and distribution

More information

Computer Components. Software{ User Programs. Operating System. Hardware

Computer Components. Software{ User Programs. Operating System. Hardware Computer Components Software{ User Programs Operating System Hardware What are Programs? Programs provide instructions for computers Similar to giving directions to a person who is trying to get from point

More information

Warm Up to Identity Protocol Soup

Warm Up to Identity Protocol Soup Warm Up to Identity Protocol Soup David Waite Principal Technical Architect 1 Topics What is Digital Identity? What are the different technologies? How are they useful? Where is this space going? 2 Digital

More information

Taming the Spaghetti: Rich Web Applications With Errai. Christian Sadilek Lincoln Baxter III JBoss / Red Hat

Taming the Spaghetti: Rich Web Applications With Errai. Christian Sadilek Lincoln Baxter III JBoss / Red Hat Taming the Spaghetti: Rich Web Applications With Errai Christian Sadilek (@csadilek) Lincoln Baxter III (@lincolnthree) JBoss / Red Hat Another Java Web Framework? Photo by: darkuncle From: Flickr What

More information

TheServerSide.com. Part 3 of dependency injection in Java EE 6

TheServerSide.com. Part 3 of dependency injection in Java EE 6 TheServerSide.com Part 3 of dependency injection in Java EE 6 This series of articles introduces Contexts and Dependency Injection for Java EE (CDI), a key part of the Java EE 6 platform. Standardized

More information

JSF - H:PANELGRID. JSF Tag. Rendered Output. Tag Attributes. The h:panel tag renders an HTML "table" element. Attribute & Description.

JSF - H:PANELGRID. JSF Tag. Rendered Output. Tag Attributes. The h:panel tag renders an HTML table element. Attribute & Description. http://www.tutorialspoint.com/jsf/jsf_panelgrid_tag.htm JSF - H:PANELGRID Copyright tutorialspoint.com The h:panel tag renders an HTML "table" element. JSF Tag

More information

Exam Name: IBM Certified System Administrator - WebSphere Application Server Network Deployment V7.0

Exam Name: IBM Certified System Administrator - WebSphere Application Server Network Deployment V7.0 Vendor: IBM Exam Code: 000-377 Exam Name: IBM Certified System Administrator - WebSphere Application Server Network Deployment V7.0 Version: Demo QUESTION 1 An administrator would like to use the Centralized

More information

1 Markus Eisele, Insurance - Strategic IT-Architecture

1 Markus Eisele, Insurance - Strategic IT-Architecture 1 Agenda 1. Java EE Past, Present and Future 2. Java EE 7 Platform as a Service 3. PaaS Roadmap 4. Focus Areas 5. All the Specs 2 http://blog.eisele.net http://twitter.com/myfear markus.eisele@msg-systems.com

More information

purequery Deep Dive Part 2: Data Access Development Dan Galvin Galvin Consulting, Inc.

purequery Deep Dive Part 2: Data Access Development Dan Galvin Galvin Consulting, Inc. purequery Deep Dive Part 2: Data Access Development Dan Galvin Galvin Consulting, Inc. Agenda The Problem Data Access in Java What is purequery? How Could purequery Help within My Data Access Architecture?

More information

JSR-299: The new Java standard for dependency injection and contextual lifecycle management

JSR-299: The new Java standard for dependency injection and contextual lifecycle management Weld - JSR-299 Reference Implementation JSR-299: The new Java standard for dependency injection and contextual lifecycle management Gavin King Pete Muir Dan Allen David Allen Italian Translation: Nicola

More information

J2EE Interview Questions

J2EE Interview Questions 1) What is J2EE? J2EE Interview Questions J2EE is an environment for developing and deploying enterprise applications. The J2EE platform consists of a set of services, application programming interfaces

More information

Oracle Fusion Middleware 11g: Build Applications with ADF I

Oracle Fusion Middleware 11g: Build Applications with ADF I Oracle University Contact Us: Local: 1800 103 4775 Intl: +91 80 4108 4709 Oracle Fusion Middleware 11g: Build Applications with ADF I Duration: 5 Days What you will learn Java EE is a standard, robust,

More information

JBoss Enterprise Application Platform 5

JBoss Enterprise Application Platform 5 JBoss Enterprise Application Platform 5 Hibernate Validator Reference Guide Edition 5.2.0 for Use with JBoss Enterprise Application Platform 5 Last Updated: 2017-10-13 JBoss Enterprise Application Platform

More information

CO Java EE 6: Develop Database Applications with JPA

CO Java EE 6: Develop Database Applications with JPA CO-77746 Java EE 6: Develop Database Applications with JPA Summary Duration 4 Days Audience Database Developers, Java EE Developers Level Professional Technology Java EE 6 Delivery Method Instructor-led

More information

Red Hat JBoss Enterprise Application Platform 7.1

Red Hat JBoss Enterprise Application Platform 7.1 Red Hat JBoss Enterprise Application Platform 7.1 Security Architecture For Use with Red Hat JBoss Enterprise Application Platform 7.1 Last Updated: 2018-04-05 Red Hat JBoss Enterprise Application Platform

More information

A web application serving queries on renewable energy sources and energy management topics database, built on JSP technology

A web application serving queries on renewable energy sources and energy management topics database, built on JSP technology International Workshop on Energy Performance and Environmental 1 A web application serving queries on renewable energy sources and energy management topics database, built on JSP technology P.N. Christias

More information

Prototype 1.0 Specification

Prototype 1.0 Specification Prototype 1.0 Specification Javier Ramos Rodríguez Use Case View The prototype 1.0 will implement some basic functionality of the system to check if the technology used is the appropriate one to implement

More information

JBOSS AS 7 AND JBOSS EAP 6 ADMINISTRATION AND CLUSTERING (4 Days)

JBOSS AS 7 AND JBOSS EAP 6 ADMINISTRATION AND CLUSTERING (4 Days) www.peaklearningllc.com JBOSS AS 7 AND JBOSS EAP 6 ADMINISTRATION AND CLUSTERING (4 Days) This training course covers both the unsupported open source JBoss Application Server and the supported platform

More information

DreamFactory Security Guide

DreamFactory Security Guide DreamFactory Security Guide This white paper is designed to provide security information about DreamFactory. The sections below discuss the inherently secure characteristics of the platform and the explicit

More information

Java SE 8 Fundamentals

Java SE 8 Fundamentals Oracle University Contact Us: +52 1 55 8525 3225 Java SE 8 Fundamentals Duration: 5 Days What you will learn This Java SE 8 Fundamentals training introduces you to object-oriented programming using the

More information

TRAINING GUIDE. Lucity GIS. Web Administration

TRAINING GUIDE. Lucity GIS. Web Administration TRAINING GUIDE Lucity GIS Web Administration Lucity GIS Web Administration Contents Portal Config and SSO... 2 Registering with Portal... 2 Behind the Scenes... 4 Resetting Portal Integration... 5 Single

More information

Skyway Builder 6.3 Reference

Skyway Builder 6.3 Reference Skyway Builder 6.3 Reference 6.3.0.0-07/21/09 Skyway Software Skyway Builder 6.3 Reference: 6.3.0.0-07/21/09 Skyway Software Published Copyright 2009 Skyway Software Abstract The most recent version of

More information

Java EE 6 - Update Harpreet Singh GlassFish Portfolio Product Manager

Java EE 6 - Update Harpreet Singh GlassFish Portfolio Product Manager Java EE 6 - Update Harpreet Singh GlassFish Portfolio Product Manager Sun Microsystems 1 The Elephant In The Room 2 Here's what I can... Show Say 3 Business As Usual 4 Business As Usual = Participate in

More information

Not just an App. Server

Not just an App. Server Israel JBoss User Group Session 01 / 16.3.2006 JBoss Not just an App. Server By : Lior Kanfi Tikal Hosted by Tikal. w w w. t i k a l k. c o m Cost-Benefit Open Source Agenda Introduction» The problem domain

More information

1 Copyright 2011, Oracle and/or its affiliates. All rights reserved.

1 Copyright 2011, Oracle and/or its affiliates. All rights reserved. The following is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material,

More information

Object-Relational Mapping

Object-Relational Mapping Object-Relational Mapping Object-Relational Mapping Software Architecture ORM Problems ORM Solutions Demo Software Architecture Part 1 Architecture Separation of Concerns A design principle that comprises

More information

Very short introduction to JavaServer Faces

Very short introduction to JavaServer Faces Very short introduction to JavaServer Faces Example of an JSF application Application consists from two HTML pages The first page allows to enter a number, and as a result outputs squared number Example

More information

JBoss Seam and beyond

JBoss Seam and beyond JBoss Seam and beyond Jeroen Verhulst Joris De Winne Karel Maes Overall Presentation Goal basic concepts of Seam with practical demo (Jeroen) testing Seam applications (Joris) real-life project with Seam

More information

Java EE 7: Back-End Server Application Development

Java EE 7: Back-End Server Application Development Oracle University Contact Us: Local: 0845 777 7 711 Intl: +44 845 777 7 711 Java EE 7: Back-End Server Application Development Duration: 5 Days What you will learn The Java EE 7: Back-End Server Application

More information

Network Security Essentials

Network Security Essentials Network Security Essentials Fifth Edition by William Stallings Chapter 4 Key Distribution and User Authentication No Singhalese, whether man or woman, would venture out of the house without a bunch of

More information

Java EE Application Assembly & Deployment Packaging Applications, Java EE modules. Model View Controller (MVC)2 Architecture & Packaging EJB Module

Java EE Application Assembly & Deployment Packaging Applications, Java EE modules. Model View Controller (MVC)2 Architecture & Packaging EJB Module Java Platform, Enterprise Edition 5 (Java EE 5) Core Java EE Java EE 5 Platform Overview Java EE Platform Distributed Multi tiered Applications Java EE Web & Business Components Java EE Containers services

More information

Advanced Web Technology - Java Server Faces

Advanced Web Technology - Java Server Faces Berne University of Applied Sciences Advanced Web Technology - Java Server Faces Dr. E. Benoist Bibliography: Mastering Java Server Faces B.Dudney et al. - Wiley November 2005 1 Table of Contents Model

More information

Oracle Middleware 12c: Build Rich Client Applications with ADF Ed 1 LVC

Oracle Middleware 12c: Build Rich Client Applications with ADF Ed 1 LVC Oracle University Contact Us: Local: 1800 103 4775 Intl: +91 80 67863102 Oracle Middleware 12c: Build Rich Client Applications with ADF Ed 1 LVC Duration: 5 Days What you will learn This Oracle Middleware

More information

Course: JBoss Training: JBoss AS 7 and JBoss EAP 6 Administration and Clustering Training

Course: JBoss Training: JBoss AS 7 and JBoss EAP 6 Administration and Clustering Training Course: JBoss Training: JBoss AS 7 and JBoss EAP 6 Administration and Clustering Training Course Length: Duration; 4 days Course Code: WA 2060 This training course covers both the unsupported open source

More information

Introduction to Java Server Faces(JSF)

Introduction to Java Server Faces(JSF) Introduction to Java Server Faces(JSF) Deepak Goyal Vikas Varma Sun Microsystems Objective Understand the basic concepts of Java Server Faces[JSF] Technology. 2 Agenda What is and why JSF? Architecture

More information

JBPM Course Content. Module-1 JBPM overview, Drools overview

JBPM Course Content. Module-1 JBPM overview, Drools overview JBPM Course Content Module-1 JBPM overview, Drools overview JBPM overview Drools overview Community projects Vs Enterprise projects Eclipse integration JBPM console JBPM components Getting started Downloads

More information

Oracle Database. Installation and Configuration of Real Application Security Administration (RASADM) Prerequisites

Oracle Database. Installation and Configuration of Real Application Security Administration (RASADM) Prerequisites Oracle Database Real Application Security Administration 12c Release 1 (12.1) E61899-04 May 2015 Oracle Database Real Application Security Administration (RASADM) lets you create Real Application Security

More information