SlideShare a Scribd company logo
WCF & ASP.NET Web API – An
Architect’s Primer
 Presented at Southern California .NET Architecture User
  Group; Feb 21st 2013.




Adnan Masood MS (CS). MCSD. MCPD.
Software Architect & Doctoral Candidate
blog.AdnanMasood.com
adnan.masood@owasp.org
About Me
Adnan Masood works as a system architect / technical lead for Green dot
Corporation where he develops SOA based middle-tier
architectures, distributed systems, and web-applications using
Microsoft technologies. He is a Microsoft Certified Trainer holding several
technical certifications, including MCPD (Enterprise Developer), MCSD
.NET, and SCJP-II. Adnan is attributed and published in print media and
on the Web; he also teaches Windows Communication Foundation (WCF)
courses at the University of California at San Diego and regularly presents
at local code camps and user groups. He is actively involved in the .NET
community as cofounder and president of the of San Gabriel Valley .NET
Developers group.

Adnan holds a Master’s degree in Computer Science; he is currently a
doctoral student working towards PhD in Machine Learning; specifically
discovering interestingness measures in outliers using Bayesian Belief
Networks. He also holds systems architecture certification from MIT and
SOA Smarts certification from Carnegie Melon University.
Abstract
WCF vs. ASP.NET Web API – An Architect’s Primer

ASP.NET Web API is a framework that makes it easy to build HTTP services that reach a
broad range of clients, including browsers and mobile devices. The new ASP.NET Web
API is a continuation of the previous WCF Web API projection. WCF was originally
created to enable SOAP-based services and other related bindings. However, for simpler
RESTful or RPCish services (think clients like jQuery) ASP.NET Web API is a good
choice.

In this meeting we discuss what do you need to understand as an architect to implement
your service oriented architecture using WCF or ASP.NET web API. With code
samples, we will elaborate on WCF Web API’s transition to ASP.NET Web API and
respective constructs such as Service vs. Web API controller, Operation vs. Action, URI
templates vs ASP.NET Routing, Message handlers, Formatters and Operation handlers vs
Filters, model binders. WebApi offers support for modern HTTP programming model with
full support for ASP.NET Routing, content negotiation and custom formatters, model
binding and validation, filters, query composition, is easy to unit test and offers improved
Inversion of Control (IoC) via DependencyResolver.
Agenda
 Difference between Web API and WCF REST Services
 How to Migrate from WCF Web API to ASP.NET Web API
 Model for RESTFul Maturity
 WCF or Web API – confusing?
 WCF evolution and strengths
 What ASP.NET Web API brings to the table?
 Architectures and comparing non functional requirements
Architectural Questions
 What is the purpose of the WebAPIs?
 Why do we need REST HTTP services? What’s wrong with
  SOAP-over-HTTP?
 Why did the WebAPIs move from WCF to ASP.NET MVC?
 Is there still a use for WCF? When should I choose Web APIs
  over WCF?
History of Web Services
  1989 - Tim Berners-Lee invents HTTP/HTML
  1998 - XML 1.0, SOAP begins ratification
  2001 - SOAP standard
  2000 - Fielding dissertation on REST
History of SOAP
Before SOAP we did this…
  HTTP GET/POST with Plain Old XML (POX)
  Out-of-band exchange of DTD or schema
SOAP evolved to provide us
  Specifications
  Tooling
  Metadata
  Productivity
  location transparency
Tools Evolution
 ASP.NET Web Services (ASMX)
 Web Services Enhancements (WSE)
 •.NET 3.0 => WCF = SOAP+WS*
 •.NET 3.5 => WCF = SOAP+WS*/ HTTP
 WebHttpBinding, contract attributes, JSON
 •REST Starter Kit (Codeplex)
 •WCF 4 => Features from starter kit
 •WCF Web API => ASP.NET Web API
Web API or WCF - An Architectural Comparison
Web API or WCF - An Architectural Comparison
SignalR
 What is ASP.NET SignalR
 ASP.NET SignalR is a new library for ASP.NET developers that makes it
  incredibly simple to add real-time web functionality to your applications.
  What is "real-time web" functionality? It's the ability to have your server-
  side code push content to the connected clients as it happens, in real-
  time.
 You may have heard of WebSockets, a new HTML5 API that enables bi-
  directional communication between the browser and server. SignalR will
  use WebSockets under the covers when it's available, and gracefully
  fallback to other techniques and technologies when it isn't, while your
  application code stays the same.
 SignalR also provides a very simple, high-level API for doing server to
  client RPC (call JavaScript functions in your clients' browsers from
  server-side .NET code) in your ASP.NET application, as well as adding
  useful hooks for connection management, e.g. connect/disconnect
  events, grouping connections, authorization.
