Tuesday, 22 December 2015

Restrict Logging of StackTrace in Java


Problem :
we have a requirement of restricting the logging of full stacktrace due to many reasons.

Solution:
we have two ways to control this printing of stakctrace.
one solution fits for application which is in devlopement stage and second one is for production stage.

1. Application in DEV STAGE :
so we have option to customize the printing of stack trace.
please go through this method .

public String customizeStackTrace(Throwable e, int maxLines)
    {
       
        StringBuilder newStackStrace = new StringBuilder(e.getMessage()+"\n"); 
        StackTraceElement[] elements = e.getStackTrace();
        for (int i = 0; i < maxLines; i++)
        {
            newStackStrace.append(elements[i]).append("\n");
        }
        return newStackStrace.toString();
    }



2. Application in PROD STAGE:
 so we have to control using log4j .
If you are using log4j version lessthan 1.12.16 then you need to upgrade to 1.2.16 or more.
and use layout as
<layout class="org.apache.log4j.EnhancedPatternLayout">
            <param name="ConversionPattern" value=" %d{yyyy-MM-dd HH:mm:ss,SSS} %-5p %c{1}: %m%n %throwable{10}" />
        </layout>




I think you found right information here. see you soon with new issue i found..

Wednesday, 15 July 2015

Eclipse Code Template


I came across importing same stuff frequently. I thought of creating the shortcut for this.
Then I found eclipse is good in providing this kind of stuff.

The stuff  I want to import are Logger from SLF4J, for this we have to import slf4j and lo4j api in our class.Which is irritating stuff to type everytime while creating new class.

Eclipse already have code templates which some of them are shown below:










Now we will  create a code template which will show as above

Solution:

Window->Preferences->Java -> Editor -> Templates
 
 
you Will see below :






Click on "New" 



Enter template Name as "slf4j" 
Write description
Add Patteren given below in the box.

Click OK.


For SLF4J:

${:import(org.slf4j.Logger,org.slf4j.LoggerFactory,org.slf4j.Logger,org.slf4j.Logger)}
private static final Logger LOGGER = LoggerFactory.getLogger(${enclosing_type}.class);


For Log4J:

${:import(org.apache.log4j.Logger)}
private static final Logger LOG = Logger.getLogger(${enclosing_type}.class);



Now you will see the slf4j code template in your eclipse .
 Start Typing sl and CTRL+SPACE. you will...like this..:-)