SlideShare une entreprise Scribd logo
1  sur  68
Télécharger pour lire hors ligne
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="12345" capitalize="true" />
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid="12345" capitalize="true" />
FQL
Facebook API
FBML/XFBML
 Subset of HTML/XML, with some extra (powerful)
 Facebook tags
 <fb:name uid="12345" capitalize="true" />
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="12345" capitalize="true" />
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="12345" capitalize="true" />
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?
Profile
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?
Profile 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
  Profile 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
Profile	   Facebook in Browser

                      Profile Box



          Facebook Server




          Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML


                                Facebook Server




                                Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML


                                Facebook Server




                                Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML
1 - Browser makes request
                                Facebook Server




                                Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML
1 - Browser makes request
                                Facebook Server




                                Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML
1 - Browser makes request
2 - Facebook server renders     Facebook Server
profile FBML to HTML




                                Application Server
Profile	                         Facebook in Browser

                                            Profile Box
0 - Application provides FBML
1 - Browser makes request
2 - Facebook server renders     Facebook Server
profile 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_profile_tab
 fb_sig_profile_user
 fb_sig_profile_session_key
 fb_sig_page_id
 fb_sig_page_added
When authorized
When authorized

fb_sig_session_key
fb_sig_expires
fb_sig_profile_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...?

Contenu connexe

Similaire à Facebook App Development

Peepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebookPeepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebook
sushilprajapati
 

Similaire à Facebook App Development (9)

Creating a Facebook App
Creating a Facebook AppCreating a Facebook App
Creating a Facebook App
 
Facebook Development in 5 Minutes
Facebook Development in 5 MinutesFacebook Development in 5 Minutes
Facebook Development in 5 Minutes
 
Facebook Dorkbot
Facebook DorkbotFacebook Dorkbot
Facebook Dorkbot
 
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
 
Facebook 3rd Party Api
Facebook 3rd Party ApiFacebook 3rd Party Api
Facebook 3rd Party Api
 
페이스북 소셜 앱 개발 가이드 2011
페이스북 소셜 앱 개발 가이드 2011페이스북 소셜 앱 개발 가이드 2011
페이스북 소셜 앱 개발 가이드 2011
 
Iskandar Najmuddin
Iskandar NajmuddinIskandar Najmuddin
Iskandar Najmuddin
 
Charlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage UgandaCharlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage Uganda
 
Peepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebookPeepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebook
 

Dernier

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
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
WSO2
 

Dernier (20)

Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..
 
Vector Search -An Introduction in Oracle Database 23ai.pptx
Vector Search -An Introduction in Oracle Database 23ai.pptxVector Search -An Introduction in Oracle Database 23ai.pptx
Vector Search -An Introduction in Oracle Database 23ai.pptx
 
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
 
Exploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with MilvusExploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with Milvus
 
[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
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
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor Presentation
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
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...
 
Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)
 
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
 
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
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
 
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot ModelMcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
 

Facebook App Development