The WCF Web API => ASP.NET
Web API
 WCF Web API -> ASP.NET Web API
 Service -> Web API controller
 Operation -> Action
 Service contract -> Not applicable
 Endpoint -> Not applicable
 URI templates -> ASP.NET Routing
 Message handlers -> Same
 Formatters -> Same
 Operation handlers -> Filters, model binders
Integrated stack
 Modern HTTP programming model
 Full support for ASP.NET Routing
 Content negotiation and custom formatters
 Model binding and validation
 Filters
 Query composition
 Easy to unit test
 Improved Inversion of Control (IoC) via DependencyResolver
 Code-based configuration
 Self-host
Web API or WCF - An Architectural Comparison
SOAP
 Simple Object Access Protocol
 Uses a standard XML Schema over HTTP
 Extremely cross platform compatible
 Extremely Slow
REST
 Representable State Transfer
 Uses standard HTTP
 Can use any text format including XML
XML vs JSON
  XML tag based document formatting
  Javascript Notation by Douglas Crockford
  JSON less verbose than XML, more lightweight
  Mobile devices have limited bandwidth
Public APIs
  Twitter
  Facebook
  Flickr
  Amazon
  iTunes
WebAPI
  Available now as Nuget Package
  Built-in as part of MVC 4
  Take advantage of HTTP features directly
Default route will use http method for action
  Controller/action/id
  API/Controller/id GET/POST/PUT/DELETE




HTTP methods as Actions
HTTP Method meanings
  Get - Return an existing document
  Post - Create a new document
  Put - Update a document
  Delete - Self explanatory
Configure Transport
  Set Xml or JSON based on Content-Type or Accept
  header
  Accept: application/xml
  Can also use Odata
Return Codes
  Now have the ability to specify return codes beside 200
  HttpResponseMessage<YourEntity>
  HttpStatusCode.Created 201
  response.Headers.Location = new Uri()
Http Status codes
  201 Created
  200 Success/204 Success but No Content
  403 Not authorized
  404 Does not exist
  500 Server Error
  301 Uri Moved
Security
  [Authorize()]
  https over port 443
  Security Tokens
  OAuth
Testing WebAPI
  Download Fiddler2
  Firebug (Firefox)
  Chrome
  On Mac use CocoaRestClient
Consuming WebAPI
  Web Apps
  (ASP.NET, MVC, PHP, Java, ColdFusion, Ruby(Rails), Pyt
  hon, Perl(if you are masochistic))
  JavaScript/JQuery
  Mobile (iOS, Android, WP7, Blackberry OS)
Develop WebAPI and iOS on
Same Computer
  Parallels or VMWare
  Set Network Adapter to Bridged
  Run Visual Studio as Administrator
  Host on IIS (do not use IIS Express or Casini)
Consuming WebAPI
in iOS
  Use NSURLConnection delegate or GCD
  Show progress while waiting on response
  Use JSON over XML
  NSJSONSerialization class (new in iOS 5)
XML Parsing in iOS
  NSXMLParser (Slowest)
  libxml2 (C api)
  TBXML (DOM, Fastest, no write or xpath)
  TouchXML (DOM supports xpath, no write)
  KissXML (based on Touch, can write)
  GDataXML (DOM, from Google)
  RaptureXML (DOM, supports xpath)
Create DefaultHttpClient();
    Create request with HttpGet(Url);
    Create response handler BasicResponseHandler();
    httpClient.execute(request, handler);




Call WebAPI from Android
JSON in Android
  use the JSONObject to parse
  JSONObject jo = new JSONObject(jString);
  jo.getJSONObject(“car”);
  jo.getJSONArray(“cars”);
XML Parsing in Android
  DOM, SAX and Pull
  W3C Dom parser
  Standard Java Sax Parser
  SJXP (Pull parser)
WebAPI as persistence
  Don’t use WebAPI as default persistence on Mobile
  Both Android and iOS have device persistence
  local storage, CoreData and SQLite
  iCloud to sync between iOS devices
Demo




       Slides courtesy Michelle L. Bustamante
Comparison

 Transport Coupling
   HTTP is an application protocol, not just a transport protocol
   TCP, named pipes, MSMQ, UDP are transport only
   WCF is decoupled, message can traverse any
 Performance
   Sometimes a faster protocol/serialization mechanism is needed




                                                   Slides courtesy Michelle L. Bustamante
