SlideShare a Scribd company logo
JAVAEE MEETS
MATTHIAS WESSENDORF
JBoss by Red Hat
Member Apache Software Foundation
Formerly working at Kaazing and Oracle
Speaker, Author, Blogger:
http://wessendorf.net
Twitter:
@mwessendorf
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
WHAT DOES

MOBILE
  MEAN?
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf
FOR US, BASICALLY:
Modern Smartphones & Tablets
Supporting complex native apps
Access to the “standard” web
MOBILE APPLICATION CLIENT TYPES
Multi-Platform Requirements
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf
MOBILE APPLICATION CLIENT TYPES
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
WHAT DO YOU
    MEAN WITH
HTML5 + REST ?
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf
THE MYTHICAL “HTML5”
W3C Suite of Specifications
   Canvas
   Geolocation
   WebSockets
   SSE (Server-Sent Events)
   CSS3
   WebWorker
   Web Storage
and some JavaScript APIs
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
TAKE A REST...
WITH JAX-RS RESTFUL ENDPOINTS
   Uses HTTP standards
   GET, POST, UPDATE, DELETE, etc...
   Returns XML, JSON content
   Annotate POJO’s for request mapping
   Error handling with Bean Validation
   CDI to tie it all together
REST...
Uses meaningful response codes
      200 OK
      201 Created
      400 Bad Request
      404 Not Found
      409 Conflict
HTML5 <3 REST
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
AEROGEAR’S MOBILE WEB QUICKSTART
        The HTML5 + REST example:
     single page app
     jQuery / jQuery mobile
     JavaEE
        JAX-RS Endpoints
        CDI Beans and Services
     http://html5-aerogear.rhcloud.com/
DEMO
GOING NATIVE




    as hybrid
APACHE CORDOVA
perhaps known as PhoneGap...
APACHE CORDOVA
1.   embedded browser in native app
2.   bridge between browser and native
3.   DEV => writes web app
4.   packages web app with the native code
5.   no device specific compile (of web app)
6.   PLUGINS: between layers!

                     <3
DEMO
BACKBONE.JS
Good structure => Four Abstractions
    Collection
    Model
    Router
    View
Doesn't hide the DOM
    since you are doing web dev....
lightweight, easy to start with
DEMO
VANILLA.JS
Vanilla JS is a fast, lightweight, cross-platform framework for building
              incredible, powerful JavaScript applications.
                           http://vanilla-js.com/


                                  :-)
AGENDA
Mobile: some background
HTML5
JavaEE -> JAX-RS
JavaScript Frameworks
   jQuery Mobile
   Backbone.js
   Your JS Framework...
JBoss' AeroGear Framework
Outlook: AeroGear goes native
EXTEND JAVAEE INTO MOBILE CLIENTS!
AEROGEAR
Open Source Libraries for Mobile Connectivity:
      JBoss community project
      Dedicated to mobile development
         HTML5 and native
      Facilitate all types of mobile
         Mobile Web
         Hybrid
         Native mobile
      Examples, tutorials, & community
AEROGEAR
 current offerings:
AeroGear.js
AeroGear-iOS
AeroGear.jar (Android)

server components:
   aerogear-controller
   aerogear-security
AEROGEAR.JS
      internal usage of jQuery ($.ajax and $.extend)
      Example:
/ cet a epyppln:
 / rae n mt ieie
