Tuesday, 13 May 2014

Using Log4j on Eclipse

Log4j is a Reliable, Fast and Flexible Logging Framework (APIs) written in Java which is distributed under the Apache Software License.


What do you require to use log4j in eclipse project : apache-logging-log4j.jar (http://logging.apache.org/log4j/1.2/download.html )

You will get zip file for the jar. Unzip and save tge jar file in a directory and import the jar file in project.
Right click on the project and click properties.
Now click on java build path and click on Add External jars.
Add the external jar for the log4j logging.
Now you wizard should looks like this.(must have apache-logging-log4j.jar entry)





Java Files
1. StudentActivities.java

package firstLog;

import org.apache.log4j.Logger;

public class StudentActivities
{
static Logger log = Logger.getLogger(StudentActivities.class);
public void takeadmission()
{
log.info("Student has taken admission");
firstYear();
}
private void firstYear()
{
log.info("student in first year");
secondYear();
}

private void secondYear()
{
log.info("student ins second year");
thirdYear();
}

private void thirdYear()
{
log.info("student in third year");
fourthYear();
}

private void fourthYear()
{
log.info("student in fourth year");
professional();
}

private void professional()
{
log.info("Now he is a professional");
}
}

2. Run.java

// Using JUnit to run the program (can be replaced by a class with main method)

package firstLog;

import org.junit.Test;

public class Run
{
@Test
public void testStudentActivities()
{
StudentActivities studentActivities = new StudentActivities(); 
studentActivities.takeadmission();
}

}


3. log4j.properties (should be in project's src folder)


# This sets the global logging level and specifies the appenders
log4j.rootLogger=INFO, theConsoleAppender, FILE

# settings for the console appender
log4j.appender.theConsoleAppender=org.apache.log4j.ConsoleAppender
log4j.appender.theConsoleAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.theConsoleAppender.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=logs/log.txt
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

log4j.appender.FILE.Append=true

Now project explorer should looks like this:



Run the program and you can see the logs in /logs/log.txt

Hope this helps you :)



Thursday, 17 April 2014

Static Import

Static import
Introduced in  Java 5
Import statement was enhanced to provide greater keystroke-reduction capabilities.
 Static import is use when you want to access Class static members.
Example:
File: First.java
import static staticImport.Second.*;

public class First
{
       public static void main(String[] args)
       {
              System.out.println(firstVar);
              printfirstVar();
       }

}

File : Second.java

public class Second
{
              final static int  firstVar= 34;
             
              static void printfirstVar()
              {
                     System.out.println(firstVar);
              }
}

Output:
34
34

Problem:
Ambiguity of static members:
If we import from two classes which use same static variables then compiler will in ambiguity to decide which variable class variable to use.


Example:
File:First.java

import static staticImport.Second.*;
import static staticImport.Third.*;

public class First
{
       public static void main(String[] args)
       {
              System.out.println(firstVar);         // Error since compile not able to decide which firstVar we want to use, either of Second.java or Third.java
             

printfirstVar();                   // Error: reason is same as above
       }

}

File: second.java
public class Second
{
       final static int  firstVar= 34;
             
       static void printfirstVar()
       {
              System.out.println(firstVar);
       }
}

File: Third.java
public class Third
{
       final static int  firstVar= 34;
      
       static void printfirstVar()
       {
              System.out.println(firstVar);
       }
}


Monday, 14 April 2014

Java Serialization Example

A simple example of serialization concept in java having logging concept so that you can track object before and after serialization.


Class1 : Person.java

import java.io.Serializable;

public class Person implements Serializable
{
private static final long serialVersionUID = 1L;
String name;
int age;

Person(String name, int age)
{
this.name = name;
this.age=  age;
}

public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}

public String toString()
{
return name + " " +age;
}
}

Class 2: First.java (Serialization part )

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.util.logging.FileHandler;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

public class First {

private static final Logger logger = Logger.getLogger(First.class.getName());
public static void main(String[] args)
{
SimpleFormatter simpleFormatter = new SimpleFormatter();
Person p =new Person("shubham", 24);
try
{
FileHandler log = new FileHandler("D:\\My\\java\\try\\src\\serialization\\log.txt", true);
log.setFormatter(simpleFormatter);
logger.addHandler(log);
logger.info("Object to be serialize   " + p.toString());
FileOutputStream fileOutputStream = new FileOutputStream("D:\\My\\java\\try\\src\\serialization\\abc.ser");
ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
objectOutputStream.writeObject(p);
objectOutputStream.close();
}
catch (FileNotFoundException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
}
}
}


Class 3: Second.java (Deserialization )

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.util.logging.FileHandler;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

public class Second {

private static final Logger logger = Logger.getLogger(Second.class.getName());
static SimpleFormatter simpleFormatter = new SimpleFormatter();

public static void main(String[] args)
{
try
{
FileHandler log = new FileHandler("D:\\My\\java\\try\\src\\serialization\\log.txt", true);
log.setFormatter(simpleFormatter);
logger.addHandler(log);

FileInputStream fileInputStream = new FileInputStream("abc.ser");
ObjectInputStream objectOutputStream = new ObjectInputStream(fileInputStream);
Person p = (Person) objectOutputStream.readObject();
objectOutputStream.close();
logger.info("Object deserialized is "+p.toString());
}
catch (FileNotFoundException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
}
catch (ClassNotFoundException e)
{
e.printStackTrace();
}
}
}

Thursday, 10 April 2014

Remote debugging using Tomcat with eclipse


Remote debugging using Tomcat with eclipse
The Java debugger has a client/server design so that it can be used to debug programs that run locally (on the same workstation as the debugger) or remotely (on another computer on the network).
Local debugging:
Local debugging is the simplest and most common kind of debugging.  After you have finished editing and building your Java program, you can launch the program on your workstation using the menu item on the workbench.  Launching the program in this way will establish a connection between the debugger client and the Java program that you are launching.  You may then use breakpoints, stepping, or expression evaluation to debug your program.
Remote debugging:
The client/server design of the Java debugger allows you to launch a Java program from computer on your network and debug it from the workstation running the platform.  This is particularly useful when you are developing a program for a device that cannot host the development platform.  It is also useful when debugging programs on dedicated machines such as web servers. 
Steps:
  1. Stop your tomcat if it is in running mode.
  2. Go to Tomcat/webapp/bin. You will find a file catalina.bat (windows)/ catalina.sh (UNIX and Linux).
  3. Catalina.sh have this entry:
JPDA_ADDRESS = 8080
This port number is use for remote debugging. 8080 is default port and you can change it if required.
Write this command on UNIX command interpreter: catalina.sh jpda start
You will see something like this “INFO: Server startup in 4955 ms”.
Now, go to eclipse
Click on debug pick list icon and you will menu like this:



Now select Debug Configurations…
You well get a new window like this:



Now right click on “Remote Java Application” and select “new”.
Debug configuration window now looks like this:



Select an entry for Name field.
Select desired project from Browse button.
Enter Host: (Host name of the machine where tomcat will run.) and valid port number.
Select Apply and click Debug.  
Now you can debug your application as you usually debug on local machine.

[Note: Remote debugging may be quite slow as compared to debugging on local machine]

Sources: http://help.eclipse.org/