PHP and MongoDB Web Development Beginner’s Guide
()
About this ebook
Related to PHP and MongoDB Web Development Beginner’s Guide
Related ebooks
Node Web Development, Second Edition Rating: 0 out of 5 stars0 ratingsASP.NET MVC 4 Mobile App Development Rating: 0 out of 5 stars0 ratingsWeb Application Development with MEAN Rating: 0 out of 5 stars0 ratingsMastering Web Application Development with Express Rating: 0 out of 5 stars0 ratingsNode.js Web Development - Third Edition Rating: 2 out of 5 stars2/5Learning jQuery Rating: 4 out of 5 stars4/5Mastering Spring Application Development Rating: 1 out of 5 stars1/5WordPress 3 Plugin Development Essentials Rating: 4 out of 5 stars4/5Node.js 6.x Blueprints Rating: 0 out of 5 stars0 ratingsJavaScript for .NET Developers Rating: 0 out of 5 stars0 ratingsWordPress 3.7 Complete Rating: 5 out of 5 stars5/5Learning Underscore.js Rating: 0 out of 5 stars0 ratingsWordPress Web Application Development Rating: 5 out of 5 stars5/5WordPress Plugin Development: Beginner's Guide Rating: 0 out of 5 stars0 ratingsASP.NET Site Performance Secrets Rating: 5 out of 5 stars5/5Bootstrap 4 Site Blueprints Rating: 5 out of 5 stars5/5Spring MVC: Beginner's Guide - Second Edition Rating: 0 out of 5 stars0 ratingsMeteor: Full-Stack Web Application Development Rating: 0 out of 5 stars0 ratingsMastering Node.js Rating: 1 out of 5 stars1/5Web Development with MongoDB and Node.js Rating: 0 out of 5 stars0 ratingsNode.js Blueprints Rating: 0 out of 5 stars0 ratingsBuilding Websites with VB.NET and DotNetNuke 4 Rating: 1 out of 5 stars1/5jQuery Design Patterns Rating: 0 out of 5 stars0 ratingsCouchDB and PHP Web Development Beginner’s Guide Rating: 0 out of 5 stars0 ratingsAngularJS Web Application Development Blueprints Rating: 0 out of 5 stars0 ratingsMastering Ext JS - Second Edition Rating: 0 out of 5 stars0 ratingsPHP 5 CMS Framework Development - 2nd Edition Rating: 0 out of 5 stars0 ratingsPHP Team Development Rating: 3 out of 5 stars3/5Learning PHP Data Objects Rating: 5 out of 5 stars5/5AJAX Interview Questions, Answers, and Explanations: AJAX Certification Review Rating: 0 out of 5 stars0 ratings
Information Technology For You
Health Informatics: Practical Guide Rating: 0 out of 5 stars0 ratingsCompTIA ITF+ CertMike: Prepare. Practice. Pass the Test! Get Certified!: Exam FC0-U61 Rating: 0 out of 5 stars0 ratingsHow To Use Chatgpt: Using Chatgpt To Make Money Online Has Never Been This Simple Rating: 0 out of 5 stars0 ratingsWordPress Plugin Development: Beginner's Guide Rating: 0 out of 5 stars0 ratingsWindows Registry Forensics: Advanced Digital Forensic Analysis of the Windows Registry Rating: 4 out of 5 stars4/5How to Write Effective Emails at Work Rating: 4 out of 5 stars4/5AWS Certified Cloud Practitioner: Study Guide with Practice Questions and Labs Rating: 5 out of 5 stars5/5The Ultimate Guide to Landing a Network Engineering Job Rating: 0 out of 5 stars0 ratingsComputer Science: A Concise Introduction Rating: 4 out of 5 stars4/5Creating Online Courses with ChatGPT | A Step-by-Step Guide with Prompt Templates Rating: 4 out of 5 stars4/5Practical Ethical Hacking from Scratch Rating: 5 out of 5 stars5/5Data Analytics for Beginners: Introduction to Data Analytics Rating: 4 out of 5 stars4/5An Ultimate Guide to Kali Linux for Beginners Rating: 3 out of 5 stars3/5Hacking Essentials - The Beginner's Guide To Ethical Hacking And Penetration Testing Rating: 3 out of 5 stars3/5The Basics of Hacking and Penetration Testing: Ethical Hacking and Penetration Testing Made Easy Rating: 4 out of 5 stars4/5Inkscape Beginner’s Guide Rating: 5 out of 5 stars5/5The Certified Fintech Professional Rating: 5 out of 5 stars5/5The Programmer's Brain: What every programmer needs to know about cognition Rating: 5 out of 5 stars5/5DNS in Action Rating: 0 out of 5 stars0 ratingsQuantum Computing for Programmers and Investors: with full implementation of algorithms in C Rating: 5 out of 5 stars5/5Summary of Super-Intelligence From Nick Bostrom Rating: 5 out of 5 stars5/5CompTIA Network+ CertMike: Prepare. Practice. Pass the Test! Get Certified!: Exam N10-008 Rating: 0 out of 5 stars0 ratingsA Civic Technologist's Practice Guide Rating: 0 out of 5 stars0 ratingsSupercommunicator: Explaining the Complicated So Anyone Can Understand Rating: 3 out of 5 stars3/5Computer Organization and Design: The Hardware / Software Interface Rating: 4 out of 5 stars4/5ChatGPT: The Future of Intelligent Conversation Rating: 4 out of 5 stars4/5CompTIA A+ CertMike: Prepare. Practice. Pass the Test! Get Certified!: Core 1 Exam 220-1101 Rating: 0 out of 5 stars0 ratingsCybersecurity for Beginners : Learn the Fundamentals of Cybersecurity in an Easy, Step-by-Step Guide: 1 Rating: 0 out of 5 stars0 ratings
Reviews for PHP and MongoDB Web Development Beginner’s Guide
0 ratings0 reviews
Book preview
PHP and MongoDB Web Development Beginner’s Guide - Rubayeet Islam
Table of Contents
PHP and MongoDB Web Development
Credits
About the Author
About the Reviewers
www.PacktPub.com
Support files, eBooks, discount offers and more
Why Subscribe?
Free Access for Packt account holders
Preface
What this book covers
What you need for this book
Who this book is for
Conventions
Time for action - heading
What just happened?
Pop Quiz - heading
Have a go hero heading
Reader feedback
Customer support
Downloading the example code
Errata
Piracy
Questions
1. Getting Started with MongoDB
The NoSQL movement
Types of NoSQL databases
MongoDB A document-based NoSQL database
Why MongoDB?
Who is using MongoDB?
MongoDB concepts—Databases, collections, and documents
Anatomy of document
BSON—The data exchange format for MongoDB
Similarity with relational databases
Downloading, installing, and running MongoDB
System requirements
Time for action - downloading and running MongoDB on Windows
What just happened?
Installing the 64-bit version
Time for action - downloading and running MongoDB on Linux
What just happened?
Installing MongoDB on OS X
Configuring MongoDB
Command-line parameters
File-based configuration
Have a go hero configure MongoDB to run with non-default settings
Stopping MongoDB
Hitting Control + C
From the mongo shell
Sending INT or TERM signal in UNIX
Creating databases, collections, and documents
Time for action - creating databases, collections, and documents
What just happened?
Pop Quiz - configuring MongoDB
Installing the PHP driver for MongoDB
Time for action - installing PHP driver for MongoDB on Windows
What just happened?
Installing the PHP-MongoDB driver on Unix
Connecting to the MongoDB server from PHP
Creating a PHP-Mongo connection
Time for action - creating a connection to the MongoDB server from PHP
What just happened?
Configuring the PHP-MongoDB connection
Specifying timeout for the connection attempt
Have a go hero connect to a MongoDB server on a networked computer
Summary
2. Building your First MongoDB Powered Web App
A MongoDB powered blog
Have the MongoDB server running
Inserting documents in MongoDB
Time for action - building the Blog Post Creator
What just happened?
Creating databases and collections implicitly
Performing 'safe' inserts
Benefits of safe inserts
Specifying a timeout on insert
Setting the user generated _id
The MongoDate object
Have a go hero allow storing tags for an article
Querying documents in a collection
Time for action - retrieving articles from a database
What just happened?
The Mongo Query Language
The MongoCursor object
Conditional Queries
Pop Quiz - what does this query do?
Doing advanced queries in MongoDB
Time for action - building the Blog Dashboard
What just happened?
Returning a subset of fields
Sorting the query results
Using count, skip, and limit
Performing range queries on dates
Have a go hero rewrite blogs.php
Updating documents in MongoDB
Time for action - building the Blog Editor
What just happened?
Optional arguments to the update method
Performing 'upsert'
Using update versus using save
Using modifier operations
Setting with $set
Incrementing with $inc
Deleting fields with $unset
Renaming fields with $rename
Have a go hero merge Blog editor and creator into a single module
Deleting documents in MongoDB
Time for action - deleting blog posts
What just happened?
Optional arguments to remove
Managing relationships between documents
Embedded documents
Referenced documents
Time for action - posting comments to blog posts
What just happened?
Embedded versus referenced Which one to use?
Querying embedded objects
Have a go hero get comments by username
Summary
3. Building a Session Manager
Understanding HTTP sessions
Understanding PHP native session handling
Time for action - testing native PHP session handling
What just happened?
Limitations of native PHP session handling
Implementing session handling with MongoDB
Extending session handling with session_set_save_handler
The SessionManager class
Time for action - building the SessionManager class
What just happened?
How the SessionManager works
The constructor
The open and close methods
The read method
The write method
The destroy method
The gc method
Pop Quiz - what does session_destroy() do?
Putting the SessionManager in action
Time for action - putting SessionManager into action
What just happened?
Building the user authentication module
Time for action - building the User class
What just happened?
Creating the login, logout, and user profile page
Time for action - creating the login, logout, and profile page
What just happened?
Have a go hero implement user authentication in the blogging web app
Using good session practices
Setting low expiry times of session cookies
Using session timeouts
Setting proper domains for session cookies
Checking for browser consistency
Have a go hero store and verify User Agent in SessionManager
Summary
4. Aggregation Queries
Generating sample data
Time for action - generating sample data
What just happened?
Understanding MapReduce
Visualizing MapReduce
Pop Quiz - MapReduce basics
Performing MapReduce in MongoDB
Time for action - counting the number of articles for each author
What just happened?
Defining the Map function
Defining the Reduce function
Applying the Map and Reduce
Viewing the results
Performing MapReduce on a subset of the collection
Concurrency
Performing MongoDB MapReduce within PHP
Time for action - creating a tag cloud
What just happened?
Have a go hero repeat the earlier example with PHP
Performing aggregation using group()
Time for action - calculating the average rating per author
What just happened?
Grouping by custom keys
MapReduce versus group()
Have a go hero find the maximum and minimum rating for each author
Pop Quiz - limitation of group()
Listing distinct values for a field
Time for action - listing distinct categories of articles
What just happened?
Using distinct() in mongo shell
Counting documents with count()
Summary
5. Web Analytics using MongoDB
Why MongoDB is a good choice as a web analytics backend
Logging with MongoDB
Time for action - logging page visits with MongoDB
What just happened?
Capped collections
Sorting in natural order
Updating and deleting documents in a capped collection
Specifying the size of a regular collection
Convert a regular collection to a capped one
Pop Quiz - capped collection
Extracting analytics data with MapReduce
Time for action - finding total views and average response time per blog post
What just happened?
The map, reduce, and finalize functions
Displaying the result
Running MapReduce in real time versus running it in the background
Have a go hero find out usage share of browsers for the site
Real-time analytics using MongoDB
Time for action - building a real-time page visit counter
What just happened?
Have a go hero get unique page visits in real time
Summary
6. Using MongoDB with Relational Databases
The motivation behind using MongoDB and an RDBMS together
Potential use cases
Defining the relational model
Time for action - creating the database in MySQL
What just happened?
Caching aggregation results in MongoDB
Time for action - storing the daily sales history of products in MongoDB
What just happened
Benefits of caching queries in MongoDB
Storing results of expensive JOINs
Have a go hero replacing Views with MongoDB
Using MongoDB for data archiving
Time for action - archiving old sales records in MongoDB
What just happened?
Challenges in archiving and migration
Dealing with foreign key constraints
Preserving data types
Storing metadata in MongoDB
Time for action - using MongoDB to store customer metadata
What just happened?
Problems with using MongoDB and RDBMS together
Summary
7. Handling Large Files with GridFS
What is GridFS?
The rationale of GridFS
The specification
Advantages over the filesystem
Pop Quiz - what is the maximum size of BSON objects?
Storing files in GridFS
Time for action - uploading images to GridFS
What just happened?
Looking under the hood
Have a go hero perform multiple file uploads in GridFS
Serving files from GridFS
Time for action - serving images from GridFS
What just happened?
Updating metdata of a file
Deleting files
Have a go hero create an image gallery with GridFS
Reading files in chunks
Time for action - reading images in chunks
What just happened?
When should you not use GridFS
Summary
8. Building Location-aware Web Applications with MongoDB and PHP
A geolocation primer
Methods to determine location
Pop Quiz - locating a smartphone
Detecting the location of a web page visitor
The W3C Geolocation API
Browsers that support geolocation
Time for action - detecting location with W3C API
What just happened?
The Geolocation object
The getCurrentPosition() method
Drawing the map using the Google Maps API
Geospatial indexing
Time for action - creating geospatial indexes
What just happened?
Geospatial indexing Important things to know
Performing location queries
Time for action - finding restaurants near your location
What just happened?
The geoNear() command
Bounded queries
Geospatial haystack indexing
Time for action - finding nearby restaurants that serve burgers
What just happened?
Summary
9. Improving Security and Performance
Enhancing query performance using indexes
Time for action - creating an index on a MongoDB collection
What just happened?
The _id index
Unique indexes
Compound keys indexes
Indexing embedded document fields
Indexing array fields
Deleting indexes
When indexing cannot be used
Indexing guidelines
Choose the keys wisely
Keep an eye on the index size
Avoid using low-selectivity single key indexes
Be aware of indexing costs
On a live database, run indexing in the background
Pop Quiz - the indexing MCQ test
Have a go hero implement search in the blogging application
Optimizing queries
Explaining queries using explain()
Optimization rules
Have a go hero compare outputs of explain() for indexed and non-indexed queries
Using hint()
Profiling queries
Understanding the output
Optimization rules
Securing MongoDB
Time for action - adding user authentication in MongoDB
What just happened?
Creating an admin user
Creating regular user
Viewing, changing, and deleting user accounts
User authentication through PHP driver
Have a go hero modify DBConnection class to add user authentication
Filtering user input
Running MongoDB server in a secure environment
Ensuring data durability
Journaling
Performance
Using fsync
Replication
Pop Quiz - flushing data to disk
Summary
10. Easy MongoDB Administration with RockMongo and phpMoAdmin
Administering MongoDB with RockMongo
Time for action - installing RockMongo on your computer
What just happened?
Exploring data with RockMongo
Querying
Updating, deleting, and creating documents
Importing and exporting data
Viewing stats
Miscellaneous
Using phpMoAdmin to administer MongoDB
Time for action - installing phpMoAdmin on your computer
What just happened?
Viewing databases and collections
Querying documents
Saving and deleting objects
Importing and exporting data
Viewing stats
Other features
RockMongo versus phpMoAdmin
The verdict
Summary
A. Pop Quiz Answers
Chapter 1, Getting Started with MongoDB
Chapter 2, Building your First MongoDB Powered Web App
Chapter 3, Building a Session Manager
Chapter 4, Aggregation Queries
Chapter 5, Web Analytics using MongoDB
Chapter 7, Handling Large Files with GridFS
Chapter 8, Building Location-aware Web Applications with MongoDB and PHP
Chapter 9, Improving Security and Performance
Index
PHP and MongoDB Web Development
PHP and MongoDB Web Development
Copyright © 2011 Packt Publishing
All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews.
Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book.
Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information.
First published: November 2011
Production Reference: 1181111
Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK.
ISBN 978-1-84951-362-3
www.packtpub.com
Cover Image by Charwak A ( <charwak86@gmail.com> )
Credits
Author
Rubayeet Islam
Reviewers
Sam Millman
Sigert de Vries
Nurul Ferdous
Vidyasagar N V
Acquisition Editor
Usha Iyer
Development Editor
Susmita Panda
Technical Editors
Joyslita D'Souza
Veronica Fernandes
Lubna Shaikh
Copy Editor
Laxmi Subramanian
Project Coordinator
Kushal Bhardwaj
Proofreader
Matthew Humphries
Indexer
Tejal Daruwale
Graphics
Valentina D'silva
Production Coordinator
Prachali Bhiwandkar
Cover Work
Prachali Bhiwandkar
About the Author
Rubayeet Islam is a Software Developer with over 4 years of experience in large-scale web application development on open source technology stacks (LAMP, Python/Django, Ruby on Rails). He is currently involved in developing cloud-based distributed software that use MongoDB as their analytics and metadata backend. He has also spoken in seminars to promote the use of MongoDB and NoSQL databases in general. He graduated from the University of Dhaka with a B.S. in Computer Science and Engineering.
I thank the Almighty for giving me such a blessed life and my parents for letting me follow my passion. My friend and colleague, Nurul Ferdous, for inspiring me to be an author in the first place. Finally, the amazing people at Packt—Usha Iyer, Kushal Bhardwaj, Priya Mukherji, and Susmita Panda, without your help and guidance this book would not have been possible to write.
About the Reviewers
Sam Millman, after achieving a B.Sc. in Computing from the University of Plymouth, immediately moved to advance his knowledge within Web development, specifically PHP. He is a fully self-taught professional Web Developer and IT Administrator working for a company in the south of England.
He first started to show an interest in MongoDB when he went in search of something new to learn. Now he is an active user of the MongoDB Google User Group and is about to release a new site written in PHP with MongoDB as the primary data store.
Sigert de Vries (1983) is a professional Web Developer working in The Netherlands. He has worked in several companies as a System Administrator and Web Developer. He is a specialist in high performance websites and is an open source enthusiast. With his communicative skills, he translates advanced technical issues to normal
human language.
Sigert is currently working at Worldticketshop.com, helping them to be one of the largest ticket marketplaces in Europe. Within the company, there's plenty of room to use NoSQL solutions such as MongoDB.
I would like to thank Packt publishing for asking me to review this book, it has been a pleasure!
Vidyasagar N V was interested in Computer Science since an early age. Some of his serious work in computers and computer networks began during his high school days. Later, he went to the prestigious Institute Of Technology, Banaras Hindu University for his B.Tech. He has been working as a Software Developer and Data Expert, developing and building scalable systems. He has worked with a variety of 2nd, 3rd, and 4th generation languages. He has worked with flat files, indexed files, hierarchical databases, network databases, relational databases, NoSQL databases, Hadoop, and related technologies. Currently, he is working as a Senior Developer at Ziva Software Pvt. Ltd., developing big database-structured data-extraction techniques for the Web and local information. He enjoys producing high-quality software, web-based solutions, and designing secure and scalable data systems.
I would like to thank my parents, Mr. N Srinivasa Rao and Mrs.Latha Rao, and my family who supported and backed me throughout my life. My friends for being friends, and all those people willing to donate their time, effort, and expertise by participating in open source software projects. Thank you Packt Publishing for selecting me as one of the technical reviewers on this wonderful book. It is my honor to be a part of this book. You can contact me at <vidyasagar1729@gmail.com>.
www.PacktPub.com
Support files, eBooks, discount offers and more
You might want to visit www.PacktPub.com for support files and downloads related to your book.
Did you know that Packt offers eBook versions of every book published, with PDF and ePub files available? You can upgrade to the eBook version at www.PacktPub.com and as a print book customer, you are entitled to a discount on the eBook copy. Get in touch with us at
At www.PacktPub.com, you can also read a collection of free technical articles, sign up for a range of free newsletters and receive exclusive discounts and offers on Packt books and eBooks.
http://PacktLib.PacktPub.com
Do you need instant solutions to your IT questions? PacktLib is Packt's online digital book library. Here, you can access, read and search across Packt's entire library of books.
Why Subscribe?
Fully searchable across every book published by Packt
Copy and paste, print and bookmark content
On demand and accessible via web browser
Free Access for Packt account holders
If you have an account with Packt at www.PacktPub.com, you can use this to access PacktLib today and view nine entirely free books. Simply use your login credentials for immediate access.
Preface
MongoDB is an open source, non-relational database system designed to meet the needs of modern Web 2.0 applications. It is currently being used by some of the most popular websites in the world. This book introduces MongoDB to the web developer who has some background building web applications using PHP. This book teaches what MongoDB is, how it is different from relational database management systems, and when and why developers should use it instead of a relational database for storing data.
You will learn how to build PHP applications that use MongoDB as the data backend; solve common problems, such as HTTP session handling, user authentication, and so on.
You will also learn to solve interesting problems with MongoDB, such as web analytics with MapReduce, storing large files in GridFS, and building location-aware applications using Geospatial indexing.
Finally, you will learn how to optimize MongoDB to boost performance, improve security, and ensure data durability. The book will demonstrate the use of some handy GUI tools that makes database management easier.
What this book covers
Chapter 1, Getting Started with MongoDB introduces the underlying concepts of MongoDB, provides a step-by-step guide on how to install and run a MongoDB server on a computer, and make PHP and MongoDB talk to each other.
Chapter 2, Building your First MongoDB Powered Web App shows you how to build a simple blogging web application using PHP and