Pages

Wednesday, February 9, 2011

Java Client - Server chat --- very Basic SOCKET PROGRAMMING

Compile both Programs and create clas files
Open 2 cmd's .In one of thos enter
java server
and in other
java client


server.java

import java.net.*;
import java.io.*;
public class server
{
public static void main(String [] ar)
{
int port = 6666;
try
{
ServerSocket ss=new ServerSocket(port);
System.out.println("Waiting for a client....");
Socket socket=ss.accept();
System.out.println("Got a client...");
System.out.println();
InputStream sin=socket.getInputStream();
OutputStream sout=socket.getOutputStream();
DataInputStream in=new DataInputStream(sin);
DataOutputStream out=new DataOutputStream(sout);
String line=null;
while(true)
{
line=in.readUTF();
System.out.println("Client send me this line : "+ line);
System.out.println("I'm sending it back...");
out.writeUTF(line);
out.flush();
System.out.println("Waiting for the next line....");
System.out.println();

}

}
catch(Exception x)
{
x.printStackTrace();
}
}
}

client.java

import java.net.*;
import java.io.*;
public class client
{
public static void main(String [] ar)
{
int serverPort = 6666;

String address="127.0.0.1";
try
{
InetAddress ipAddress=InetAddress.getByName(address);
System.out.println("Any of you heard of a socket with IP Address " + address + " And Port " + serverPort + "?");
Socket socket=new Socket(ipAddress, serverPort);
System.out.println("Yes ! i just got hold of the program");
InputStream sin =socket.getInputStream();
OutputStream sout=socket.getOutputStream();
DataInputStream in=new DataInputStream(sin);
DataOutputStream out=new DataOutputStream(sout);
BufferedReader keyboard=new BufferedReader(new InputStreamReader(System.in));
String line=null;
System.out.println("Type in somethg and press enter.will send it to server n tell you wat it thinks");
System.out.println();
while(true)
{
line=keyboard.readLine();
System.out.println("Sending this line to server...");
out.writeUTF(line);

out.flush();
line =in.readUTF();
System.out.println("The server wa very pollite.it send me this " + line);
System.out.println("Looks like the server is pleased.go n enter more lines");
System.out.println();
}

}
catch(Exception x)
{
x.printStackTrace();
}
}
}
Read more

Saturday, February 5, 2011

User Login in JSP

User Login in JSP



Every website and software in the world is having login facility. Login gives access rights to user and defines their role in website and application. Nobody can access website if they failure in proving their identity on website or application.

Registration is first step by login to website. We will keep focus on only user login in JSP.



User login contain two fields, first one important User ID. This is unique ID provided by site owner or software application itself or most of provide facility to choose user id themselves on their website of web application.



Second is password, it is secret field and user have to keep remember without sharing with anybody. This field gives authentication to user to login on the website. User ID and password keep isolate one user to other users.



We have three forms of JSP pages.



login.jsp take input from user, mainly user id and password then submitted to server for further processing. This process handles with database. Database has a SQL table name usermaster. Usermaster table is having number of fields which are not using in login process. We need user id, password, user type, user level, first name, last name.

User type field in database explain user type as e.g. admin role, power user role, moderator role, end user role. User levels field explain about permission defined to user. Read, write, update, view are permission on user can work accordingly to these permission. This certainly is not using in current login facility. This can be useful after user login successfully and work in application.



SQL usermaster Table



CREATE TABLE `usermaster` (

`sUserID` varchar(45) NOT NULL,

`sEmail` varchar(250) NOT NULL,

`sFirstName` varchar(45) NOT NULL,

`sLastName` varchar(45) NOT NULL,

`iDOB` datetime NOT NULL,

`cGender` varchar(45) NOT NULL,

`iCountryID` int(10) unsigned NOT NULL,

`iCityID` varchar(45) NOT NULL,

`iUserType` varchar(45) DEFAULT NULL,

`iUserLevel` varchar(45) DEFAULT NULL,

`sPassword` varchar(45) NOT NULL,

`sForgetPassword` varchar(45) DEFAULT NULL,

`sContact` bigint(20) unsigned NOT NULL,

`sCreatedBy` varchar(45) DEFAULT NULL,

`dCreatedDate` datetime DEFAULT NULL,

`sModifiedBy` varchar(45) DEFAULT NULL,

`sModifiedDate` datetime DEFAULT NULL,

`sStatus` varchar(45) NOT NULL,

PRIMARY KEY (`sUserID`),

UNIQUE KEY `sEmail` (`sEmail`)

);







login.jsp



<%@ page contentType="text/html; charset=iso-8859-1" language="java" %>

<% String error=request.getParameter("error"); if(error==null || error=="null"){ error=""; } %>





User Login JSP









<%=error%>




User Name



Password

















doLogin.jsp mainly deals with database to check user id and password is matched with user trying to provide to get access from the server.



Our password field is encrypted with mysql password function. To decrypt password we have to use mysql password function again. If you are using Oracle or other database password function come with different name. Only user knows exact password and anybody can find out real password of the user. This increases the security of the system and reduces the hacking.



doLogin.jsp



<%@ page language="java" import="java.sql.*" errorPage="" %>

<% Connection conn = null; Class.forName("com.mysql.jdbc.Driver").newInstance(); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/database","root", ""); ResultSet rsdoLogin = null; PreparedStatement psdoLogin=null; String sUserID=request.getParameter("sUserName"); String sPassword=request.getParameter("sPwd"); String message="User login successfully "; try{ String sqlOption="SELECT * FROM usermaster where" +" sUserID=? and sPassword=password(?) and sStatus='A'"; psdoLogin=conn.prepareStatement(sqlOption); psdoLogin.setString(1,sUserID); psdoLogin.setString(2,sPassword); rsdoLogin=psdoLogin.executeQuery(); if(rsdoLogin.next()) { String sUserName=rsdoLogin.getString("sFirstName")+" "+rsdoLogin.getString("sLastName"); session.setAttribute("sUserID",rsdoLogin.getString("sUserID")); session.setAttribute("iUserType",rsdoLogin.getString("iUserType")); session.setAttribute("iUserLevel",rsdoLogin.getString("iUserLevel")); session.setAttribute("sUserName",sUserName); response.sendRedirect("success.jsp?error="+message); } else { message="No user or password matched" ; response.sendRedirect("login.jsp?error="+message); } } catch(Exception e) { e.printStackTrace(); } /// close object and connection try{ if(psdoLogin!=null){ psdoLogin.close(); } if(rsdoLogin!=null){ rsdoLogin.close(); } if(conn!=null){ conn.close(); } } catch(Exception e) { e.printStackTrace(); } %>



doLogin.jsp match user id and password with database record. If record is matched with user field and password. It will set user id, user type, user level, first name, last name in session. This can access from session in further in application. It will finish processing and return to success.jsp page.



success.jsp



<%@ page contentType="text/html; charset=iso-8859-1" language="java"%>





Successfully Login by JSP







Successfully login by JSP



Session Value



<% out.print("UserName :"+session.getAttribute("sUserID")+"

");

out.print("First & Last Name :"+session.getAttribute("sUserName"));

%>







If user id and password is not matched, it will return back to login.jsp page and print error message to user, user id and password is not matched.



The example of login is given with source code, login.jsp, doLogin.jsp and success.jsp.
Read more