SlideShare ist ein Scribd-Unternehmen logo
1 von 68
Downloaden Sie, um offline zu lesen
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...?

Weitere ähnliche Inhalte

Ähnlich wie Facebook App Development

Facebook Development in 5 Minutes
Facebook Development in 5 MinutesFacebook Development in 5 Minutes
Facebook Development in 5 MinutesJesse Stay
 
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 photosRakesh Rajan
 
Facebook 3rd Party Api
Facebook 3rd Party ApiFacebook 3rd Party Api
Facebook 3rd Party ApiYoss Cohen
 
페이스북 소셜 앱 개발 가이드 2011
페이스북 소셜 앱 개발 가이드 2011페이스북 소셜 앱 개발 가이드 2011
페이스북 소셜 앱 개발 가이드 2011Sukjoon Kim
 
Iskandar Najmuddin
Iskandar NajmuddinIskandar Najmuddin
Iskandar NajmuddiniPlatform
 
Charlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage UgandaCharlie Cheever Facebook Developer Garage Uganda
Charlie Cheever Facebook Developer Garage UgandaLeila Janah
 
Peepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebookPeepcode facebook-2-rails on facebook
Peepcode facebook-2-rails on facebooksushilprajapati
 

Ähnlich wie 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
 

Kürzlich hochgeladen

Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel Araújo
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...apidays
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...Neo4j
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityPrincipled Technologies
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Servicegiselly40
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Scriptwesley chun
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024The Digital Insurer
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationMichael W. Hawkins
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Allon Mureinik
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...Martijn de Jong
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Igalia
 
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 Processorsdebabhi2
 
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEarley Information Science
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 

Kürzlich hochgeladen (20)

Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
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
 
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 

Facebook App Development