In this post:
The Spring module enables Mule apps to use the Spring framework. In this article, we will use a database datasource that is created by spring beans. Also, we will invoke one bean’s method from a Mule flow.
Step by step
1 - Create Mule Project: Go to Anypoint Studio and create a new Mule project.
2 - Add spring module: In Anypoint Studio, the Spring module is provided in the default configuration. In the Mule Palette, click on add modules, search for Spring and add this module to your project.
data:image/s3,"s3://crabby-images/c9977/c99776143b4950d14791eceb295d86c257cfd7e4" alt=""
3 - Spring config: Go to spring config, add name as Spring_Config and provide files as beans.xml
data:image/s3,"s3://crabby-images/d0683/d068358dadea8ca63af1d028e8676c694a5c4a15" alt=""
4 - Spring Beans: Create a beans.xml file under src/main/resources. Add the below configuration in this file.
5 - Spring JDBC: Add spring JDBC and PostgreSQL dependency and shared library in pom.xml
Add below shared library in the shared libraries tag.
6 - Spring JDBC Beans: Add spring Datasource bean configuration in beans.xml.
7 - Application Properties: Add below application properties for JDBC connection in src/main/resources. You can replace the correct username, password, and database name in the below properties.
8 - Database Config: Go to Mule Palette and drag the database connector. Configure the database configuration in global.xml with the datasource and select the PostgreSQL jar for the JDBC driver.
data:image/s3,"s3://crabby-images/c24bc/c24bc6d5f59e0bcb4fc2955adcc1e8c9acd97c56" alt=""
Test the configuration, this should return a successful connection.
9 - HTTP Listener for accounts: Add an HTTP listener and configure it with the default settings. Add a Select DB configuration and a Select query for the accounts table. Make sure the account table is created in your database and there will be at least one entry for the account table. Add a transformer to give the result in JSON format.
data:image/s3,"s3://crabby-images/9a1c9/9a1c93fffa3889da5fc86979b8eee1f2bd17b28b" alt=""
10 - Invoke: Run the mule application and invoke the endpoint to see the result. This will return records from the accounts table.
data:image/s3,"s3://crabby-images/e023d/e023da34c82bef21df3024b3e92901acbe9bff2e" alt=""
11 - Create Spring Beans: Create User POJO class, UserService interface, and UserServiceImpl service implementation class.
User.java
UserService.java
UserServiceImpl.java
12 - Spring Bean Configuration: Add below spring bean configuration for User and UserServiceImpl class in beans.xml.
13 - Mule flow: From a Mule flow it's very simple to access one of the previously created beans. It just uses an Invoke component to call the Spring bean’s function.
data:image/s3,"s3://crabby-images/7be02/7be023f42ea9e1084c86bf48e3515f0ffbfcaa71" alt=""
14 - JAVA Invoke: In the Invoke component in the Mule application, we are simply calling the sayHello() method of the UserServiceImpl. Here is the screenshot of the configuration of the Invoke component:
data:image/s3,"s3://crabby-images/4d912/4d912af4c06e53a8e057d94e6af7370ad7352ade" alt=""
15 - Invoke: Invoke the endpoint and see this will return Hello from Shyam, which we have configured the first name in beans property.
data:image/s3,"s3://crabby-images/cb819/cb819d8619a93dac782a5b15078256d1b9fca9bf" alt=""
Comments