Security
 Web API
     HTTP Services
     HTTPS / SSL
     Authorization header or custom headers
     OAuth 2.0
 WCF Services
     HTTPS / SSL
     SOAP Message Security
     WS-Trust
     OAuth 2.0

                                               Slides courtesy Michelle L. Bustamante
Error Handling
 Mostly automatic
 Helpful to control how things are returned to Ajax clients
 Setting status code and message




                                                 Slides courtesy Michelle L. Bustamante
Hosting
 IIS or Self hosting




                        Slides courtesy Michelle L. Bustamante
Feature Comparison
 Productivity
     Design effort
     Complexity
     Client code and proxy generation
     Communication stack
 State
   Both should be stateless
   Caching
   Built in to HTTP, but beware
The WS* Overload




                   Slides courtesy Michelle L. Bustamante
SOAP vs REST – Focus on the
necessities




                      Slide courtesy Michelle L. Bustamante
Web API Selling Points
 If we need a Web Service and don’t need SOAP, then ASP.Net
  Web API is very useful.
 Web API - Used to build simple, non-SOAP-based HTTP Services
  on top of existing WCF message pipeline.
 Web API - No need for configurable like WCF REST services
 Web API - No need for Data contracts
 Web API - Could create fully blown REST Services
 Simple service creation with Web API. With WCF REST
  Services, service creation is difficult.
 WCF is any wire protocol. Web API is focused at one thing, being
  easy to define and expose and consume, while also facilitating
  doing things in a RESTful way.
 Web API is light weight architecture.
Web API or WCF - An Architectural Comparison
The hypermedia Venn Diagram
The unified model? Kinda, sorta
Obsolete
Revision - WCF to ASP.NET Web
API
   ApiController (!=Controller, no common BaseClass)
   ASP.NET Routing (MapHttpRoute)
   Convention over Configuration
   Web API to go / NuGet Packages
   Web API hosted in ASP.NET: AspNetWebApi
   Self-hosted Web API: AspNetWebApi.Selfhost
   HttpClient including XML and JSON formatters:
   System.Net.Http.Formatting
     JsonValue for navigating and manipulating JSON:
 System.Json
 Go Live License
How to Migrate from WCF Web
API to ASP.NET Web API
 http://wcf.codeplex.com/wikipage?title=How%20to%20Migrate
  %20from%20WCF%20Web%20API%20to%20ASP.NET%20
  Web%20API
Competing with Node.JS?
Resources & Credits
   http://www.asp.net/web-api
   http://blogs.msdn.com/b/henrikn/
    http://weblogs.asp.net/scottgu/archive/tags/Web+API/defa
   ult.aspx
    http://stackoverflow.com/questions/tagged/asp.net-web-api
    https://github.com/ChristianWeyer/Thinktecture.Web.Http
    http://blog.alexonasp.net
    http://aspnet.uservoice.com/forums/147201-webapi/suggestions/2618312-allow-for-
    non-asynchronouscalls-to-the-web-api
   Thanks to Michele Leroux Bustamante’s slide-deck from Windows Azure
    connections, March 26-29, 2012 Las Vegas, NV which I thoroughly enjoyed.
   Ida Flatow’s article on web API http://www.codeproject.com/Articles/341414/WCF-or-
    ASP-NET-Web-APIs-My-two-cents-on-the-subjec
   Alexander Zeitler’s Web API Round up
   David Fekke Web API - www.fekke.com/Media/Default/powerpoint/webapi.ppt
Summary
 Choose wisely and quantitatively; avoiding the shiny object
  syndrome.
 Enterprise WCF implementations will continue to be
  important…
 The trend to HTTP services is here to stay, embrace it
 If you are starting from scratch for a mobile / web heavy
  service, look at HTTP services first
Thank You!
 Adnan Masood
 adnan.masood@owasp.org
   @adnanmasood
  Blog: www.AdnanMasood.com
  Pasadena .NET User Group: www.sgvdotnet.org

More Related Content

