Spring SpEL - Expression Templating



SpEL expression allows to mix literal text with evaluation block(s). Each evaluation block is to be prefixed and suffixed properly. Standard choice is to use #{}. org.springframework.expression.common. TemplateParserContext uses the #{}

Syntax

String result = parser.parseExpression("Random number : #{T(java.lang.Math).random() * 100}", 
   new TemplateParserContext()).getValue(String.class);

Following example shows the various use cases.

Example - Usage of Projection in Collection in SpEL

Let's update the project created in Spring SpEL - Create Project chapter. We're updating following file −

  • MainApp.java − Main application to run and test.

MainApp.java

Here is the content of MainApp.java file −

package com.tutorialspoint;

import java.text.ParseException;

import org.springframework.expression.ExpressionParser;
import org.springframework.expression.common.TemplateParserContext;
import org.springframework.expression.spel.standard.SpelExpressionParser;

public class MainApp {
   public static void main(String[] args) throws ParseException, NoSuchMethodException, SecurityException {
      ExpressionParser parser = new SpelExpressionParser();
      String result=parser.parseExpression("Random number : #{T(java.lang.Math).random() * 100}", 
         new TemplateParserContext()).getValue(String.class);
      System.out.println(result);
   }
}

Output

Once you are done creating the source and bean configuration files, let us run the application. If everything is fine with your application, it will print the following message −

Random number : 43.15856974355583
Advertisements