Book Image

CouchDB and PHP Web Development Beginner's Guide

By : Tim Juravich
Book Image

CouchDB and PHP Web Development Beginner's Guide

By: Tim Juravich

Overview of this book

CouchDB is a NoSQL database which is making waves in the development world. It's the tool of choice for many PHP developers so they need to understand the robust features of CouchDB and the tools that are available to them.CouchDB and PHP Web Development Beginner's Guide will teach you the basics and fundamentals of using CouchDB within a project. You will learn how to build an application from beginning to end, learning the difference between the "quick way"ù to do things, and the "right way"ù by looking through a variety of code examples and real world scenarios. You will start with a walkthrough of setting up a sound development environment and then learn to create a variety of documents manually and programmatically. You will also learn how to manage their source control with Git and keep track of their progress. With each new concept, such as adding users and posts to your application, the author will take you through code step-by-step and explain how to use CouchDB's robust features. Finally, you will learn how to easily deploy your application and how to use simple replication to scale your application.
Table of Contents (17 chapters)
CouchDB and PHP Web Development Beginner's Guide
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
4
Starting your Application

Time for action — anonymously accessing the _users database


Let's go through a quick exercise of calling a curl statement to the _users database to see why it's important to secure our data.

  1. 1. Open Terminal.

  2. 2. Run the following command, replacing your_username with the username of the server admin that you just created.

    curl localhost:5984/_users/org.couchdb.user:your_username | python -mjson.tool
    
    
  3. 3. Terminal will respond with something similar to:

    {
    "_id": "org.couchdb.user:your_username",
    "_rev": "1-b9af54a7cdc392c2c298591f0dcd81f3",
    "name": "your_username",
    "password_sha": "3bc7d6d86da6lfed6d4d82e1e4d1c3ca587aecc8",
    "roles": [],
    "salt": "9812acc4866acdec35c903f0cc072c1d",
    "type": "user"
    }
    
    

What just happened?

You used Terminal to create a curl request to read the document containing your server admin's data. The passwords in the database are encrypted, but it's possible that someone could still unencrypt the password or use the usernames of the users against them. With that in mind, let...