vrmPpln =ArGa.ieie)
 a  yieie  eoerPpln(;

/ Adacneto/ieojc:
 / d oncinpp bet
mPpln.d(poet";
 yieiead"rjcs)

/ Raigdt fo te'yrjcs cneto:
 / edn aa rm h mpoet' oncin
mPpln.ie[poet'.ed)
 yieiepps'rjcs]ra(;
DEMO
AEROGEAR.JS
   ROADMAP:


WebSocket
Messaging
Data Sync
client side validation
AEROGEAR.NEXT
1.   More transports (e.g. WebSocket)
2.   Data Sync and Push notifications
3.   OData?
4.   More platforms ?

         GROW THE COMMUNITY
THANK YOU
  MATZEW AT REDHAT DOT COM
           Find us:
http://aerogear.org
@AeroGears
IRC: #aerogear
MAILING LIST
   http://aerogear.org/community/
AEROGEAR-IOS
iOS 5 - full ARC support
AFNetworking used for HTTP communication
Example:
DEMO
AEROGEAR-IOS
       ROADMAP:


Core Data support
Data Sync
WebSocket (via SocketRocket)
APN
HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf

More Related Content

PDF
JavaCro'14 - Vaadin web application integration for Enterprise systems – Pete...
PDF
Building Desktop RIAs with PHP, HTML & Javascript in AIR
PDF
JavaCro'14 - Hybrid mobile apps – deploy Java web application on Android to r...
PPTX
Building Mobile Web Apps using ASP.NET MVC, HTML5, & jQuery Mobile
PDF
Rock Your Web Apps with Vaadin: Coding Serbia 2014
PDF
AEM responsive
PDF
Java Edge.2008.Web.Frameworks.Catagorized
PPTX
Backbone.js
JavaCro'14 - Vaadin web application integration for Enterprise systems – Pete...
Building Desktop RIAs with PHP, HTML & Javascript in AIR
JavaCro'14 - Hybrid mobile apps – deploy Java web application on Android to r...
Building Mobile Web Apps using ASP.NET MVC, HTML5, & jQuery Mobile
Rock Your Web Apps with Vaadin: Coding Serbia 2014
AEM responsive
Java Edge.2008.Web.Frameworks.Catagorized
Backbone.js

What's hot (20)

KEY
Intro To webOS
PPTX
Web assembly with PWA
PPT
MarvelSoft SchoolAdmin Dev Framework
PDF
Evaluating and Choosing ZK Framework
KEY
Automating Web Application Deployment
PDF
Cross Platform Mobile Apps with the Ionic Framework
PPTX
Uniface Lectures Webinar - Building Responsive Applications with Uniface: Get...
KEY
Phonegap/Cordova vs Native Application
PDF
Single page applications
PDF
Overview on Mobile Cross Platform Development
PDF
SVQDC 2017 Tecnologías para Microservicios
PDF
HTML5를 활용한 하이브리드 앱개발하기
PPT
Developing Applications for WebOS
PDF
uMobile Preconference Seminar
PDF
Mozilla, Firefox OS and the Open Web
PPTX
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
PDF
JavaCro'14 - Consuming Java EE Backends in Desktop, Web, and Mobile Frontends...
PPTX
Web development presentation
PDF
Cordova: APIs and instruments
PPTX
HTML5 WebWorks
Intro To webOS
Web assembly with PWA
MarvelSoft SchoolAdmin Dev Framework
Evaluating and Choosing ZK Framework
Automating Web Application Deployment
Cross Platform Mobile Apps with the Ionic Framework
Uniface Lectures Webinar - Building Responsive Applications with Uniface: Get...
Phonegap/Cordova vs Native Application
Single page applications
Overview on Mobile Cross Platform Development
SVQDC 2017 Tecnologías para Microservicios
HTML5를 활용한 하이브리드 앱개발하기
Developing Applications for WebOS
uMobile Preconference Seminar
Mozilla, Firefox OS and the Open Web
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
JavaCro'14 - Consuming Java EE Backends in Desktop, Web, and Mobile Frontends...
Web development presentation
Cordova: APIs and instruments
HTML5 WebWorks
Ad

Viewers also liked (20)

PPSX
Emarketing y redes sociales
PPTX
Valoració Post Laura Casaramona
PDF
Diogen magazin printana verzija 2014 2015 new final online
PDF
Canilux - Proyecto Final Workshop Lenguaje Publicitario UIC
PDF
Edurne baines.Vivir Galicia.-IV Curso de Verano Turismo UDC
PDF
Case study-telekom
PDF
guia turistica
PPTX
Mensajes del rey proclamacion inicial
PDF
datos utilrs
PPTX
El mundo de tinieblas
PPTX
Alquila una herramienta en Ferreteria EPA C.A
PDF
Apresentação da Pesquisa do empreendedor de serviços
PDF
Umfrage Social Media Monitoring
DOCX
Sociología de la vida cotidiana. Reflexiones
PPT
Cloud complete
PDF
Cognotecnologia
PPS
Caso de Estudio EasyDrive School of Motoring
PDF
Ccoo -folleto informativo-2016
DOCX
Inteligencia Competitiva en las PYMES
PPTX
Advanced Persistent Threat - Evaluating Effective Responses
Emarketing y redes sociales
Valoració Post Laura Casaramona
Diogen magazin printana verzija 2014 2015 new final online
Canilux - Proyecto Final Workshop Lenguaje Publicitario UIC
Edurne baines.Vivir Galicia.-IV Curso de Verano Turismo UDC
Case study-telekom
guia turistica
Mensajes del rey proclamacion inicial
datos utilrs
El mundo de tinieblas
Alquila una herramienta en Ferreteria EPA C.A
Apresentação da Pesquisa do empreendedor de serviços
Umfrage Social Media Monitoring
Sociología de la vida cotidiana. Reflexiones
Cloud complete
Cognotecnologia
Caso de Estudio EasyDrive School of Motoring
Ccoo -folleto informativo-2016
Inteligencia Competitiva en las PYMES
Advanced Persistent Threat - Evaluating Effective Responses
Ad

Similar to HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf (20)

PPTX
Apache Cordova In Action
PPTX
[JavaLand 2015] Developing JavaScript Mobile Apps Using Apache Cordova
PDF
Developing Native Mobile Apps Using JavaScript, ApacheCon NA 2014
PPTX
Android App Development using HTML5 Technology
PPTX
[JMaghreb 2014] Developing JavaScript Mobile Apps Using Apache Cordova
PPT
Phonegap android
PDF
Meteoro de pegasuus! Desenvolvendo aplicações realtime com MeteorJS
PPTX
[Devoxx Morocco 2015] Apache Cordova In Action
PDF
Wso2 product release webinar introducing jaggery
PPT
Developing Java Web Applications
PDF
Building Rich Applications with Appcelerator
PPTX
Angularjs Tutorial for Beginners
PDF
Web app and more
PDF
Web Apps and more
PDF
Deview 2013 mobile browser internals and trends_20131022
PDF
WSO2Con Asia 2014 - WSO2 AppDev Platform for the Connected Business
PDF
WSO2 AppDev platform
PDF
Seven Versions of One Web Application
PDF
Past, present, and future of web assembly - Devfest Nantes 2017
PPTX
JavaFX Versus HTML5 - JavaOne 2014
Apache Cordova In Action
[JavaLand 2015] Developing JavaScript Mobile Apps Using Apache Cordova
Developing Native Mobile Apps Using JavaScript, ApacheCon NA 2014
Android App Development using HTML5 Technology
[JMaghreb 2014] Developing JavaScript Mobile Apps Using Apache Cordova
Phonegap android
Meteoro de pegasuus! Desenvolvendo aplicações realtime com MeteorJS
[Devoxx Morocco 2015] Apache Cordova In Action
Wso2 product release webinar introducing jaggery
Developing Java Web Applications
Building Rich Applications with Appcelerator
Angularjs Tutorial for Beginners
Web app and more
Web Apps and more
Deview 2013 mobile browser internals and trends_20131022
WSO2Con Asia 2014 - WSO2 AppDev Platform for the Connected Business
WSO2 AppDev platform
Seven Versions of One Web Application
Past, present, and future of web assembly - Devfest Nantes 2017
JavaFX Versus HTML5 - JavaOne 2014

More from JAX London (20)

PDF
Everything I know about software in spaghetti bolognese: managing complexity
PDF
Devops with the S for Sharing - Patrick Debois
PPT
Busy Developer's Guide to Windows 8 HTML/JavaScript Apps
PDF
It's code but not as we know: Infrastructure as Code - Patrick Debois
KEY
Locks? We Don't Need No Stinkin' Locks - Michael Barker
PDF
Worse is better, for better or for worse - Kevlin Henney
PDF
Java performance: What's the big deal? - Trisha Gee
PDF
Clojure made-simple - John Stevenson
PDF
Play framework 2 : Peter Hilton
PDF
Complexity theory and software development : Tim Berglund
PDF
Why FLOSS is a Java developer's best friend: Dave Gruber
PDF
Akka in Action: Heiko Seeburger
PDF
NoSQL Smackdown 2012 : Tim Berglund
PDF
Closures, the next "Big Thing" in Java: Russel Winder
KEY
Java and the machine - Martijn Verburg and Kirk Pepperdine
PDF
Mongo DB on the JVM - Brendan McAdams
PDF
New opportunities for connected data - Ian Robinson
PDF
HTML5 Websockets and Java - Arun Gupta
PDF
The Big Data Con: Why Big Data is a Problem, not a Solution - Ian Plosker
KEY
Bluffers guide to elitist jargon - Martijn Verburg, Richard Warburton, James ...
Everything I know about software in spaghetti bolognese: managing complexity
Devops with the S for Sharing - Patrick Debois
Busy Developer's Guide to Windows 8 HTML/JavaScript Apps
It's code but not as we know: Infrastructure as Code - Patrick Debois
Locks? We Don't Need No Stinkin' Locks - Michael Barker
Worse is better, for better or for worse - Kevlin Henney
Java performance: What's the big deal? - Trisha Gee
Clojure made-simple - John Stevenson
Play framework 2 : Peter Hilton
Complexity theory and software development : Tim Berglund
Why FLOSS is a Java developer's best friend: Dave Gruber
Akka in Action: Heiko Seeburger
NoSQL Smackdown 2012 : Tim Berglund
Closures, the next "Big Thing" in Java: Russel Winder
Java and the machine - Martijn Verburg and Kirk Pepperdine
Mongo DB on the JVM - Brendan McAdams
New opportunities for connected data - Ian Robinson
HTML5 Websockets and Java - Arun Gupta
The Big Data Con: Why Big Data is a Problem, not a Solution - Ian Plosker
Bluffers guide to elitist jargon - Martijn Verburg, Richard Warburton, James ...

Recently uploaded (20)

PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PDF
Approach and Philosophy of On baking technology
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
cuic standard and advanced reporting.pdf
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PPTX
Cloud computing and distributed systems.
PPTX
A Presentation on Artificial Intelligence
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Modernizing your data center with Dell and AMD
Reach Out and Touch Someone: Haptics and Empathic Computing
Dropbox Q2 2025 Financial Results & Investor Presentation
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Diabetes mellitus diagnosis method based random forest with bat algorithm
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
20250228 LYD VKU AI Blended-Learning.pptx
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
Approach and Philosophy of On baking technology
The AUB Centre for AI in Media Proposal.docx
CIFDAQ's Market Insight: SEC Turns Pro Crypto
cuic standard and advanced reporting.pdf
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
Cloud computing and distributed systems.
A Presentation on Artificial Intelligence
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Per capita expenditure prediction using model stacking based on satellite ima...
Network Security Unit 5.pdf for BCA BBA.
Modernizing your data center with Dell and AMD

HTML alchemy: the secrets of mixing JavaScript and Java EE - Matthias Wessendorf