SlideShare a Scribd company logo
1 of 68
Download to read offline
Facebook App Development
An introduction by Cristiano Betta
About me
Senior Web Developer
@ Nudge London
About me
Freelance Web
Developer
About me
Hobby Photographer
About me
Geek
Why Facebook Apps?
Bring existing apps into Facebook
Why Facebook Apps?
Harvest social relationships
Why Facebook Apps?	
Campaign on Facebook
Why Facebook Apps?	
Bring a brand into Facebook
Why Facebook Apps
Launch brand within Facebook
Facebook API
Facebook API
FBML/XFBML
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid=quot;12345quot; capitalize=quot;truequot; />
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid=quot;12345quot; capitalize=quot;truequot; />
FQL
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid=quot;12345quot; capitalize=quot;truequot; />
FQL
 Ideal for querying extra data server side
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid=quot;12345quot; capitalize=quot;truequot; />
FQL
 Ideal for querying extra data server side
 SELECT name, pic FROM user WHERE uid=12345
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid=quot;12345quot; capitalize=quot;truequot; />
FQL
 Ideal for querying extra data server side
 SELECT name, pic FROM user WHERE uid=12345
FBJS
Whatā€™s in a FB app?
Application Directory
Whatā€™s in a FB app?
About Page
Whatā€™s in a FB app?
Proļ¬le
Whatā€™s in a FB app?
Applications menu
Whatā€™s in a FB app?
Bookmarks
Whatā€™s in a FB app?
Applications Tab
Whatā€™s in a FB app?
Boxes Tab
Whatā€™s in a FB app?
Proļ¬le Info Section
Whatā€™s in a FB app?
Publisher
Whatā€™s in a FB app?
News Feed
Whatā€™s in a FB app?
    And much more.....
Integration Points
 Canvas pages
  Canvas
  Tab
  Attachment
Integration Points
 Asynchronous FBML
  Proļ¬le box
  Info tab box
  Boxes Tab
Canvas   Facebook in Browser

                Application Canvas



         Facebook Server




         Application Server
Canvas                      Facebook in Browser

                                   Application Canvas
1 - Browser makes request


                            Facebook Server




                            Application Server
Canvas                      Facebook in Browser

                                   Application Canvas
1 - Browser makes request


                            Facebook Server




                            Application Server
Canvas                           Facebook in Browser

                                        Application Canvas
1 - Browser makes request
2 - FB server calls web server
                                 Facebook Server




                                 Application Server
Canvas                           Facebook in Browser

                                        Application Canvas
1 - Browser makes request
2 - FB server calls web server
                                 Facebook Server




                                 Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server




                                  Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server




                                  Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server

4 - App returns FBML




                                  Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server

4 - App returns FBML




                                  Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server

4 - App returns FBML
5 - Facebook renders FBML
to HTML



                                  Application Server
Canvas                            Facebook in Browser

                                         Application Canvas
1 - Browser makes request
2 - FB server calls web server
3 - App Calls FB API (optional)   Facebook Server

4 - App returns FBML
5 - Facebook renders FBML
to HTML



                                  Application Server
Proļ¬le	   Facebook in Browser

                      Proļ¬le Box



          Facebook Server




          Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML


                                Facebook Server




                                Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML


                                Facebook Server




                                Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML
1 - Browser makes request
                                Facebook Server




                                Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML
1 - Browser makes request
                                Facebook Server




                                Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML
1 - Browser makes request
2 - Facebook server renders     Facebook Server
proļ¬le FBML to HTML




                                Application Server
Proļ¬le	                         Facebook in Browser

                                            Proļ¬le Box
0 - Application provides FBML
1 - Browser makes request
2 - Facebook server renders     Facebook Server
proļ¬le FBML to HTML




                                Application Server
Authentication
Authentication
Without Authorization
Without Authorization

 fb_sig_added
 fb_sig_api_key
 fb_sig_friends
 fb_sig_time
 fb_sig_user/fb_sig_canvas_user
Without Authorization
Without Authorization
 fb_sig_in_canvas
 fb_sig_in_proļ¬le_tab
 fb_sig_proļ¬le_user
 fb_sig_proļ¬le_session_key
 fb_sig_page_id
 fb_sig_page_added
When authorized
When authorized