PDF
OSSで出来るインシデント管理とサービス資産管理及び構成管理の自動化
PPT
Βασικές έννοιες προγραμματισμού
PPTX
失敗から学ぶAWSの監視
PPT
β λυκ μάθ 28 αφρικανικά θρησκεύματα
PPTX
25.η εκκλησιαστικη τεχνη στη δυση
PPTX
Η ΚΙΝΕΖΙΚΗ ΘΡΗΣΚΕΙΑ
PPTX
παραβολη του ασωτου
PDF
PureLogics Company Profile
OSSで出来るインシデント管理とサービス資産管理及び構成管理の自動化
Βασικές έννοιες προγραμματισμού
失敗から学ぶAWSの監視
β λυκ μάθ 28 αφρικανικά θρησκεύματα
25.η εκκλησιαστικη τεχνη στη δυση
Η ΚΙΝΕΖΙΚΗ ΘΡΗΣΚΕΙΑ
παραβολη του ασωτου
PureLogics Company Profile

What's hot (20)

PDF
Rails SQL Injection Examplesの紹介
PDF
Tradotto- Carta di Erice
PPTX
Περιήγηση στην πόλη των Σερρών: Μία Εφαρμογή στο AppInventor
PPT
ιαπωνικα θρησκευματα
PPT
Tεχνικές διδασκαλίας στα θρησκευτικά
PDF
Τα κτίσματα του Ιουστινιανού
PPT
Εισαγωγή στις αρχές της επιστήμης των ΗΥ κεφ 2 3 2
PPSX
2.2.1 - ΟΡΙΣΜΟΣ ΑΛΓΟΡΙΘΜΟΥ
PPSX
2.2.6 ΑΝΑΠΑΡΑΣΤΑΣΗ ΔΕΔΟΜΕΝΩΝ
PDF
εισαγωγή βιολογίας
PDF
EC-CUBEによるECサイトの負荷対策
PPTX
Agia Sofia
PDF
Η ΙΣΤΟΡΙΑ ΤΗΣ ΕΚΚΛΗΣΙΑΣ ΚΑΙ Η ΜΕΛΕΤΗ ΤΗΣ
PPTX
Διατροφή στις 4 μεγάλες θρησκείες
PDF
[最新バージョンの情報がDescription欄にございます]AWS Black Belt Online Seminar 2018 Amazon Connect
PDF
202202 AWS Black Belt Online Seminar AWS SaaS Boost で始めるSaaS開発⼊⾨
PPTX
Accenture and Workday: Look to the Cloud for your Global Payroll Strategy
PDF
Ansible AWXで一歩進んだプロビジョニング
PPTX
21.Εκκλησιαστικη Τεχνη Β΄- Μόνικα Κωνσταντίνου Γ΄3 ΝΙΚΟΛΑΪΔΕΙΟ Γ. ΠΑΦΟΥ
Rails SQL Injection Examplesの紹介
Tradotto- Carta di Erice
Περιήγηση στην πόλη των Σερρών: Μία Εφαρμογή στο AppInventor
ιαπωνικα θρησκευματα
Tεχνικές διδασκαλίας στα θρησκευτικά
Τα κτίσματα του Ιουστινιανού
Εισαγωγή στις αρχές της επιστήμης των ΗΥ κεφ 2 3 2
2.2.1 - ΟΡΙΣΜΟΣ ΑΛΓΟΡΙΘΜΟΥ
2.2.6 ΑΝΑΠΑΡΑΣΤΑΣΗ ΔΕΔΟΜΕΝΩΝ
εισαγωγή βιολογίας
EC-CUBEによるECサイトの負荷対策
Agia Sofia
Η ΙΣΤΟΡΙΑ ΤΗΣ ΕΚΚΛΗΣΙΑΣ ΚΑΙ Η ΜΕΛΕΤΗ ΤΗΣ
Διατροφή στις 4 μεγάλες θρησκείες
[最新バージョンの情報がDescription欄にございます]AWS Black Belt Online Seminar 2018 Amazon Connect
202202 AWS Black Belt Online Seminar AWS SaaS Boost で始めるSaaS開発⼊⾨
Accenture and Workday: Look to the Cloud for your Global Payroll Strategy
Ansible AWXで一歩進んだプロビジョニング
21.Εκκλησιαστικη Τεχνη Β΄- Μόνικα Κωνσταντίνου Γ΄3 ΝΙΚΟΛΑΪΔΕΙΟ Γ. ΠΑΦΟΥ
Ad

Viewers also liked (20)

