Thursday, May 24, 2012

Resolve error "org.springframework.beans.factory.BeanCreationException: Error creating bean with name Hello': Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: Method must not be null"

I think every Spring beginner will face this issue.Have no clues,Code seems like perfect.Tried all possible ways to resolve it? 

see below!

Reason: Its because of using different versions of the spring jars in the project.

Resolution:
 Clean the libraries/jars added to the project.Remove all the libraries from the class path.Then add the libraries into the project from the same version of Spring.
You can find the libraries in the Spring website  

Make sure that all the libraries added in the project are from the same spring version/release.

Stacktrace:
Nested in org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.beans.factory.config.PropertyPlaceholderConfigurer#0': Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: Method must not be null:
java.lang.IllegalArgumentException: Method must not be null
    at org.springframework.util.Assert.notNull(Assert.java:112)
    at org.springframework.core.BridgeMethodResolver.findBridgedMethod(BridgeMethodResolver.java:63)
    at org.springframework.beans.GenericTypeAwarePropertyDescriptor.<init>(GenericTypeAwarePropertyDescriptor.java:58)
    at org.springframework.beans.CachedIntrospectionResults.<init>(CachedIntrospectionResults.java:250)
    at org.springframework.beans.CachedIntrospectionResults.forClass(CachedIntrospectionResults.java:144)
    at org.springframework.beans.BeanWrapperImpl.getCachedIntrospectionResults(BeanWrapperImpl.java:252)
    at org.springframework.beans.BeanWrapperImpl.getPropertyDescriptorInternal(BeanWrapperImpl.java:282)
    at org.springframework.beans.BeanWrapperImpl.isWritableProperty(BeanWrapperImpl.java:333)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1247)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1010)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:472)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
    at java.security.AccessController.doPrivileged(Native Method)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:515)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:362)
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
   

Resolve Error "org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions INFO: Loading XML bean definitions from class path resource [Beans.xml]"

Spring projects will compile without any warnings and errors.But when you run the code you will see the exception.

 Reason:  It is the issue with the location of the Beans.xml.So server could not find the  location of the Spring beans xml.
Stacktrace :org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from class path resource [Beans.xml]
org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document from class path resource [Beans.xml]; nested exception is java.io.FileNotFoundException: class path resource [Beans.xml] cannot be opened because it does not exist
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:349)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310)
    at org.springframework.beans.factory.xml.XmlBeanFactory.<init>(XmlBeanFactory.java:73)
    at org.springframework.beans.factory.xml.XmlBeanFactory.<init>(XmlBeanFactory.java:61)
    at com.mySpringExample.helloExample.HelloClient.main(HelloClient.java:20)
Caused by: java.io.FileNotFoundException: class path resource [Beans.xml] cannot be opened because it does not exist
    at org.springframework.core.io.ClassPathResource.getInputStream(ClassPathResource.java:143)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:336)
    ... 4 more

Resolution :  
1) Move the spring Beans.xml to the src folder from the current folder. 
Clean and run the project.
See the screen shots below.

Wrong location(Example)

















Right location  

Resolve Error "Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory" in Spring

Spring projects compiles without any errors and warnings but when the code is run it will through the exception.You will have no clues on what is wrong with the code and project.

Stack trace:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
    at org.springframework.core.CollectionFactory.<clinit>(CollectionFactory.java:64)
    at org.springframework.core.SimpleAliasRegistry.<init>(SimpleAliasRegistry.java:41)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.<init>(DefaultSingletonBeanRegistry.java:73)
    at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.<init>(FactoryBeanRegistrySupport.java:41)
    at org.springframework.beans.factory.support.AbstractBeanFactory.<init>(AbstractBeanFactory.java:146)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.<init>(AbstractAutowireCapableBeanFactory.java:144)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.<init>(AbstractAutowireCapableBeanFactory.java:155)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.<init>(DefaultListableBeanFactory.java:121)
    at org.springframework.beans.factory.xml.XmlBeanFactory.<init>(XmlBeanFactory.java:72)
    at org.springframework.beans.factory.xml.XmlBeanFactory.<init>(XmlBeanFactory.java:61)
    at com.mySpringExample.helloExample.HelloClient.main(HelloClient.java:20)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 11 more
 
Issue: The Spring project does not have a required Jars in the build path.

Resolution : 
Add the library commons-logging.jar to the build path of the project.Then clean and build the project.

Saturday, May 19, 2012

Code for displaying image in Phonegap mobile application from server

Code for displaying image in Phonegap mobile application from server

I had a requirement to display the image in phonegap mobile application from Web server using JSON.
I could not find any solution over the net. My solution is below.

1) Add an images folder under Webcontent folder and add a jpeg image in it.
(Added the image picture5.jpg in the folder)
      2) Mention the Exact location of the image in the JSON String just like string or int value in the server   side code.
        EX: productMap.put("LOCAT", "http://192.178.3.2:9080/SalesManager/images/picture5.jpg");

      3) Create a new Javascript file picShow.js to get the image from the server using JSON.
            function getPicture()
            {
            $
            .getJSON("http://192.178.3.2:9080/SalesManager/getImage.action",
            {}, function(data) {
            processPictureData(data);
            });
            }
            function processPictureData(data)
            {
            $.each(data.PICTURE, function(i, product) {
            $('#productPic').attr('src', product.LOCAT);
            });
            }

            4) Create a new html to display the picture.
            <!DOCTYPE HTML>
            <html>
            <head>
            <title>Picture POC</title>
            <meta name="viewport" content="width=device-width,initial-scale=1" />
            <script src="scripts/phonegap-1.0.0rc2.js"></script>
            <script src="scripts/jquery-1.6.4.min.js"></script>
            <script src="scripts/jquery.mobile.min.js"></script>
            <script src="scripts/database.js"></script>
            <script src="scripts/synchronizeData.js"></script>
            <link rel="stylesheet" href="css/jquery.mobile.min.css" />
            <link rel="stylesheet" href="css/styles.css" />
            <script src="scripts/picShow.js"></script>
            </head>
            <body>
            <h1>Picture Demo</h1>
            <button onclick="getPicture()">click here</button>
            <div data-role="">
            <img id="productPic">
            </div>
            </body>
            </html>















Learn Spring by Examples: How to add Spring IDE to the Eclipse?

Adding the Spring IDE to the eclipse is not  compulsory. However it will ease out the spring coding.
All you need to do is adding spring related Jars to the workspace.
I assume everyone have the Eclipse workspace ready for adding the Spring IDE.
If not Download the eclipse from the website http://www.eclipse.org/downloads/
In this post I am going to tell you on how to add Spring IDE to the Eclipse.
Step 1:  Open the Eclipse workspace and click on help -> Install New Software























Step 2:  Click on Add button on the window opened.



















Step 3:  Add a site Enter some name and enter location http://springide.org/updatesite and click on OK (Make sure that you are connected to internet before this step)
Select the necessary softwares.







Step 4:  You are done!! Wait till the completion of downloading process and Reopen the workspace to see the added IDE.
Step 5:  Once you reopen the workspace you should be able to create the spring project.
Right click on project explorer -> click on New -> click on Other and select the Spring project.
I will cover all the modules of the Spring framework with working code examples…in my next blogs.

Resolve "Target runtime Apache Tomcat v6.0 is not defined." error

Go to window ->preferences ->Server->Runtime environments . add server Apache Tomcat v6.0 Mention the directory where apache-toma...