fb_sig_session_key
fb_sig_expires
fb_sig_proļ¬le_update_time
fb_sig_ext_perms
Security?
Security? fb_sig!
How to get started
http://www.facebook.com/developers
How to get started
Create a new app and get API key, Secret, and
more....
How to get started
Setup your application canvas with API key
How to get started
Read the wiki for reference on FBML, FBJS, API,
etc - http://wiki.developers.facebook.com/
How to get started
Make sure to get the libraries
How to get started
Write a hello world, and see what happens
More about me
cristianobetta.com
More about me
nudgelondon.com/cristiano
Questions...?

More Related Content

What's hot

Introduction to facebook platform
Introduction to facebook platformIntroduction to facebook platform
Introduction to facebook platform
Venkatesh Narayanan
Ā 
110910 facebook customization
110910   facebook customization110910   facebook customization
110910 facebook customization
Pinnacle of Indiana
Ā 
Dan Lester
Dan LesterDan Lester
Dan Lester
GrantBell
Ā 
Facebook Apps
Facebook AppsFacebook Apps
Facebook Apps
davebalogh
Ā 
Appendix a frog widget guide (new)
Appendix a   frog widget guide (new)Appendix a   frog widget guide (new)
Appendix a frog widget guide (new)
Ira Raji
Ā 
Rume publisher promoassets-2
Rume publisher promoassets-2Rume publisher promoassets-2
Rume publisher promoassets-2
Rumble
Ā 

What's hot (19)

Introduction to facebook platform
Introduction to facebook platformIntroduction to facebook platform
Introduction to facebook platform
Ā 
Developing Facebook Application
Developing Facebook ApplicationDeveloping Facebook Application
Developing Facebook Application
Ā 
Facebook to Makeover Brand Pages
Facebook to Makeover Brand PagesFacebook to Makeover Brand Pages
Facebook to Makeover Brand Pages
Ā 
110910 facebook customization
110910   facebook customization110910   facebook customization
110910 facebook customization
Ā 
Facebook API for iOS
Facebook API for iOSFacebook API for iOS
Facebook API for iOS
Ā 
Dan Lester
Dan LesterDan Lester
Dan Lester
Ā 
Salesforce Winter Release
Salesforce Winter ReleaseSalesforce Winter Release
Salesforce Winter Release
Ā 
funP 開ē™¼č€…äæ±ę؂éƒØ åęœˆä»½čšęœƒ
funP 開ē™¼č€…äæ±ę؂éƒØ åęœˆä»½čšęœƒfunP 開ē™¼č€…äæ±ę؂éƒØ åęœˆä»½čšęœƒ
funP 開ē™¼č€…äæ±ę؂éƒØ åęœˆä»½čšęœƒ
Ā 
Facebook Apps
Facebook AppsFacebook Apps
Facebook Apps
Ā 
Myface
MyfaceMyface
Myface
Ā 
[Code Camp] į»Øng dį»„ng Facebook API vĆ o phĆ”t triį»ƒn website
[Code Camp] į»Øng dį»„ng Facebook API vĆ o phĆ”t triį»ƒn website[Code Camp] į»Øng dį»„ng Facebook API vĆ o phĆ”t triį»ƒn website
[Code Camp] į»Øng dį»„ng Facebook API vĆ o phĆ”t triį»ƒn website
Ā 
Facebook api
Facebook api Facebook api
Facebook api
Ā 
10 Steps to SEO Success
10 Steps to SEO Success 10 Steps to SEO Success
10 Steps to SEO Success
Ā 
Symfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web developmentSymfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web development
Ā 
Appendix a frog widget guide (new)
Appendix a   frog widget guide (new)Appendix a   frog widget guide (new)
Appendix a frog widget guide (new)
Ā 
Facebook Dorkbot
Facebook DorkbotFacebook Dorkbot
Facebook Dorkbot
Ā 
What's New on the Facebook Platform, August 2010
What's New on the Facebook Platform, August 2010What's New on the Facebook Platform, August 2010
What's New on the Facebook Platform, August 2010
Ā 
Filemaker FMP URLs
Filemaker FMP URLsFilemaker FMP URLs
Filemaker FMP URLs
Ā 
Rume publisher promoassets-2
Rume publisher promoassets-2Rume publisher promoassets-2
Rume publisher promoassets-2
Ā 

Viewers also liked

Viewers also liked (10)

