© 2002 IBM Corporation Web 2.0 Mashups Project Proposal UCLA CS130, Spring 2007 Alex Rodriguez SWG – Tivoli Chris Montalvo GBS Martin Stenkilde SWG – Rational Gergana Markova SWG – Tivoli
© 2007 IBM Corporation 2 Mashup A hybrid application that combines content from more than one source. Very popular Web 2.0 idea Mash-up (you can use a hyphen if you want)
© 2007 IBM Corporation 3 Why Mash? Mashups are the next logical step in Service Oriented Architecture The real power in Web services comes from combining Web services are typically specialized, mashups are “situational” Development without central authority
© 2007 IBM Corporation 4 Web 2.0 Web 2.0: O’Reilly Media coined the term Web 1.0 vs. 2.0 One-to-many vs. many-to-many publishing Application gets better as publishers make it better vs. application gets better the more people use it No AJAX vs. AJAX
© 2007 IBM Corporation 5 What is a Web service? W3C Web Services Architecture Group “A Web service is a software system designed to support interoperable machine-to-machine interaction over a network. It has an interface described in a machine-processable format (specifically WSDL). Other systems interact with the Web service in a manner prescribed by its description using SOAP messages, typically conveyed using HTTP with an XML serialization in conjunction with other Web-related standards.”
© 2007 IBM Corporation 6 Service Oriented Architecture (SOA) A style of application design focused on how services are described and organized to support dynamic, automated discovery and use. Web services implement the service oriented architecture SOA principles: Reuse Modularity Composability Interoperability
© 2007 IBM Corporation 7 Service Oriented Architecture Roles Service Requester Service Registry Service Provider Find Discover service Publish Advertise service Bind/Invoke Request service
© 2007 IBM Corporation 8 SOAP A W3C Specification An XML format, typically holds information for a Web service method call, or a response Programming language independent SOAP expanded: Services-Oriented Access Protocol Used to be Simple Object Access Protocol
© 2007 IBM Corporation 9 WSDL Web Services Description Language A kind of IDL (Interface Definition Language) An XML format to describe a Web service’s capabilities Describes a service as a set of endpoints operating on messages
© 2007 IBM Corporation 10 XML/Java XML Parsers Parsers help with validation, well-formedness checking, building a DOM, notifying the application of errors Two API Standards: DOM and SAX Xerces2 Data Binding APIs
© 2007 IBM Corporation 11 Axis Apache Extensible Interaction System A SOAP Engine A JAX-RPC run-time system Provides emitter tooling that generates Java classes from WSDL Used to be IBM SOAP4J
© 2007 IBM Corporation 12 JAX-RPC A Sun specification, was JSR 101 Specifies Java APIs for XML-based Remote Procedure Call Remote Procedure Call A mechanism for clients to call procedures from a service over a network Typically used in distributed client/server model Other example of RPC mechanism: RMI
© 2007 IBM Corporation 13 A Very Simple Example The Library Web service Exposes one method: findTitleByAuthor Uses Axis “instant deployment” with a JWS file Generates a Web service client from the Library service WSDL
© 2007 IBM Corporation 14 Service Implementation - Library.jws import java.util.*; public class Library { private LibraryDatastore dataStore; public Library() { DatastoreFactory.getDS(); dataStore = DatastoreFactory.getLibraryDataStore(); } public Collection findTitleByAuthor(String author) {... }
© 2007 IBM Corporation 15 Axis Instant Deployment $tomcat_home/webapps/axis
© 2007 IBM Corporation 16 WSDL2Java Generates
© 2007 IBM Corporation 17 Service Client – LibraryClient.java import java.util.*; import org.library.*; public class LibraryClient { public static void main(String[] args) { try { LibraryService libraryLocator = new LibraryServiceLocator(); Library library = libraryLocator.getLibrary(); Object[] titles = library.findTitleByAuthor(args[0]); for (Object title : titles) { System.out.println(title); } } catch (Exception e) { e.printStackTrace(); }
© 2007 IBM Corporation 18 Suggested Approach Environment setup Service discovery Your Mashup Concept Design / Storyboard Component Level Design Implementation Test Deployment (Go Live)
© 2007 IBM Corporation 19 Web service Providers
© 2007 IBM Corporation 20 Real Mashup Examples Weather_Maps.aspx Weather_Maps.aspx Allows users to search US cities/locations - provides users with information on the city requested Weather Forecasts Wikipedia geo Articles Flickr photos APIs used Flickr GeoNames Yahoo Geocoding Yahoo Maps
© 2007 IBM Corporation 21 Real Mashup Examples The site is not complete, however the concept is interesting This specific site is a map of Corozal Town Belize (Central America). Each attraction on the map is clickable Once clicked the user can see pictures and video of each attraction APIs used Google AdSense Google Maps YouTube
© 2007 IBM Corporation 22 Skills Required Java Programming, nothing fancy Basic web service concepts: SOAP, WSDL Basic web-application concepts: URLs, HTTP, JavaScript, server- side scripting (JSP, PHP, other) Basic XML (syntax, parsing) AJAX (would be nice) CSS (optional)
© 2007 IBM Corporation 23 Gain Experience J2EE Web services SOAP Axis JAX-RPC XML Web UI AJAX
© 2007 IBM Corporation 24 Links and References (1) Documentation / Specifications developerWorks – SOA and Web services SOAP WSDL JAX-RPC SOAP Engine Axis Eclipse
© 2007 IBM Corporation 25 Links and References (2) Web service Providers (WSDL) Google Code Yahoo Developer Network Amazon ECS Flickr Web services YouTube API Microsoft Web services
© 2007 IBM Corporation 26 Questions Questions?