PPTX
ASP.NET Mvc 4 web api
DOC
WCF tutorial
PDF
Windows Communication Foundation (WCF)
PDF
C# ASP.NET WEB API APPLICATION DEVELOPMENT
PPTX
Windows Communication Foundation (WCF)
PPTX
The Full Power of ASP.NET Web API
PPTX
The ASP.NET Web API for Beginners
PPTX
WCF Fundamentals
PPTX
Windows Communication Foundation (WCF) Best Practices
PPTX
Overview of Rest Service and ASP.NET WEB API
PPTX
ASP.NET WEB API
PPTX
ASP.NET Web API
PPTX
ASP.NET Web API and HTTP Fundamentals
PPT
PPTX
Introduction to ServiceStack
PDF
Resource-Oriented Web Services
PPTX
Mysql gdb-101022041146-phpapp01
PPT
Wcf security session 2
PPT
Web 2.0 Trabajo Practico
PDF
Denis Venter-111512819 - Blogging Week 1
ASP.NET Mvc 4 web api
WCF tutorial
Windows Communication Foundation (WCF)
C# ASP.NET WEB API APPLICATION DEVELOPMENT
Windows Communication Foundation (WCF)
The Full Power of ASP.NET Web API
The ASP.NET Web API for Beginners
WCF Fundamentals
Windows Communication Foundation (WCF) Best Practices
Overview of Rest Service and ASP.NET WEB API
ASP.NET WEB API
ASP.NET Web API
ASP.NET Web API and HTTP Fundamentals
Introduction to ServiceStack
Resource-Oriented Web Services
Mysql gdb-101022041146-phpapp01
Wcf security session 2
Web 2.0 Trabajo Practico
Denis Venter-111512819 - Blogging Week 1
Ad

Similar to Web API or WCF - An Architectural Comparison (20)

PPT
A Microsoft primer for PHP devs
PPT
Scalable Web Architectures and Infrastructure
PPT
.Net3.5 Overview
PPT
sMash_for_zOS-users
PPTX
ASP.NET Presentation
PPT
Net35 Overview
PPTX
Windows Azure AppFabric
PDF
ASP.NET Web API Interview Questions By Scholarhat
PPSX
Web development concepts using microsoft technologies
PPTX
Xml web services
PDF
Getting Started with ASP.NET Core 1.0 (formerly ASP.NET 5)
PPTX
Best of Microsoft Dev Camp 2015
PPTX
Owin & katana
PPTX
Vijay Oscon
PDF
ASP.NET Core Interview Questions PDF By ScholarHat.pdf
PPT
DevNext - Web Programming Concepts Using Asp Net
PPT
Enterprise Software Architecture
PPTX
2014 q3-platform-update-v1.06.johnmathon
PPTX
Running PHP In The Cloud
PPTX
Windows Azure
A Microsoft primer for PHP devs
Scalable Web Architectures and Infrastructure
.Net3.5 Overview
sMash_for_zOS-users
ASP.NET Presentation
Net35 Overview
Windows Azure AppFabric
ASP.NET Web API Interview Questions By Scholarhat
Web development concepts using microsoft technologies
Xml web services
Getting Started with ASP.NET Core 1.0 (formerly ASP.NET 5)
Best of Microsoft Dev Camp 2015
Owin & katana
Vijay Oscon
ASP.NET Core Interview Questions PDF By ScholarHat.pdf
DevNext - Web Programming Concepts Using Asp Net
Enterprise Software Architecture
2014 q3-platform-update-v1.06.johnmathon
Running PHP In The Cloud
Windows Azure

More from Adnan Masood (11)

PPTX
Spark with Azure HDInsight - Tampa Bay Data Science - Adnan Masood, PhD
PPTX
Data science with Windows Azure - A Brief Introduction
PPTX
Restructuring Technical Debt - A Software and System Quality Approach
PPTX
System Quality Attributes for Software Architecture
PDF
Agile Software Development
PPTX
Belief Networks & Bayesian Classification
PPTX
Bayesian Networks and Association Analysis
PPTX
Probabilistic Interestingness Measures - An Introduction with Bayesian Belief...
PDF
Bayesian Networks - A Brief Introduction
PPTX
SOLID Principles of Refactoring Presentation - Inland Empire User Group
PDF
Brief bibliography of interestingness measure, bayesian belief network and ca...
Spark with Azure HDInsight - Tampa Bay Data Science - Adnan Masood, PhD
Data science with Windows Azure - A Brief Introduction
Restructuring Technical Debt - A Software and System Quality Approach
System Quality Attributes for Software Architecture
Agile Software Development
Belief Networks & Bayesian Classification
Bayesian Networks and Association Analysis
Probabilistic Interestingness Measures - An Introduction with Bayesian Belief...
Bayesian Networks - A Brief Introduction
SOLID Principles of Refactoring Presentation - Inland Empire User Group
Brief bibliography of interestingness measure, bayesian belief network and ca...