Happy facebook developer
Happy facebook developerHappy facebook developer
Happy facebook developer
Ā 
Making Facebook Faster
Making Facebook FasterMaking Facebook Faster
Making Facebook Faster
Ā 
Facebook Development with Zend Framework
Facebook Development with Zend FrameworkFacebook Development with Zend Framework
Facebook Development with Zend Framework
Ā 
Introduction to Facebook Javascript SDK (NEW)
Introduction to Facebook Javascript SDK (NEW)Introduction to Facebook Javascript SDK (NEW)
Introduction to Facebook Javascript SDK (NEW)
Ā 
Facebook Developer Garage Indonesia - Introduction
Facebook Developer Garage Indonesia - IntroductionFacebook Developer Garage Indonesia - Introduction
Facebook Developer Garage Indonesia - Introduction
Ā 
Workshop : Facebook JavaScript SDK
Workshop : Facebook JavaScript SDKWorkshop : Facebook JavaScript SDK
Workshop : Facebook JavaScript SDK
Ā 
Introduction to Facebook JavaScript & Python SDK
Introduction to Facebook JavaScript & Python SDKIntroduction to Facebook JavaScript & Python SDK
Introduction to Facebook JavaScript & Python SDK
Ā 
Introduction to facebook java script sdk
Introduction to facebook java script sdk Introduction to facebook java script sdk
Introduction to facebook java script sdk
Ā 
Introduction to facebook javascript sdk
Introduction to facebook javascript sdk Introduction to facebook javascript sdk
Introduction to facebook javascript sdk
Ā 
Facebook + Ruby
Facebook + RubyFacebook + Ruby
Facebook + Ruby
Ā 

Similar to Facebook App Development

How to write a FaceBook Application
How to write a FaceBook ApplicationHow to write a FaceBook Application
How to write a FaceBook Application
Nguyį»…n Duy NhĆ¢n
Ā 
Peepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebookPeepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebook
sushilprajapati
Ā 
Ikandar Najmuddin - "What's new?"
Ikandar Najmuddin - "What's new?"Ikandar Najmuddin - "What's new?"
Ikandar Najmuddin - "What's new?"
iPlatform
Ā 

Similar to Facebook App Development (12)

Facebook App Development
Facebook App DevelopmentFacebook App Development
Facebook App Development
Ā 
How to write a FaceBook Application
How to write a FaceBook ApplicationHow to write a FaceBook Application
How to write a FaceBook Application
Ā 
Facebook Development in 5 Minutes
Facebook Development in 5 MinutesFacebook Development in 5 Minutes
Facebook Development in 5 Minutes
Ā 
Building an interactive timeline from facebook photos
Building an interactive timeline from facebook photosBuilding an interactive timeline from facebook photos
Building an interactive timeline from facebook photos
Ā 
Charlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage UgandaCharlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage Uganda
Ā 
ķŽ˜ģ“ģŠ¤ė¶ ģ†Œģ…œ ģ•± ź°œė°œ ź°€ģ“ė“œ 2011
ķŽ˜ģ“ģŠ¤ė¶ ģ†Œģ…œ ģ•± ź°œė°œ ź°€ģ“ė“œ 2011ķŽ˜ģ“ģŠ¤ė¶ ģ†Œģ…œ ģ•± ź°œė°œ ź°€ģ“ė“œ 2011
ķŽ˜ģ“ģŠ¤ė¶ ģ†Œģ…œ ģ•± ź°œė°œ ź°€ģ“ė“œ 2011
Ā 
Iskandar Najmuddin
Iskandar NajmuddinIskandar Najmuddin
Iskandar Najmuddin
Ā 
Peepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebookPeepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebook
Ā 
Connect with Facebook to Rails Application By Nyros Developer
Connect with Facebook to Rails Application By Nyros DeveloperConnect with Facebook to Rails Application By Nyros Developer
Connect with Facebook to Rails Application By Nyros Developer
Ā 
Whats New On The Facebook Platform Feb 2010 Iskandar
Whats New On The Facebook Platform Feb  2010   IskandarWhats New On The Facebook Platform Feb  2010   Iskandar
Whats New On The Facebook Platform Feb 2010 Iskandar
Ā 
Ikandar Najmuddin - "What's new?"
Ikandar Najmuddin - "What's new?"Ikandar Najmuddin - "What's new?"
Ikandar Najmuddin - "What's new?"
Ā 
Facebook Open Stream API - Facebook Developer Garage Dhaka
Facebook Open Stream API - Facebook Developer Garage DhakaFacebook Open Stream API - Facebook Developer Garage Dhaka
Facebook Open Stream API - Facebook Developer Garage Dhaka
Ā 

