Difference between BSON and JSON

 

JSON BSON
JSON stands for JavaScript Object Notation. BSON stands for Binary JavaScript Object Notation.
JSON is a human readable and completely language independent. BSON isn’t in human readable format.
Database like AnyDB,redis etc stores data into JSON format. MongoDB stores data in BSON format.
JSON data contains its data simple in JSON format. BSON provides additional datatypes over the JSON data.

You can also Visit

MongoDb installation on Windows 32 bit System
Rest API in Angular 4
Angular 4 Service Tutorial
Angular 4 Component Tutorial

MongoDb installation on Windows 32 bit System

MongoDb is a document database with the scalability and flexibility. It is NOSQL Database.

Some Important points regarding MongoDb

  • MongoDb stores data in flexible, JSON-like documents, meaning fields can vary from document to document and data structure can be changed over time.
  • The document model maps to the objects in your application code, making data easy to work with
  • Ad hoc queries, indexing, and real time aggregation provide powerful ways to access and analyze your data
  • MongoDb is a distributed database at its core, so high availability, horizontal scaling, and geographic distribution are built in and easy to use

But In this post I am discussing more about MongoDb you can obtain these contents from MongoDb Official website.

“At this time our primary concern is how to install MongoDb on Windows 32 bit system.”

Note: You can install MongoDb for other operating system from official website.

Now, We come to our point that is not installing MongoDb on windows or other operating system of 64 bit.For installing 64 bit MongoDb you can visit MongoDb official page.So now we come to point to full-fill  our purpose for that I will go to official page of mongoDb

Download MongoDb for 32 bit system

mongodb_installation_page

Click above link after that install MongoDb for windows 32 bit system. You can either download  and then install .msi file or you can also download zip file and extract on specified location. I have downloaded highlighted .msi file and then install it on my system.

Now, I  am assuming that you have already download and install MongoDb file on your system. After installing MongoDb open your cmd terminal and type mongod command and after that your terminal shows


mongod

MongoDb error

It shows from this location you can’t access MongoDb. So, for resolving problem we have to replace our directory location with MongoDb bin folder location for this purpose we have to type


cd C:\Program Files\MongoDB\Server\3.2\bin

After that our terminal will be look like

change MongoDb directory

