
Classify security threats to an enterprise application select measures an architect can propose to mitigate them.Select appropriate locations to implement Java EE security technologies or features in a UML component and deployment diagram.Identify elements of the security model in the Java SE environment for remote clients, including Web Start, applets and the role of the SecurityManager class.Identify the use of the law of leaky abstractions or a specific anti-pattern in a given scenario.Identify a design pattern, using a description of its features, from the following: Facade, Strategy, Observer, Composite, and Abstract Factory.Select an appropriate pattern for a given application challenge from the following: Facade, Strategy, Observer, Composite, and Abstract Factory.Demonstrate knowledge of Java EE design patterns including: Service Starter, Singleton, Bean Locator, Resource Binder, Dependency Inj ection, Payload Extractor, Context Holder, and Thread Tracker.Identify the benefits and drawbacks of using a browser to access asynchronous, lightweight processes on the server.Identify the differences between client pull and server push architectures.Identify the benefits of using an EJB container with a web container instead of a web container alone.

Identify appropriate uses for JSP and Servlet technology, and JavaServer Faces in a given Java EE application.Identify the benefits and drawbacks of using URL rewriting and cookies to manage HTTP session state.Select the appropriate use of JPA and JPQL in a given scenario.Identify the benefits and drawbacks of implementing Web Services in the EJB component container.Identify benefits and drawbacks of different persistence technologies such as BMP, CMP, and JPA, including ease of development, performance, scalability, extensibility, and security.Identify the correct EJB technology to apply for a given scenario, including entity classes, session beans, message-driven beans, timers, interceptors, and POJOs.Identify how a Service Oriented Architecture (SOA) facilitates system integration and best practices.Identify and detail the technologies used to integrate business components with external resources, including JMS and JCA.Describe the technologies used to integrate business components with Web Services, including XML over HTTP, JSON, SOAP and REST.Outline the benefits and drawbacks of each approach. Identify the APIs available for a Java EE technology-based system to communicating with external resources, including JPA, JDBC, RMI, Web Services, JMS, and JCA.Identify the challenges in integrating enterprise resources, the Java EE technologies that address them (including JPA and JDBC), and the communication protocols that support tier-to-tier communication (including RMI, IIOP, and CORBA).Identify Java EE technologies, including JMS, JCA and Web Services, and design patterns that address specific challenges in enterprise integration.Identify design patterns that address specific challenges in the web tier, including authentication, authorization, and scaling and clustering to meet demand.Identify best practices for exception handling, logging, and business tier patterns.Identify the appropriate strategy for deploying client applications to desktop and mobile platforms, the principles for designing a user interface and the benefits of applying client-tier patterns.