More from Cristiano Betta

Hacking with html5 video, rtc and shared web workers
Hacking with html5 video, rtc and shared web workersHacking with html5 video, rtc and shared web workers
Hacking with html5 video, rtc and shared web workers
Cristiano Betta
Ā 
The state of packaged web apps
The state of packaged web appsThe state of packaged web apps
The state of packaged web apps
Cristiano Betta
Ā 
Payments for the REST of us
Payments for the REST of usPayments for the REST of us
Payments for the REST of us
Cristiano Betta
Ā 

More from Cristiano Betta (20)

This strange planet earth
This strange planet earthThis strange planet earth
This strange planet earth
Ā 
Techsylvania -Hackathons on Rails
Techsylvania -Hackathons on RailsTechsylvania -Hackathons on Rails
Techsylvania -Hackathons on Rails
Ā 
Death to Passwords
Death to Passwords Death to Passwords
Death to Passwords
Ā 
Making your hackathon matter api con-uk
Making your hackathon matter   api con-ukMaking your hackathon matter   api con-uk
Making your hackathon matter api con-uk
Ā 
The future ux of money
The future ux of moneyThe future ux of money
The future ux of money
Ā 
Why we released the kraken
Why we released the krakenWhy we released the kraken
Why we released the kraken
Ā 
Hardware and the commerce revolution
Hardware and the commerce revolutionHardware and the commerce revolution
Hardware and the commerce revolution
Ā 
How hardware is driving the commerce revolution copy
How hardware is driving the commerce revolution copyHow hardware is driving the commerce revolution copy
How hardware is driving the commerce revolution copy
Ā 
Making your hackathon matter
Making your hackathon matterMaking your hackathon matter
Making your hackathon matter
Ā 
Hackathons: Best Practices From experience
Hackathons: Best Practices From experienceHackathons: Best Practices From experience
Hackathons: Best Practices From experience
Ā 
Hacking through space and time
Hacking through space and timeHacking through space and time
Hacking through space and time
Ā 
Hacking with html5 video, rtc and shared web workers
Hacking with html5 video, rtc and shared web workersHacking with html5 video, rtc and shared web workers
Hacking with html5 video, rtc and shared web workers
Ā 
From geek to event organiser
From geek to event organiserFrom geek to event organiser
From geek to event organiser
Ā 
5 awesome new paypal hack ideas
5 awesome new paypal hack ideas5 awesome new paypal hack ideas
5 awesome new paypal hack ideas
Ā 
Concrete indentity really getting to know your users
Concrete indentity  really getting to know your usersConcrete indentity  really getting to know your users
Concrete indentity really getting to know your users
Ā 
Online identity getting to know your users
Online identity  getting to know your usersOnline identity  getting to know your users
Online identity getting to know your users
Ā 
PayPal on iOS + 9 great free app ideas
PayPal on iOS + 9 great free app ideasPayPal on iOS + 9 great free app ideas
PayPal on iOS + 9 great free app ideas
Ā 
The state of packaged web apps
The state of packaged web appsThe state of packaged web apps
The state of packaged web apps
Ā 
Payments for the REST of us
Payments for the REST of usPayments for the REST of us
Payments for the REST of us
Ā 
Chrome Extensions for Hackers
Chrome Extensions for HackersChrome Extensions for Hackers
Chrome Extensions for Hackers
Ā 

Recently uploaded

Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
Ā 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Victor Rentea
Ā 

Recently uploaded (20)

Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
Ā 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
Ā 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
Ā 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
Ā 
AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024
Ā 
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ..."I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
Ā 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Ā 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
Ā 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
Ā 
Ransomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdfRansomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdf
Ā 
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Ā 
Spring Boot vs Quarkus the ultimate battle - DevoxxUK
Spring Boot vs Quarkus the ultimate battle - DevoxxUKSpring Boot vs Quarkus the ultimate battle - DevoxxUK
Spring Boot vs Quarkus the ultimate battle - DevoxxUK
Ā 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
Ā 
Exploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with MilvusExploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with Milvus
Ā 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Ā 
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Ā 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Ā 
Cyberprint. Dark Pink Apt Group [EN].pdf
Cyberprint. Dark Pink Apt Group [EN].pdfCyberprint. Dark Pink Apt Group [EN].pdf
Cyberprint. Dark Pink Apt Group [EN].pdf
Ā 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
Ā 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
Ā 

Facebook App Development