Recently uploaded (20)

PDF
Approach and Philosophy of On baking technology
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
KodekX | Application Modernization Development
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Review of recent advances in non-invasive hemoglobin estimation
PPTX
Programs and apps: productivity, graphics, security and other tools
PPTX
Cloud computing and distributed systems.
PDF
cuic standard and advanced reporting.pdf
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
Approach and Philosophy of On baking technology
Agricultural_Statistics_at_a_Glance_2022_0.pdf
KodekX | Application Modernization Development
NewMind AI Weekly Chronicles - August'25 Week I
Reach Out and Touch Someone: Haptics and Empathic Computing
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
20250228 LYD VKU AI Blended-Learning.pptx
Review of recent advances in non-invasive hemoglobin estimation
Programs and apps: productivity, graphics, security and other tools
Cloud computing and distributed systems.
cuic standard and advanced reporting.pdf
Advanced methodologies resolving dimensionality complications for autism neur...
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Dropbox Q2 2025 Financial Results & Investor Presentation
Per capita expenditure prediction using model stacking based on satellite ima...
Building Integrated photovoltaic BIPV_UPV.pdf

Web API or WCF - An Architectural Comparison

  • 1. WCF & ASP.NET Web API – An Architect’s Primer  Presented at Southern California .NET Architecture User Group; Feb 21st 2013. Adnan Masood MS (CS). MCSD. MCPD. Software Architect & Doctoral Candidate blog.AdnanMasood.com [email protected]
  • 2. About Me Adnan Masood works as a system architect / technical lead for Green dot Corporation where he develops SOA based middle-tier architectures, distributed systems, and web-applications using Microsoft technologies. He is a Microsoft Certified Trainer holding several technical certifications, including MCPD (Enterprise Developer), MCSD .NET, and SCJP-II. Adnan is attributed and published in print media and on the Web; he also teaches Windows Communication Foundation (WCF) courses at the University of California at San Diego and regularly presents at local code camps and user groups. He is actively involved in the .NET community as cofounder and president of the of San Gabriel Valley .NET Developers group. Adnan holds a Master’s degree in Computer Science; he is currently a doctoral student working towards PhD in Machine Learning; specifically discovering interestingness measures in outliers using Bayesian Belief Networks. He also holds systems architecture certification from MIT and SOA Smarts certification from Carnegie Melon University.
  • 3. Abstract WCF vs. ASP.NET Web API – An Architect’s Primer ASP.NET Web API is a framework that makes it easy to build HTTP services that reach a broad range of clients, including browsers and mobile devices. The new ASP.NET Web API is a continuation of the previous WCF Web API projection. WCF was originally created to enable SOAP-based services and other related bindings. However, for simpler RESTful or RPCish services (think clients like jQuery) ASP.NET Web API is a good choice. In this meeting we discuss what do you need to understand as an architect to implement your service oriented architecture using WCF or ASP.NET web API. With code samples, we will elaborate on WCF Web API’s transition to ASP.NET Web API and respective constructs such as Service vs. Web API controller, Operation vs. Action, URI templates vs ASP.NET Routing, Message handlers, Formatters and Operation handlers vs Filters, model binders. WebApi offers support for modern HTTP programming model with full support for ASP.NET Routing, content negotiation and custom formatters, model binding and validation, filters, query composition, is easy to unit test and offers improved Inversion of Control (IoC) via DependencyResolver.
  • 4. Agenda  Difference between Web API and WCF REST Services  How to Migrate from WCF Web API to ASP.NET Web API  Model for RESTFul Maturity  WCF or Web API – confusing?  WCF evolution and strengths  What ASP.NET Web API brings to the table?  Architectures and comparing non functional requirements
  • 5. Architectural Questions  What is the purpose of the WebAPIs?  Why do we need REST HTTP services? What’s wrong with SOAP-over-HTTP?  Why did the WebAPIs move from WCF to ASP.NET MVC?  Is there still a use for WCF? When should I choose Web APIs over WCF?
  • 6. History of Web Services 1989 - Tim Berners-Lee invents HTTP/HTML 1998 - XML 1.0, SOAP begins ratification 2001 - SOAP standard 2000 - Fielding dissertation on REST
  • 7. History of SOAP Before SOAP we did this…  HTTP GET/POST with Plain Old XML (POX)  Out-of-band exchange of DTD or schema SOAP evolved to provide us  Specifications  Tooling  Metadata  Productivity  location transparency
  • 8. Tools Evolution  ASP.NET Web Services (ASMX)  Web Services Enhancements (WSE)  •.NET 3.0 => WCF = SOAP+WS*  •.NET 3.5 => WCF = SOAP+WS*/ HTTP  WebHttpBinding, contract attributes, JSON  •REST Starter Kit (Codeplex)  •WCF 4 => Features from starter kit  •WCF Web API => ASP.NET Web API
  • 11. SignalR  What is ASP.NET SignalR  ASP.NET SignalR is a new library for ASP.NET developers that makes it incredibly simple to add real-time web functionality to your applications. What is "real-time web" functionality? It's the ability to have your server- side code push content to the connected clients as it happens, in real- time.  You may have heard of WebSockets, a new HTML5 API that enables bi- directional communication between the browser and server. SignalR will use WebSockets under the covers when it's available, and gracefully fallback to other techniques and technologies when it isn't, while your application code stays the same.  SignalR also provides a very simple, high-level API for doing server to client RPC (call JavaScript functions in your clients' browsers from server-side .NET code) in your ASP.NET application, as well as adding useful hooks for connection management, e.g. connect/disconnect events, grouping connections, authorization.
  • 12. The WCF Web API => ASP.NET Web API  WCF Web API -> ASP.NET Web API  Service -> Web API controller  Operation -> Action  Service contract -> Not applicable  Endpoint -> Not applicable  URI templates -> ASP.NET Routing  Message handlers -> Same  Formatters -> Same  Operation handlers -> Filters, model binders
  • 13. Integrated stack  Modern HTTP programming model  Full support for ASP.NET Routing  Content negotiation and custom formatters  Model binding and validation  Filters  Query composition  Easy to unit test  Improved Inversion of Control (IoC) via DependencyResolver  Code-based configuration  Self-host
  • 15. SOAP Simple Object Access Protocol Uses a standard XML Schema over HTTP Extremely cross platform compatible Extremely Slow
  • 16. REST Representable State Transfer Uses standard HTTP Can use any text format including XML
  • 17. XML vs JSON XML tag based document formatting Javascript Notation by Douglas Crockford JSON less verbose than XML, more lightweight Mobile devices have limited bandwidth
  • 18. Public APIs Twitter Facebook Flickr Amazon iTunes
  • 19. WebAPI Available now as Nuget Package Built-in as part of MVC 4 Take advantage of HTTP features directly
  • 20. Default route will use http method for action Controller/action/id API/Controller/id GET/POST/PUT/DELETE HTTP methods as Actions
  • 21. HTTP Method meanings Get - Return an existing document Post - Create a new document Put - Update a document Delete - Self explanatory
  • 22. Configure Transport Set Xml or JSON based on Content-Type or Accept header Accept: application/xml Can also use Odata
  • 23. Return Codes Now have the ability to specify return codes beside 200 HttpResponseMessage<YourEntity> HttpStatusCode.Created 201 response.Headers.Location = new Uri()
  • 24. Http Status codes 201 Created 200 Success/204 Success but No Content 403 Not authorized 404 Does not exist 500 Server Error 301 Uri Moved
  • 25. Security [Authorize()] https over port 443 Security Tokens OAuth
  • 26. Testing WebAPI Download Fiddler2 Firebug (Firefox) Chrome On Mac use CocoaRestClient
  • 27. Consuming WebAPI Web Apps (ASP.NET, MVC, PHP, Java, ColdFusion, Ruby(Rails), Pyt hon, Perl(if you are masochistic)) JavaScript/JQuery Mobile (iOS, Android, WP7, Blackberry OS)
  • 28. Develop WebAPI and iOS on Same Computer Parallels or VMWare Set Network Adapter to Bridged Run Visual Studio as Administrator Host on IIS (do not use IIS Express or Casini)
  • 29. Consuming WebAPI in iOS Use NSURLConnection delegate or GCD Show progress while waiting on response Use JSON over XML NSJSONSerialization class (new in iOS 5)
  • 30. XML Parsing in iOS NSXMLParser (Slowest) libxml2 (C api) TBXML (DOM, Fastest, no write or xpath) TouchXML (DOM supports xpath, no write) KissXML (based on Touch, can write) GDataXML (DOM, from Google) RaptureXML (DOM, supports xpath)
  • 31. Create DefaultHttpClient(); Create request with HttpGet(Url); Create response handler BasicResponseHandler(); httpClient.execute(request, handler); Call WebAPI from Android
  • 32. JSON in Android use the JSONObject to parse JSONObject jo = new JSONObject(jString); jo.getJSONObject(“car”); jo.getJSONArray(“cars”);
  • 33. XML Parsing in Android DOM, SAX and Pull W3C Dom parser Standard Java Sax Parser SJXP (Pull parser)
  • 34. WebAPI as persistence Don’t use WebAPI as default persistence on Mobile Both Android and iOS have device persistence local storage, CoreData and SQLite iCloud to sync between iOS devices
  • 35. Demo Slides courtesy Michelle L. Bustamante
  • 36. Comparison  Transport Coupling  HTTP is an application protocol, not just a transport protocol  TCP, named pipes, MSMQ, UDP are transport only  WCF is decoupled, message can traverse any  Performance  Sometimes a faster protocol/serialization mechanism is needed Slides courtesy Michelle L. Bustamante
  • 37. Security  Web API  HTTP Services  HTTPS / SSL  Authorization header or custom headers  OAuth 2.0  WCF Services  HTTPS / SSL  SOAP Message Security  WS-Trust  OAuth 2.0 Slides courtesy Michelle L. Bustamante
  • 38. Error Handling  Mostly automatic  Helpful to control how things are returned to Ajax clients  Setting status code and message Slides courtesy Michelle L. Bustamante
  • 39. Hosting  IIS or Self hosting Slides courtesy Michelle L. Bustamante
  • 40. Feature Comparison  Productivity  Design effort  Complexity  Client code and proxy generation  Communication stack  State  Both should be stateless  Caching  Built in to HTTP, but beware
  • 41. The WS* Overload Slides courtesy Michelle L. Bustamante
  • 42. SOAP vs REST – Focus on the necessities Slide courtesy Michelle L. Bustamante
  • 43. Web API Selling Points  If we need a Web Service and don’t need SOAP, then ASP.Net Web API is very useful.  Web API - Used to build simple, non-SOAP-based HTTP Services on top of existing WCF message pipeline.  Web API - No need for configurable like WCF REST services  Web API - No need for Data contracts  Web API - Could create fully blown REST Services  Simple service creation with Web API. With WCF REST Services, service creation is difficult.  WCF is any wire protocol. Web API is focused at one thing, being easy to define and expose and consume, while also facilitating doing things in a RESTful way.  Web API is light weight architecture.
  • 46. The unified model? Kinda, sorta Obsolete
  • 47. Revision - WCF to ASP.NET Web API  ApiController (!=Controller, no common BaseClass)  ASP.NET Routing (MapHttpRoute)  Convention over Configuration  Web API to go / NuGet Packages  Web API hosted in ASP.NET: AspNetWebApi  Self-hosted Web API: AspNetWebApi.Selfhost  HttpClient including XML and JSON formatters:  System.Net.Http.Formatting  JsonValue for navigating and manipulating JSON:  System.Json  Go Live License
  • 48. How to Migrate from WCF Web API to ASP.NET Web API  http://wcf.codeplex.com/wikipage?title=How%20to%20Migrate %20from%20WCF%20Web%20API%20to%20ASP.NET%20 Web%20API
  • 50. Resources & Credits  http://www.asp.net/web-api  http://blogs.msdn.com/b/henrikn/  http://weblogs.asp.net/scottgu/archive/tags/Web+API/defa  ult.aspx  http://stackoverflow.com/questions/tagged/asp.net-web-api  https://github.com/ChristianWeyer/Thinktecture.Web.Http  http://blog.alexonasp.net  http://aspnet.uservoice.com/forums/147201-webapi/suggestions/2618312-allow-for- non-asynchronouscalls-to-the-web-api  Thanks to Michele Leroux Bustamante’s slide-deck from Windows Azure connections, March 26-29, 2012 Las Vegas, NV which I thoroughly enjoyed.  Ida Flatow’s article on web API http://www.codeproject.com/Articles/341414/WCF-or- ASP-NET-Web-APIs-My-two-cents-on-the-subjec  Alexander Zeitler’s Web API Round up  David Fekke Web API - www.fekke.com/Media/Default/powerpoint/webapi.ppt
  • 51. Summary  Choose wisely and quantitatively; avoiding the shiny object syndrome.  Enterprise WCF implementations will continue to be important…  The trend to HTTP services is here to stay, embrace it  If you are starting from scratch for a mobile / web heavy service, look at HTTP services first
  • 52. Thank You! Adnan Masood [email protected] @adnanmasood  Blog: www.AdnanMasood.com  Pasadena .NET User Group: www.sgvdotnet.org