But before moving forward we have to follow some more steps.

  1. Create a data folder inside your root derive (suppose you have install mongoDb inside your c derive program file then you have to create data folder inside c derive.
  2. Create db folder inside data folder

After that I am executing mongod command on my cmd and finding storage Engine Problem

change storage Engine Problem

For resolving this problem I have to change storage Engine from wiredTiger to mmapv1.

Note: By Default storage Engine is wiredTiger but that is not supported by 32 bit system so, we have to change it from our own side. But don’t worry this task is not  rocket science but also after executing a simple command we can be able to change our storage Engine from wiredTiger to mmapv1.

So, Execute given command

mongod --storageEngine=mmapv1 

After that my terminal will look like

resolve storgeEngine

Highlighted line inside image shows that our mongoDb server has been started and by Default it’s port number is 27017.

For performing operation of MongoDb just follow these following steps

  1. Open another cmd terminal
  2. Change root folder with MongoDb bin folder for this execute command cd C:\Program Files\MongoDb\Server\3.2\bin
  3. Then execute mongo command

mongoDb Panel

Yeah now I can be able to execute MongoDb Shell commands.

Note: For executing MongoDb command still I had done a temporary path setup for permanent path set up just follow these steps

  1. open a new terminal and
  2. Type comamnd setx PATH “C:\Program Files\MongoDB\Server\3.2\bin”
  3. close terminal

You can also Learn

Angular 4

Express.js

Node.js

Rest API in Angular 4

Download Code Download From Github


I am working on Angular 4 before last few couple of months and now good command on it and each day passes with some new experiments and lots of learning. But it could not be possible in a single day but with practice of hours and day after day learning. So, I am sharing couples of things with you with Angular 4 Rest API. I will also provide an example how to use API with Angular 4.

So, now let’s ready for a deep dive for couple of minutes for learning use of Rest API with Angular 4. As we know that Angular Services provides flexibility for reusing code in our Application, with help of it we can be able to use methods and properties multiple times after adding few lines in our application. So it is good habit to define Rest APIs inside Angular services. Now for this purpose we have to need one component and one service,

Service: Contains definition of function that returns APIs result.

Component: Use result of return data from Angular service and then use return inside Angular Component.

So now let’s code for this purpose I have design an Application named RestApiTester and for this purpose I have simple write command ng new RestApiTester as I have discussed in previous lessons, after that my application is ready for further operations.

Now I am creating a component named restAPIComponent and a service named restAPIService.

Here I am creating component using angular-cli command ng g component restAPIComponent and Angular component will be created and similarly using angular cli command ng g service restAPIService for creating Angular service.

For getting data from APIs in Angular we have to add some packages inside app.module.ts HttpClientModule, HttpModule because without them we can’t be able to get result.

So At first make changes inside our app.module.ts file then we will move further. As we know that after executing angular-cli command ng g component component_name and service ng g service service_name some auto change will be occurred so after that our app.module.ts file will be look like this
app.module.ts


import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';

import { AppComponent } from './app.component';
//Import Component
import { RestApicomponentComponent } from './rest-apicomponent/rest-apicomponent.component';
//import Service
import {RestApiserviceService} from './rest-apiservice.service';

@NgModule({
  declarations: [
    AppComponent,
    RestApicomponentComponent
  ],
  imports: [
    BrowserModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

Because we want to get result from APIs so we have to make more changes i.e. in terms of adding some packages and importing some modules and also adding routing modules inside our app.moodule.ts, So after that our code will be look like this
app.module.ts


import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
//Import Component
import { RestApicomponentComponent } from './rest-apicomponent/rest-apicomponent.component';
//import Service
import {RestApiserviceService} from './rest-apiservice.service';
//Import RouterModule
import{RouterModule,Router} from '@angular/router';
//import HttpClientModule
import {HttpClientModule} from '@angular/common/http';

@NgModule({
  declarations: [
    AppComponent,
    RestApicomponentComponent
  ],
  imports: [
    BrowserModule,
    //import HttpClientModule
    HttpClientModule,
    //Routing pages  
    RouterModule.forRoot([
      {path:'all',component:RestApicomponentComponent}
    ])
  ], 
  //Adding Service inside Provide array
  providers: [RestApiserviceService],
  bootstrap: [AppComponent]
})
export class AppModule { }

We have made changes inside our front end and for this purpose we have to use bootstrap and finally our layout of project is looks like

root_page_Angular

For this we have to write these few lines of code inside app.component.html file

app.component.html file


<div style="margin:10px;">
  <div class="container">
    <h2 class="text-center">Rest API Testing Example</h2>
    <nav class="nav nav-pills flex-column flex-sm-row">
      <a class="flex-sm-fill text-sm-center nav-link active" [routerLink]="['/all']">Get All Data</a>
      <a class="flex-sm-fill text-sm-center nav-link disabled" href="#">Link</a>
      <a class="flex-sm-fill text-sm-center nav-link disabled" href="#">Link</a>
      <a class="flex-sm-fill text-sm-center nav-link disabled" href="#">Disabled</a>
    </nav>
  </div>
</div>
<router-outlet></router-outlet>

Note : We have to use routerLink on Get All Data tab for access restAPIComponent component

Because we want to result from API so, for this purpose we will have to make some changes inside our service page but before it at first view how our service page looks like before made changes.

rest-apiservice.service.ts


import { Injectable } from '@angular/core';

@Injectable()
export class RestApiserviceService {

  constructor() { }

}

Note: for getting data from API we are using a https://jsonplaceholder.typicode.com/ platform. So, moving further I will suggest you go click link and visit site.

Before calling data from API we have to make change inside our service page so that we can be able to interact with our API. After making changes inside our service page it will be looks like

rest-apiservice.service.ts


import { Injectable } from '@angular/core';
//import Http packages
import {HttpClient} from '@angular/common/http';
// import{HttpClientModule} form '@angular/http';
@Injectable()
export class RestApiserviceService {
  public allData;
  public baseUrl='https://jsonplaceholder.typicode.com/posts';
  
  constructor(public http:HttpClient) { }
  public getAllData():any{
     let allData=this.http.get(this.baseUrl);
     console.log(allData);
     return allData;
  }

}

please have a look I have opened my console for getting output and our console output page will be looked like

Angular_component_output

Yeah I got my output now my next target is to get these results in tabular form on our component html page and for this purpose I have added following lines of code on my rest-apicomponent.component page.
rest-apicomponent.component


<div class="container-fluid">
    <h5 class="text-center border">Get 100 Records </h5>
  <!-- Checking condition for data is exiting or not -->
  <div class="row" *ngIf="allData.length>0">   
  <table class="table">
    <thead class="thead-dark">
      <tr>
        <th scope="col">Id</th>
        <th scope="col">UserId</th>
        <th scope="col">Title</th>
        <th scope="col">Body</th>
      </tr>
    </thead>
    <tbody>  
    <!--Loop for getting data inside row --> 
    <tr *ngFor="let postData of allData">
      <td>{{postData.id}}</td>
      <td>{{postData.userId}}</td>
      <td>{{postData.title}}</td>
      <td>{{postData.body}}</td>
    </tr>
    </tbody>
  </table>
</div>
</div>

Go For Live Demo

Angular 4 Service Tutorial

During developing Angular application we come across a situation where we need to write some lines of code everywhere inside our application. One simple way is to write code everywhere that is needed, but that is not good practice specially when we are using frameworks because frameworks are basically build for making our coding effort less and arrange file and folders in a better way.

With help of Services we can be able to access methods and properties across other components inside entire Application.

To create a Service we have to need to write simple command


ng g service service_name

Inside this case I have created two component i.e home and servicecheck and a service servicetest as shown inside image. Look at image carefully and we will find that after executing angular-cli command for creating services two files are automatically generated as in this case servicetest is name of service and two new files servicetest.service.spec.ts and servicetest.service.ts are generated as shown below inside application folder structure.

If we are beginner then in this phase we should not think more about servicetest.service.spec.ts  file because this is used during testing of application in this case we have to consider only about servicetest.service.ts which looks like


import { Injectable } from '@angular/core';

@Injectable({
  providedIn: 'root'
})
export class ServicetestService {

  constructor() { }
}

In this case Injectable module is imported from @angular/core. It contains @Injectable method and ServicetestService class. Now you can create properties or method that you want to access inside entire application.

Suppose we want to print date on my homepage then for this purpose we have to add

Before injecting service inside our application we have to need to include service inside app.moule.ts file and way to include service inside app.module.ts file is add inside provider array like.


import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
//import components 
import { HomeComponent } from './home/home.component';
import { ServicechekComponent } from './servicechek/servicechek.component';
//import service test
import { ServicetestService } from './servicetest.service';
//import Router Link
import {RouterModule,Router} from '@angular/router';

@NgModule({
  declarations: [
    AppComponent,
    HomeComponent,
    ServicechekComponent
  ],
  imports: [
    BrowserModule,
//RouterModule
    RouterModule.forRoot([
      {path:'home',component:HomeComponent},
      {path:'servicechek',component:ServicechekComponent}
    ])
    
  ],
  providers: [HomeComponent,ServicechekComponent],
  bootstrap: [AppComponent]
})
export class AppModule {

 }

In above code I think if you are absolutely new in Angular 4 then little bit confused in RouterModule code


RouterModule.forRoot([
      {path:'home',component:HomeComponent},
      {path:'servicechek',component:ServicechekComponent}
    ])

Router is basically used for navigation between pages in Angular if we talk in terms of background then it is navigation between one component to other component. We talk in details about Router in upcoming post. Don’t panic for that.

Now come to app.component.html file I have not removed previous content which is generate by Default.

<!--The content below is only a placeholder and can be replaced.-->
<div style="text-align:center">
  <h1>
    Welcome to {{ title }}!
  </h1>
  <img width="300" alt="Angular Logo" src="">
</div>
<h2>Here are some links to help you start: </h2>
<ul>
  <li>
    <h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
  </li>
  <li>
    <h2><a target="_blank" rel="noopener" href="https://github.com/angular/angular-cli/wiki">CLI Documentation</a></h2>
  </li>
  <li>
    <h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
  </li>
</ ul >

Now we make some changes for navigating from one page to another page and for that we will make some changes inside our app.component.html file.


<!--The content below is only a placeholder and can be replaced.-->
<div style="text-align:center">
  <h1>
    Welcome to {{ title }}!
  </h1>
  <img width="300" alt="Angular Logo" src="">
</div>
<h2>Here are some links to help you start: </h2>
<ul>
  <li>
    <h2>
      <a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a>
    </h2>
  </li>
  <li>
    <h2>
      <a target="_blank" rel="noopener" href="https://github.com/angular/angular-cli/wiki">CLI Documentation</a>
    </h2>
  </li>
  <li>
    <h2>
      <a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular Blog</a>
    </h2>
  </li>
  <li>
    <a [routerLink]="['/home']">Home</a>
  </li>
  <li>
    <a [routerLink]="['/servicechek']">Service Check</a>
  </li>
  <li>
    <a [routerLink]="['/']">Back</a>
  </li>
</ul>
<router-outlet></router-outlet>
<!-- Routed components go here -->

It’s time to make changes inside service class for final out


import { Injectable } from '@angular/core';

@Injectable({
  providedIn: 'root'
})
export class ServicetestService {
  constructor() { }
//create a method for finding date
  public getDate() {
    let date = new Date();
    console.log(date);
    return date;
  }
}

How to include Service inside Component?

For including service inside Component we have to make such changes inside component, we have to make changes inside component.html and component.ts file.As we have already generated two components first one is home component and second one is servicecheck component.

Home Component

  • home.component.html
  • home.component.ts

home.component.ts


import { Component, OnInit } from '@angular/core';
import { ServicetestService } from '../servicetest.service';
// import {ServicetestService} from ''

@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent implements OnInit {
 public todate;
  constructor(public servicech:ServicetestService) { 
    console.log("constructor is called ...");

  }
  //ngOnInit method calls at first 
  ngOnInit() {  
    console.log("Ng OnInit method is called .....");
    this.todate=this.servicech.getDate();
  }

}

home.component.html


<p>
 Today is : {{todate |date}}
</p>

It is our root page

root-page

Now click on home tab as highlighted inside image and we will find our desired output as shown below.

home-service-page


Angular 4 Component Tutorial

In Angular major part of development has been done inside Component. We can also say that Components are basically backbone of Angular. Component provides flexibility to move from one view to another. In Angular best part is to load specific portion of page rather than loading complete page. As we know that (if u familiar little bit about how to start Angular then) after executing ng new Project_name we obtain file structure of app component which contains following files

Angular 4 component

  • app.component.css
  • app.component.html
  • app.component.spec.ts
  • app.component.ts
  • app.module.ts

If you open app.module.ts file then it contains @NgModule field and for being a part of complete application we have to list it inside the declaration filed  of @NgModule metadata.


import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
@NgModule({
   declarations: [
      AppComponent
   ],
   imports: [
      BrowserModule
   ],
  providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

Currently Declaration filed contains AppComponent which is parent component of Application, which is generated by default.Now if You  want to create our own component then you have to run following angular-cli command.

ng g component component_name

After executing this command your new component will be automatically created suppose if  you execute Angular-cli command like ng g component new-comp then after executing this command you will obtain a folder new-comp inside directory which contains app.module.ts and other files and folder contains these files

    • new-cmp.component.css − css file for the new component is created.
    • new-cmp.component.html − html file is created.
    • new-cmp.component.spec.ts − this can be used for unit testing.
    • new-cmp.component.ts − here,you can define the module, properties etc , how new-comp component will be behave with application that definition resides inside new-cmp.component.ts file.

After executing Angular-cli command changes are added inside app.module.ts file as shown below


import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
// includes the new-cmp component we created
@NgModule({
   declarations: [
      AppComponent,
      NewCmpComponent // here it is added in declarations and will behave as a child component
   ],
   imports: [
      BrowserModule
   ],
   providers: [],
   bootstrap: [AppComponent] //for bootstrap the AppComponent the main app component is given.
})

export class AppModule { }

Default new-comp.component.ts file looks like this way


import { Component, OnInit } from '@angular/core'; // here angular/core is imported .
@Component({
   // this is a declarator which starts with @ sign. The component word marked in bold needs to be the same.
   selector: 'app-new-cmp', //
   templateUrl: './new-cmp.component.html', 
   // reference to the html file created in the new component.
   styleUrls: ['./new-cmp.component.css'] // reference to the style file.
})
export class NewCmpComponent implements OnInit {
   constructor() { }
   ngOnInit() {}
}

File contains a new class named NewCmpComponent that implements OnInit and containing constructor and method ngOnInit which is called at time of execution of class.

Now I think you are exited for watching what the magic  is happened after making these changes so for watching changes you have to execute magical Angular-cli command ng serve and after executing command your browser display localhost:4200 page  and you will find that oh no! nothing has been changed after doing so much changes. Don’t worry I am here, you have to make some more changes for obtaining your desired output.so, why you are waiting let’s do with me. open your index.html file residing inside src folder open this file and you will obtain some codes like


<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>Angular 4App</title>
      <base href = "/">
      <meta name="viewport" content="width = device-width, initial-scale = 1">
      <link rel = "icon" type = "image/x-icon" href = "favicon.ico">
   </head>
   
   <body>
    <!-- Body Contains app app-root which is selectro of root component-->
      <app-root></app-root>
   </body>
</html>

As we have seen index.html body tag contains <app-root></app-root> tag which shows decides which component will be displayed on the browser.If you replaced it with


<app-new-cmp></app-new-cmp>

After that our code will look like


<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>Angular 4App</title>
      <base href = "/">
      <meta name="viewport" content="width = device-width, initial-scale = 1">
      <link rel = "icon" type = "image/x-icon" href = "favicon.ico">
   </head>
   
   <body>
      <app-new-cmp></app-new-cmp>
   </body>
</html>

then You will obtained your desired outPut.

Note :

  1. app.component.html file is known as cell page
  2. new generated component pages are known as variable page.
  3. After executing ng new project_name we obtain parent component
  4. After executing ng g component componet_name we obtain child component

AJAX with JSON file

AJAX is a web development technique for creating interactive web application. It contains a lot of features that added flexibility in Your web application. AJAX became so popular after adding suggestion feature by Google on Google search page, after that popularity of AJAx increase day after day.

What is AJAX ??

AJAX stands for

A   –   Asynchronous

J  –   JavaScript

A  –   and

X  –   XML

AJAX is used for creating better and faster web application with help of HTML, CSS, JAVASCRIPT and XML or JSON here I will explain feature of AJAX with help of JSON file in which I read JSON file and added to my web application, think how it is cool to add complete json file with help of AJAX after writing few lines of code just a magic but magic will happen.

HOW AJAX works ??

To explain it I have an image taken from w3schools.com.

In short from above image you are getting some concept in your mind that Browser sends a request to server and server response back to Browser and both communication takes place via internet.Here I am adding some points with a expectation that it will help to understand concept more easily.

  1. An event occurs in a web page
  2. An XMLHttpRequest object is created by JavaScript
  3. The XMLHttpRequest object sends a request to a web server
  4. The server processes the request
  5. The server sends a response back to the web page
  6. The response is read by JavaScript
  7. Proper action (like page update) is performed by JavaScript

Note : Above steps will be occurred with XML object.But here I am creating an example with JSON file so, don’t be confused.

Purpose of Doing it

# I think from above image You can be able to understand concept with XML request, 
now I thinks that You should have knowledge of JSON object.Don't worry in upcoming post
I will add Example using XML.

So,now without wasting time we are moving towards our example in which We are reading an JSON file https://raw.githubusercontent.com/krdheeraj51/country-json/master/src/country-by-capital-city.json that contains country and its capital and after reading these details we are adding to our html page.

So finally for completing this project we have need three files

  1. HTML : To display country and capital details (index.html)
  2. Js       :  To send request and get response back to html page (index.js).
  3. JSON :  file that contains data, https://raw.githubusercontent.com/krdheeraj51/country-json/master/src/country-by-capital-city.json

So, At first we are creating HTML file for designing a layout where we can display details for country and it’s respective capital.

Note : for designing I am using Bootstrap here.

index.html

Now,we go for index.js page for reading our JSON file and displaying data on html page.

 $(document).ready(function () {
    loadDetails();
});
//Load country and capital details
let loadDetails = () => {
    // alert('Company details ....');
    $.ajax({
        type: 'GET', //Method
        dataType: 'json', //File
        url: 'https://raw.githubusercontent.com/krdheeraj51/country-json/master/src/country-by-capital-city.json',
       //On success Code execute 
        success: (data) => {
            let countryDetail=data;
            //Starting for in loop for extracting data from JSON file
            for(let countyInfo in countryDetail){
      let addData=`<div class="row"> <div class="col"><p class="text-danger text-center">${countryDetail[countyInfo].country}</p></div> <div class="col"><p class="text-danger text-center">${countryDetail[countyInfo].city}</p></div> </div>`;
        $('#showDetails').append(addData);

            }
        },
        //On Error code execute
        error:(data)=>{
            alert('Somethong wrong going on');
        }    
    });

};      

After executing you code You will find output on browser like this

output_ajax_json

 

Connect Java with Sqlite3

Here we have explained an example in which we have to introduced concept of Java with Sqlite3 we discussed here concept behind establishing a connection with Java and sqlite3 database then perform operation of Create,Insert,Select Operation Reason behind switching to sqlite3 because sqlite3 is portable due to its smaller size and which suitable for any desktop application inside which we have to need smaller database, and good thing is that we don’t need to need to install any setup but also we have to store a .dll file and a shell file from specified location and take both files inside a single folder.

Download latest version SQLITE JDBC Driver from:   click here

Squlite-JDBC-Connection


//Import JDBC Packages
import java.sql.*;
import java.util.*;
public class SQLiteJDBC {
 public static void main(String args[]) {
  Connection con = null;
  Statement stmt = null;
  ResultSet rs = null;
  try {
   //Register JDBC Driver
   Class.forName("org.sqlite.JDBC");
   con = DriverManager.getConnection("jdbc:sqlite:D:/SQLiteOperation/main.db");
   // Location of SQLITE folder & main.db is default databse in SQLITE3 in your case you ca change it
   int choice;
   Scanner sb = new Scanner(System.in);
   System.out.println("Press 1 for Create table :");
   System.out.println("Press 2 for Insert Info :");
   System.out.println("Press 3 for Select Info :");
   choice = sb.nextInt();
   switch (choice) {
    case 1:

     // Creating Statement Object

     stmt = con.createStatement();
     String sqlString = "Create table test_table(name text,roll_no text)";
     stmt.executeUpdate(sqlString);
     stmt.close();
     con.close();
     break;
    case 2:

     // Creating Statement Object

     stmt = con.createStatement();
     stmt.executeUpdate("Insert into test_table(name,roll_no) values('Mohit','26')");
     stmt.close();
     con.close();
     break;
    case 3:

     // Creating Statement Object

     stmt = c.createStatement();
     rs = stmt.executeQuery("Select * from test_table");
     while (rs.next()) {
      String name = rs.getString("name");
      String roll_no = rs.getString("roll_no");
      System.out.println("name :" + name + "\nroll_no" + roll_no);
     }
     //statement close
     stmt.close();
     //connection close
     con.close();
     break;
   }
  } catch (Exception e) {
   System.err.println(e.getClass().getName() + ": " + e.getMessage());
   System.exit(0);
  }
  System.out.println("Opened database successfully");
 }
}

PHP webservices advance level

Hi Guys,

It is our advance and final level of php webservices in this session we will learn about

  1. Form Introduction
  2. Connectivity with php admin using php.
  3. Insertion operation with php
  4. Selection Opertaion with php
  5. Insert Operation with form action using php
  6. Display data on page

So, now we are starting without wasting our time

Form Introduction

What is the Form?

A Document that containing black fields, that the user can fill the data or user can select the data. Casually the data will store in the data base.

Example:

Below example shows the form with some specific actions by using post method. In this example I am adding two numbers taken from user from Input box and after clicking on submit button it will be displayed into paragraph tag.


<html>
 <head> </head> 
<body> 
<h2>Adding two numbers Using Form Action </h2> 

<form method="post"> 

<label>Enter Your first number :: </label> 
<input type="number" name="num1" /> 

<label>Enter Your Second number ::</label> 

<input type="number" name="num2" /><br> 

<input type="submit" name="submit" value="add two numbers" /> 

</form>

 <?php if(isset($_POST['submit'])){

 $number1=$_POST['num1']; 

$number2=$_POST['num2']; 

$sum=$number1+$number2; 

echo "<h2>Number after Addition" .$sum. "</h2>"; } 

?> 

</body>

</html>
        

Assignment 

# Enter Your First name inside input text enter your last name and print inside paragraph.

Connectivity with php admin using php

In php database connectivity is very simple go through these few lines of code


<?php 

$servername = "localhost";

$username = "root"; //your user name for php my admin if in local most probaly it will be "root"

$password = "root"; //password probably it will be empty or root 

$databasename = "soha_org"; //Your db nane // Create connection 

$conn = new mysqli($servername, $username, 

$password,$databasename); // Check connection 

if ($conn->connect_error) { 

die("Connection failed: " . $conn->connect_error); } 

echo "Connected successfully"; 

?>
        

Note : object operator, -> , is used in object scope to access methods and properties of an object. It’s meaning is to say that what is on the right of the operator is a member of the object instantiated into the variable on the left side of the operator.

Insertion operation with php

Now, we have learnt connectivity with phpadmin now we learnt about insertion Operation using php.

 


<?php

$servername="localhost";//servername here it is localhost 

$username="root"; //username 

$password="root"; //password

$dbane="soha_org"; //databasename //

Create a connection $conn=new mysqli($servername,$username,$password,$dbane); 

if($conn -> connect_error)

{ die("connection failed ".$conn ->connect_error); } 

//Insert query 

$sql ="Insert into student_info(name,email,gender,contact_num,additional,comment) values('abc','abc@gmail.com','Male','12345','nothing','something')";

if ($conn->query($sql) === TRUE) { 

echo "New record created successfully"; }

else{ echo "Something going wrong"; }

 ?>
        

After running this code just go to your php admin panel and you will find that yeah your data has been inserted inside your database table.



<?php //Here we are dealing with selection operation using php 

//At first we establish a database connection 

$servername="localhost";//servername

$username="root";//usernaame

$password="root"; //password 

$dbname="soha_org";//database name 

//Establish connection 

$conn = new mysqli($servername,$username,$password,$dbname); 

if($conn ->connect_error){ 

echo "Something is going wrong"; } 

//Select query to fetch your data

$sql="Select * From student_info"; 

$result =$conn->query($sql); 

if($result->num_rows > 0){ 

while($row=$result -> fetch_assoc()){ 

//Show your data taken from database table 

echo "id: " . $row["name"]. " - Email: " . $row["email"]. " " . "-Gender :" .$row["gender"]." " . "-contact number :: " .$row["contact_num"]. " " . "-Additional ::" .$row["additional"]. " " ."-comment :: " .$row["comment"]. "<br>"; } }else{ echo "0 results"; 

}

$conn->close(); 

?>
        

 

PHP webservices level 0

In this session I will describe about some basic concepts of php i.e.

  • What is PHP ?
  • PHP Features
  • How to Install PHP?
  • How to start WAMP Server?
  • Some key Concepts of WAMP server page
  • PHP Syntax

What is PHP?

  • PHP stands for HyperText Preprocessor.
  • PHP is an interpreted language, i.e. there is no need for compilation.
  • PHP is a server side scripting language.
  • PHP is faster than other scripting language e.g. asp and jsp.
  • PHP is a server side scripting language.
  • PHP is an object-oriented language.
  • PHP is an open-source scripting language.
  • PHP is simple and easy to learn language.

PHP Features

There are given many features of PHP.

    • Performance: Script written in PHP executes much faster then those scripts written in other languages such as JSP & ASP.
    • Open Source Software: PHP source code is free available on the web, you can developed all the version of PHP according to your requirement without paying any cost.
    • Platform Independent: PHP are available for WINDOWS, MAC, LINUX & UNIX operating system. A PHP application developed in one OS can be easily executed in other OS also.
    • Compatibility: PHP is compatible with almost all local servers used today like Apache, IIS etc.
    • Embedded: PHP code can be easily embedded within HTML tags and script.

How to Install PHP?

To run php program out system have need Apache,Mysql,PHP software stack, and There are many options available in the market from which we can be able to full fill our requirement.
Some of AMP options and their Download link.

    WAMP for Windows

  • LAMP for Linux
  • MAMP for Mac
  • SAMP for Solaris
  • FAMP for FreeBSD
  • XAMPP (Cross, Apache, MySQL, PHP, Perl) for Cross Platform: It includes some other components too such as FileZilla, OpenSSL, Webalizer, Mercury Mail etc.

If you are windows user and don’t want Perl and other features of XAMPP, you should go for WAMP. In a similar way, you may use LAMP for Linux and MAMP for Macintosh.

Download and Install WAMP Server

Click me to download WAMP server

Download and Install LAMP Server

Click me to download LAMP server

Download and Install MAMP Server

Click me to download MAMP server

Download and Install XAMPP Server

Click me to download XAMPP server

After installing these (not all) one of them you can be able to obtain your AMP packages that u have to need for running Your php Program.

Here ,I am using WAMP server for these complete session so, u have need to install WAMP server for practice from your own side.

How to start WAMP Server?

After installing WAMP server You have need to know how to start WAMP server but Don’t worry I am not using any rocket science here for starting Your WAMP sever. You have need to just follow these steps.

  • Just press Your windows key
  • Then serach for WAMP
  • Click on installer
  • Press yes now Your server is start.
  • Now type localhost in Your url and press Enter.

If everything is fine then on brower page You will get

wamp server page

Some key Points of WAMP server page

Inside Tools section you will find

  • phpinfo : you will get information about PHP go through it and just check.
  • phpadmin : here You can create Your database and maintain Your details from here.

I will show You how to create a database and maintain tables inside phpaddmin at a glance.

After that Your local host page contains Your project title tag which contains Your project list if You have done as in my case aliveent,aliveentertainment,arihant,arihant_backup,excel_reader,mahaveer,yesdiagnostics .

project list

Just click on any one of them and your project  will be open inside Your browser.

PHP syntax

To write PHP syntax is not a tough task. It is very easy to write a simple PHP example. To do so, create a file and write HTML tags + PHP code and save this file with .php extension.
All PHP code goes between php tag.
A syntax of PHP tag is given below:


        <?php //your code here ?>

You are free to write PHP script anywhere the page but better to prefer to write it inside body tag.

If you will understand from above line what do I want to say then good if not then very good because I am explaining it with example.

Suppose You want to declare a int type variable then just write


    $x=5;    

Now , from above line you have declared a integer type of variable which contains value 5.

I know you want to execute it and it is also good habit of a programmer to write code and execute from its own end. Then open your editor and type complete code.


<html>

<head> </head> 

    <body> 

    <?php $x =5; echo "It is an integer type value $x"; ?> 

   </body>

</html>

From above example we understood that in php there is need of declaring variable with their respective data type.

Similarly, In second example we explain how to declare string :


<html> 

<head> </head> 

  <body> 
    <?php $name ="Dheeraj"; echo "hey! I am $name"; ?>
 </body>

 </html>

Some more Examples to clear your concept :

Adding two numbers :


<html> 
<head> </head> 

  <body> 
  <?php 
  //First of all decalre two variables 

   $a=5; 

   $b=6; 

   $c=$a+$b; 

   echo "value of a : $a <br>"; 

   echo "value of b : $b <br>"; 

   echo "After adding two numbers output will be : $c"; ?> 

   </body> 
</html>
        

Displaying messages inside html tags using php

In real time applications we have to need to displaying messages inside html tags like (h1,h2,h3 …h7,p etc), from next example I will explain how to display a message inside html tag.


<html> 
<head> </head> 

 <body>

 <h1>Profile details </h1> 

<?php //At first decalring variables

$name="abc"; 

$emailId="abc@gmail.com";

$contact="91XXXXXX21"; 

$additional="php"; //Displaying messages 

echo "<h3> hey I am " .$name. "</h3><br>"; 

echo "<h6>My emailId is ".$emailId. "</h6><br>"; 

echo "<h6>My contact number is ".$contact."</h6></br>"; 

echo "<p>I like to learn more about web techonolgy so,".$additional. " is one of my favourite language.<p>" ?> 

</body> 

</html>
        

Note : Don’t  confused with dot (‘.’) inside variable  .$name.,.$emailId.,.$contact.,.$additional. It is simply separator operator used for separating two messages also used for concatenating two messages.