Saturday, September 17, 2016

SOAPUI : Using Selenium in SoapUi

Using Selenium in SoapUi


  1. Download Selenium.jar files from the following link,  (http://www.seleniumhq.org/download/)
  2. Download the Java language version of the Jars, once that is done a ZIP folder should be downloaded onto your PC.
  3. Unzip the Selenium – Java-'version no' folder.
  4. Open the unzipped folder.
  5. Copy the selenium-java-2.52.0.jar and selenium-java-2.52.0-srcs.jar from the folder.
  6. Open the SoapUI directory folder (In the previous chapter I opted for a default location, such as C:\Project\SoapUI. Refer to this location).
  7. Place these jars in the following locations: ext folder and lib folders
  8.  Once you have pasted the Jars in the ext folder you also need to paste them in the lib folder of SoapUI as well.
  9. After this step we are done with the setup we now need to work on the Groovy script.
    Following is sample Groovy script for invoking a UI from SoapUI using Groovy script enabled by Selenium Jars:

    import com.eviware.soapui.model.*
    import com.eviware.soapui.model.testsuite.Assertable
    import com.eviware.soapui.support.XmlHolder
    import java.io.File;
     
     def regLogger = org.apache.log4j.Logger.getLogger("RegressionTestLoger");
    def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
    def properties = new java.util.Properties();
     
     import org.openqa.selenium.remote.CapabilityType;
    import org.openqa.selenium.remote.DesiredCapabilities;
    import com.thoughtworks.selenium.Selenium;
    
    WebDriver driver = new FirefoxDriver();
    driver.manage().deleteAllCookies();
    driver.manage().window().maximize();
      WebDriver driver = new FirefoxDriver();  
      driver.get("http://www.google.com ");
     
     
    sample script for UI automation using the Chrome driver:
    Chrome:
    you need to install the Chrome driver and set the path of the chrome driver in the path of the system or uncomment  "System.setProperty" from the code below:
     
    import org.openqa.selenium.*;
    import org.openqa.selenium.JavascriptExecutor;
    import org.openqa.selenium.firefox.FirefoxDriver;
    import org.openqa.selenium.interactions.Actions;
    import org.openqa.selenium.ie.InternetExplorerDriver;
    import com.eviware.soapui.model.*
    import org.openqa.selenium.chrome.ChromeDriver;
    import com.eviware.soapui.model.testsuite.Assertable
    import com.eviware.soapui.support.XmlHolder
    import java.io.File;
    //import java.util.*;
    //import jxl.write.*
    //import jxl.*
    def regLogger = org.apache.log4j.Logger.getLogger("RegressionTestLoger");
    def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
    def properties = new java.util.Properties();
    import org.openqa.selenium.remote.CapabilityType;
    import org.openqa.selenium.remote.DesiredCapabilities;
    import com.thoughtworks.selenium.Selenium;
    
    //System.setProperty("webdriver.chrome.driver", "C:\\Program Files\\SmartBear\\SoapUI-5.0.0\\bin\\ext\\chromedriver.exe");
    //WebDriver driver = new ChromeDriver();
                         driver.manage().deleteAllCookies();
     driver.get("http://www.google.com ");
     
     
 

Sunday, August 28, 2016

SoapUi : SoapUi Basics

SoapUi Basic


WSDL - WEB Service Def lang
XML file in webservice = wsdl file
https://www.soapui.org/rest-testing/understanding-rest-parameters.html
https://www.soapui.org/tutorials/flickr.html
http://www.omdbapi.com/
http://www.jsontest.com/
http://headers.jsontest.com/
http://date.jsontest.com/
https://learnsoapui.wordpress.com/2011/07/17/10-groovy-scripts-on-your-finger-tips-soapui/
https://www.soapui.org/scripting-properties/tips-tricks.html

SoapUI
When project is created it automatically creates a scratch pad for request response testing.
User has to manually create testSuite>testcase>testStep

1. Groovy = Java
2. log.error("")  //to log errorand log file in soapui>bin>error.log
3. log.info("")   //to log info soapui>bin
4. to change path of log file soapui\bin\log4j.xml
5. Project>testSuite>testcase> test step(groovy step)
6. see variable =
int x=100
log.info("$x") or log.info(x)"
7. SoapUI saves project as xml
8. to open saved project , File>Import xml
9. Loops ,Conditional statements = Java
10. Normal java like initialization can be used or "def" is also used declare or initialize a variable

11. Access SoapUI methods and functions inside a class

Eg:
planet.log=log   
planet.printdata()

class planet{
  def static log  //declare using def
   public static void printdata(){log.info("hi")}
}

or

obj=new A(testRunner,log)

class A{
def testRunner,log

A(testRunner,log){
this.testRunner=testRunner
this.log=log
}
}


12. Assertions are added to  Response steps only :
(https://www.youtube.com/watch?v=ssOfIyAD8ZI)
(http://www.softwaretestinghelp.com/soapui-tutorial-13-soap-vs-rest-services/)
https://www.youtube.com/watch?v=1QMCZ3x227U   -- namespace
a. Valid response
b. Data
c. tag names
d. Data count
e. Time taken
f. Status (Eg:200 OK)
g. Assertions can only be added test step

13. To add an assersion :
a. Create Rest Project for URL
http://www.softwaretestinghelp.com/soapui-tutorial-13-soap-vs-rest-services/
"http://maps.googleapis.com/maps/api/geocode/xml?address=1600+Amphitheatre+Parkway,+Mountain+View,+CA&sensor=false"
b. Run > User will get a response
c. Ck Project>Add test Suite > add a test case >
d.  rt click on test Case>Add step> add REST request >OK >OK
e. In Rest Request Window > Below the screen ,Click Assertions  > Click "+"
f. Add Assertion window > property Content>Contains> "Mountain View"  (without quotes)>Add
g. Result in green - valid
h. Repeat above step with "Deepak" = Result is Red - Failed
- user can add tag names , anything from the request etc., as Well for validation

14. Assertion :Xpath match  (http://www.w3schools.com/xsl/xsl_functions.asp)
a. To validate Xpath - exists(//status) and press Select current button
b. To count tagnames- count(//name) and press Select current button 
c. to validte if tagname "type" exists - exists(//result/type)   and press test
(User can write true or false in Expected result and validate the result)
d. to valiate a pattern - matches(//result/formatted_address,'[a-zA-Z]*')
e. for validating functions - matches(//result/type,'\d')
-- XQuery not frequently used(Google XQuery)

15 . Xquery

16. Extract Json values
import groovy.json.JsonSlurper
responseContent = testRunner.testCase.getTestStepByName("testStepname").getPropertyValue("response")
slurperresponse = new JsonSlurper().parseText(responseContent)
log.info(slurperresponse.node)

17. Extract XML values
responseContent = testRunner.testCase.getTestStepByName("Authorize").getPropertyValue("response")
def result=new XmlSlurper().parseText(responseContent)
log.info result


or

def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
responseContent = testRunner.testCase.getTestStepByName("TestStepname").getPropertyValue("response")
//"response" is keyword
def holder = groovyUtils.getXmlHolder(responseContent)
log.info holder.getNodeValue("//locale/recordId")  // "locale/recordId" = //Parentnode/node


18 .Properties :
Create
com.eviware.soapui.SoapUI.globalProperties.setPropertyValue( "prjFromCurrency", "USD" )//global
testRunner.testCase.testSuite.project.setPropertyValue( "Project_Level_Property",value.toString( ))
testRunner.testCase.testSuite.setPropertyValue( "Testsuite_Property",value.toString( ))
testRunner.testCase.setPropertyValue( "Auth", result.toString() )


Retreive Property in Groovy Script
testRunner.testCase.testSuite.getPropertyValue("Auth")

Retreive property in Request
${#Scope#Property-name[#xpath-expression]}  // Access property in request
Eg :
 ${UserName}  -- Global
${#Project#UserName}  -- Project level
${#TestSuite#UserName} -- test Suite Level
${#TestCase#UserName} -- test Case Level
${TestStep-name#Property-name}    -- Named TestStep


Remove
testRunner.testCase.removeProperty( "Testcase_Property" );


19. SLA Assersion - To check the response time
Eg : if 200 is entered then the result is pass or Fail , if the response if below or above 200 ms

20. Security Assertion
SoapUi will search the added keyword in the response , if the added data is present in the response then the test will fail

21 Compliance ,Status and Standards(important)
REST always works on top of Http
a. Invalid Http Codes - Enter 4xx codes Eg:404 etc., If the response does not contain the mentioned invalid codes then it will pass.
B.valid Http Codes - Enter 2xx codes Eg:200 etc., If the response contain the mentioned invalid codes then it will pass.

22. To Create a new step with different Request Parameters:
In the scratch pad , goto the request which gets added correctly in the test step
In the same scratch pad request, click on "+" button to add a new parameter
Once added , when u create a new test step that paramter gets automatically  added

23. Adding Quotes values stored in Property files :
testRunner.testCase.setPropertyValue("token","\"${result}\"")


24. Properties Step (Storing value for global access):
    testRunner.testCase.getTestStepByName(""propertyname"").setPropertyValue(""usn"",""Value"")
    ${property#usr}
    val=myTestCase.getTestStepByName(""propertyname"").getPropertyValue(""usn"")



25 .Header
    Accept:application/json

26. Class in groovy :
    p=new planet()
    p.test1()
    log.info p.s

    class planet{
    String s;
    public void test1()
     {
         s=""hi""
         }
    }

27. Using Apache POI in SOAP-UI
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import org.apache.poi.hssf.usermodel.HSSFSheet
    import org.apache.poi.hssf.usermodel.HSSFWorkbook
    import org.apache.poi.ss.usermodel.Cell
    import org.apache.poi.ss.usermodel.Row
    import org.apache.poi.ss.usermodel.Sheet
    import org.apache.poi.ss.usermodel.Workbook
    import org.apache.poi.ss.usermodel.WorkbookFactory

     Workbook wb = WorkbookFactory.create(new FileInputStream(""D:\\Work_related\\soapUI\\Framework\\framework.xls""));
     Sheet Sheet_integration = wb.getSheet(""integration"");
     Sheet Sheet_authentication = wb.getSheet(""authentication"");
     log.info( sheet.getRow(0).getCell(0).getRichStringCellValue() ); // Read Cell



 28.Goto or Jump
    testRunner.gotoStepByName("data driver") //setStartStep

29.To String and To Integer
    counter = propTestStep.getPropertyValue(""Count"").toString()
    counter = counter.toInteger()


30. context keyword :
The main usage for this is to store values or objects that can be used in subsequent TestSteps or related scripts.
Eg:
    context.myProperty = ""Hello""
    log.info( context.myProperty )

(will create a property named ""myProperty"" in the context and assign it the string value ""Hello")


31. Reuseable methods (https://community.smartbear.com/t5/SoapUI-NG/How-to-write-a-reusable-script-Library/td-p/29499):
    Create project as  :- Library(TestSuite-disabled) > module-name(TC) >Example(groovy Script)

    In Example file copy paste:
        context.setProperty( ""example"", new Example( log, context, testRunner) )
        class Example{
         def log
         def context
         def testRunner
         public  Example(logIn,contextIn,testRunnerIn){
          this.log=logIn
          this.context = contextIn
            this.testRunner = testRunnerIn
         }
         public String execute(message) { 
               return message
         }
        }
Create another testsuite >testcase>groovyscript and paste below code and Run:
        library = testRunner.testCase.testSuite.project.testSuites[""Library""]
        module = library.testCases[""module-name""].testSteps[""Example""]
        module.run(testRunner, context)


        // get the instance of example from the context.
        def example = context.example
        log.info(example.execute(""hi""))


32. Access Properties from another TestSuite:
    library = testRunner.testCase.testSuite.project.testSuites[""Library""]
    prop= library.testCases[""module-name""].testSteps[""Properties""]
    log.info(prop.getPropertyValue(""a""))

 


33. Passing objects to different script file :Groovy Script file 1:
def kmauthtoken_list=new ArrayList<String>();
context.setProperty( "kmauthtoken_list", kmauthtoken_list)

 
Groovy script file 2:
def kmauthtoken_list=context.kmauthtoken_list
kmauthtoken_list.add("somevalue")

SoapUi : Read and Write xls (excel)

SOAPUI: Read and Write xls




 


1. Download and jexcel.zip
2. Unzip and copy paste jxl.jar into SoapUI\lib
3. Restart SoapUI .
4. Create a new Rest Project in soapui
5. Create a new testsuite>testcase>Add 2 steps = groovystep , properties step
6. Rename properties as "property
7. Add 2 property: usn , pass
8. Create a new xls file in "D:login.xls" drive like above screenshot
9. Add below script into "Groovy Step"

 Script :

import com.eviware.soapui.support.XmlHolder
import jxl.*
import jxl.write.*

// DECLARE THE VARIABLES

def myTestCase = context.testCase //myTestCase contains the test case
def counter,next,previous,size //Variables used to handle the loop and to move inside the file

propTestStep = myTestCase.getTestStepByName("property") // get the Property TestStep object

Workbook workbook1 = Workbook.getWorkbook(new File("d:\\login.xls")) //file containing the data
Sheet sheet1 = workbook1.getSheet(0) //save the first sheet in sheet1
size= sheet1.getRows().toInteger() //get the number of rows, each row is a data set

for(int i=0;i<=size-1;i++){
Cell uData = sheet1.getCell(0,i) // getCell(column,row) //obtains user
Cell pData = sheet1.getCell(1,i) // obtains password

propTestStep.setPropertyValue("usn", uData.getContents()) //the value is saved in the property
propTestStep.setPropertyValue("pass", pData.getContents()) //the value is saved in the property
Thread.sleep(2000)
}
workbook1.close()

To call the properties into request :

${property#usr}
${property#pass}


Wednesday, July 20, 2016

Javascript : Basic example of javascript

Basic example of javascript



<!DOCTYPE html>
<html>
<head>
<script>
function myFunction() {
    document.getElementById("demo").innerHTML = "Paragraph changed.";
}
</script>
</head>

<body>

<h1>JavaScript in Head</h1>

<p id="demo">A Paragraph.</p>

<button type="button" onclick="myFunction()">Try it</button>

</body>
</html>

Tuesday, July 19, 2016

Java : Create html table using JSP

Create html table using JSP

Libraries required :
  1.  commons-dbutils
  2. my-sqlconnector
Added to project path and WebContent/lib folder

Below method retreieves data from the DB into List of Maps
public List SelectQuery(String sURL,String sUsn,String sPassword,String sQuery){
        ResultSet rs=null;
        MapListHandler rstoList=new MapListHandler();
        Map<String,Object> MapQuery=new HashMap<String,Object>();
        List resList=null;
      
        try {
            Class.forName("com.mysql.jdbc.Driver");  
            Connection connection = DriverManager.getConnection(sURL,sUsn, sPassword);          
            Statement st=(Statement) connection.createStatement();
             rs=st.executeQuery(sQuery);
             resList= rstoList.handle(rs);
             rs.close();
             st.close();
             connection.close();          
              
      }catch(Exception e){
          System.out.println("Failed to make connection!");
          e.printStackTrace();
      }      
        return resList;
    }


 Output : [{iditem=1, item_name=ketchup, price_kg=100}, {iditem=2, item_name=Beverages, price_kg=140}]

Below method converts the input List of Maps to html
    public <E> String List_MaptoHtml_TableRows(ArrayList l){   
        StringBuffer sb=new StringBuffer() ;
        //String s=null;
        String[] stemp;
       
        int flag=0;
       
        for(Iterator<E> i=l.iterator();i.hasNext();){
            Map<String,Object> m=(Map<String, Object>) i.next();
            if(flag==0)
            {
                stemp=m.keySet().toString().split(" ");
                sb.append("\n<tr>");
                for(int i2=0;i2<stemp.length;i2++)
                    sb.append("\n    <td><strong>"+stemp[i2].replaceAll("[^a-zA-Z0-9]", "")+"</strong></td>");
                sb.append("\n</tr>\n");
                flag=1;
            }
           
            stemp=m.values().toString().split(" ");
            sb.append("\n<tr>");
            for(int i2=0;i2<stemp.length;i2++)
                sb.append("\n    <td>"+stemp[i2].replaceAll("[^a-zA-Z0-9]", "")+"</td>");
            sb.append("\n</tr>\n");

        }               
            return sb.toString();
        }
       


Create a new Servelet and add below code to Doget method
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        DBHelper DBHelp=new DBHelper();
        PrintWriter out=response.getWriter();
        ArrayList<Object> oList;


        if(LRes.isEmpty()==false){
            oList=(ArrayList<Object>) DBHelp.SelectQuery(sURL,sUsername,sPassword,"SELECT * FROM mydb.item;"); 
             Helper helper=new Helper();
             out.println("<html>");
                out.println("<head><title>Page name</title></head>");
                out.println("<body>");
                out.println(oList);
                out.println("<center><h1> List of Items </h1>");
                out.println("<table border=\"1\" cellpadding=\"1\" cellspacing=\"1\" style=\"width:500px\">");
                out.println("<tbody>");
                out.println(helper.List_MaptoHtml_TableRows(oList));
                out.println("</tbody></table><p>&nbsp;</p>");
             out.println("</center>");
                out.println("</body>");
                out.println("</html>");
        }
        HttpSession session=request.getSession(); 
            session.setAttribute("name",username); 
}

Java : Print Query data from table directly into html file in Servelet itself

Print Query data from table directly into html file in Servelet itself

Libraries required :
  1.  commons-dbutils
  2. my-sqlconnector
Added to project path and WebContent/lib folder

Below method retreieves data from the DB into List of Maps
public List SelectQuery(String sURL,String sUsn,String sPassword,String sQuery){
        ResultSet rs=null;
        MapListHandler rstoList=new MapListHandler();
        Map<String,Object> MapQuery=new HashMap<String,Object>();
        List resList=null;
      
        try {
            Class.forName("com.mysql.jdbc.Driver");  
            Connection connection = DriverManager.getConnection(sURL,sUsn, sPassword);          
            Statement st=(Statement) connection.createStatement();
             rs=st.executeQuery(sQuery);
             resList= rstoList.handle(rs);
             rs.close();
             st.close();
             connection.close();          
              
      }catch(Exception e){
          System.out.println("Failed to make connection!");
          e.printStackTrace();
      }      
        return resList;
    }


 Output : [{iditem=1, item_name=ketchup, price_kg=100}, {iditem=2, item_name=Beverages, price_kg=140}]

Below method converts the input List of Maps to html
    public <E> String List_MaptoHtml_TableRows(ArrayList l){   
        StringBuffer sb=new StringBuffer() ;
        //String s=null;
        String[] stemp;
       
        int flag=0;
       
        for(Iterator<E> i=l.iterator();i.hasNext();){
            Map<String,Object> m=(Map<String, Object>) i.next();
            if(flag==0)
            {
                stemp=m.keySet().toString().split(" ");
                sb.append("\n<tr>");
                for(int i2=0;i2<stemp.length;i2++)
                    sb.append("\n    <td><strong>"+stemp[i2].replaceAll("[^a-zA-Z0-9]", "")+"</strong></td>");
                sb.append("\n</tr>\n");
                flag=1;
            }
           
            stemp=m.values().toString().split(" ");
            sb.append("\n<tr>");
            for(int i2=0;i2<stemp.length;i2++)
                sb.append("\n    <td>"+stemp[i2].replaceAll("[^a-zA-Z0-9]", "")+"</td>");
            sb.append("\n</tr>\n");

        }               
            return sb.toString();
        }
       


Create a new Servelet and add below code to Doget method
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        DBHelper DBHelp=new DBHelper();
        PrintWriter out=response.getWriter();
        ArrayList<Object> oList;


        if(LRes.isEmpty()==false){
            oList=(ArrayList<Object>) DBHelp.SelectQuery(sURL,sUsername,sPassword,"SELECT * FROM mydb.item;"); 
             Helper helper=new Helper();
             out.println("<html>");
                out.println("<head><title>Page name</title></head>");
                out.println("<body>");
                out.println(oList);
                out.println("<center><h1> List of Items </h1>");
                out.println("<table border=\"1\" cellpadding=\"1\" cellspacing=\"1\" style=\"width:500px\">");
                out.println("<tbody>");
                out.println(helper.List_MaptoHtml_TableRows(oList));
                out.println("</tbody></table><p>&nbsp;</p>");
             out.println("</center>");
                out.println("</body>");
                out.println("</html>");
        }
        HttpSession session=request.getSession(); 
            session.setAttribute("name",username); 
}

Java : Sending and Retreiving data from JSP to Serverlet and visversa

Sending and Retreiving data from JSP to Serverlet and visversa

Note :
  1. UI to Servlet -  html or jsp
  2. Servelet to UI - jsp only


UI to Servlet 

Login.html

<html>
<body>
<form action="MyServerlet1" method="get">
    <p>Username <input name="Usn" type="text" />&nbsp;</p>
    <p>Password <input name="Password" type="text" /></p>
    <p><input name="Submit" type="submit" value="Submit" /></p>
</form>
</body>
</html>


MyServerlet1.java
  1. Project>Javarespurces>src>package>rt ck >new servelet>
  2. Name "MyServerlet1" >Next,next>check doGet and doPost>Finish
  3.  Add below code to retreieve the data from "Usn" and "Password" fields.
@WebServlet("/Login")
public class MyServerlet1 extends HttpServlet {
   
    public MyServerlet1() {
        super();
        // TODO Auto-generated constructor stub
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        PrintWriter out=response.getWriter();
        String username = request.getParameter("Usn");
        String password = request.getParameter("Password");
        out.println(username+"  "+password);
    }
}

Servlet to UI (jsp file only)

itemlist.jsp (Create new jsp file in Project>WebContent>itemslist.jsp)
<html>
  <body>
    Servlet communicated message to JSP: ${jItem_list}
  </body>
</html>

Serverlet.java
request.setAttribute("jItem_list", json);
            rd = request.getRequestDispatcher("/itemslist.jsp");
            rd.forward(request, response);

 

Tuesday, July 12, 2016

Java : Object to Xml and vis versa

Object to Xml and vis versa


JAXB, stands for Java Architecture for XML Binding, using JAXB annotation to convert Java object to / from XML file. In this tutorial, we show you how to use JAXB to do following stuffs :
  1. Marshalling – Convert a Java object into a XML file.
  2. Unmarshalling – Convert XML content into a Java Object.

Required library : https://jaxb.java.net/latest/download.html

Marshalling

@XmlRootElement
public class Customer {
 String name;
 int age;
 int id;
 public String getName() {
  return name;
 }
 @XmlElement
 public void setName(String name) {
  this.name = name;
 }
 public int getAge() {
  return age;
 }
 @XmlElement
 public void setAge(int age) {
  this.age = age;
 }
}


public class JAXBExample {
 public static void main(String[] args) {

   Customer customer = new Customer();
   customer.setName("John");
   customer.setAge(18);

   try {

  File file = new File("C:\\file.xml");
  JAXBContext jaxbContext = JAXBContext.newInstance(Customer.class);
  Marshaller jaxbMarshaller = jaxbContext.createMarshaller();

  // output pretty printed
  jaxbMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);

  jaxbMarshaller.marshal(customer, file);
  jaxbMarshaller.marshal(customer, System.out);

       } catch (JAXBException e) {
  e.printStackTrace();
       }

 }
}
 Output:
<customer age="18">
    <name>John</name>
</customer> 

Unmarshalling

public class JAXBExample {
 public static void main(String[] args) {

  try {

  File file = new File("C:\\file.xml");
  JAXBContext jaxbContext = JAXBContext.newInstance(Customer.class);

  Unmarshaller jaxbUnmarshaller = jaxbContext.createUnmarshaller();
  Customer customer = (Customer) jaxbUnmarshaller.unmarshal(file);
  System.out.println(customer);

   } catch (JAXBException e) {
  e.printStackTrace();
   }

 }
} 
Customer [name=John, age=18] 

Friday, July 1, 2016

WebServer : Login Screen

WebServer : Login Screen

http://docs.oracle.com/javaee/6/tutorial/doc/gjiie.html
http://www.tutorialspoint.com/servlets/servlets-form-data.htm  (All sorts of form elements)
http://mrbool.com/using-html-forms-with-servlets/28335
http://www.javatpoint.com/servlet-http-session-login-and-logout-
http://www.javatpoint.com/servlet-http-session-login-and-logout-example
http://tutorials.jenkov.com/java-servlets/index.html

doGet()
  1.  small amount of data
  2.  insensitive data like a query has to be sent as a request.

doPost()
  1.  large amount of  has to be sent.
  2.  sensitive data (Examples are sending data after filling up a form or sending login id and password.)

Note :
Following methods of the HttpServletRequest interface that enable you to authenticate users for a web application programmatically:

    login-An alternative to specifying form-based authentication in an application deployment descriptor.
    logout- which allows an application to reset the caller identity of a request.

Forward():
  1.     Executed in the server side.
  2.     The request is transfer to other resource within same server.
  3.     Any Client
  4.     The request is shared by the target resource.
  5.     It can be used within server.
  6.     We cannot see forwarded message
  7.      faster
  8.     It is declared in RequestDispatcher interface.
  9.     Only Response from Server

sendRedirect():
  1.     Executed in the client side.
  2.     The request is transfer to other resource to different server.
  3.     Only with HTTP clients.
  4.     New request is created for the destination resource.
  5.     It can be used within and outside the server.
  6.     We can see redirected address, it is not transparent.
  7.     slower
  8.     It is declared in HttpServletResponse.
   
Include()
    Forward() + Client Side info()


Application Overview:
Index.html > Login.html > (Pass)Welcome.html or (fail) Login.html

@WebServlet("/Login")
public class MyServerlet1 extends HttpServlet {
    private static final long serialVersionUID = 1L;
    private static final String sURL="jdbc:mysql://localhost:3306/mydb";
    private static final String sUsername="root";
    private static final String sPassword="password";
   
    public MyServerlet1() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        List LRes=null;
        RequestDispatcher rd = null;
        DBHelper DBHelp=new DBHelper();
        PrintWriter out=response.getWriter();
       
        String username = request.getParameter("Usn");
        String password = request.getParameter("Password");
        LRes=DBHelp.SelectQuery(sURL,sUsername,sPassword,"SELECT * FROM mydb.login where UserID ='"+username+"' and Password='"+password+"';");
       
        if(LRes.isEmpty()==false){
            out.print("Login Successful");
            HttpSession session=request.getSession(); 
            session.setAttribute("name",username); 
           // response.sendRedirect(request.getContextPath() + "/WelcomeServlet.jsp");
            rd = request.getRequestDispatcher("/WelcomeServlet.html");
            rd.include(request, response);
            //rd.forward(request, response);  -- This can be used as well
            LRes=null;
        }
        else{
            out.print("Login failed");
        response.sendRedirect(request.getContextPath() + "/Login.html");
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);

    }
}


Database helper Class :
public class DBHelper {   
    public List SelectQuery(String sURL,String sUsn,String sPassword,String sQuery){
        ResultSet rs=null;
        MapListHandler rstoList=new MapListHandler();
        Map<String,Object> MapQuery=new HashMap<String,Object>();
        List resList=null;
       
        try {
            Class.forName("com.mysql.jdbc.Driver");   
            Connection connection = DriverManager.getConnection(sURL,sUsn, sPassword);           
            Statement st=(Statement) connection.createStatement();
             rs=st.executeQuery(sQuery);
             resList= rstoList.handle(rs);
             rs.close();
             st.close();
             connection.close();           
               
      }catch(Exception e){
          System.out.println("Failed to make connection!");
          e.printStackTrace();
      }       
        return resList;
    }
}