- Spring SpEL - Home
- Spring SpEL - Overview
- Spring SpEL - Environment Setup
- Spring SpEL - Create Project
- Spring SpEL - Literal Expression
- Spring SpEL - Properties
- Spring SpEL - Array
- Spring SpEL - List
- Spring SpEL - Map
- Spring SpEL - Methods
- Spring SpEL - Relational Operators
- Spring SpEL - Logical Operators
- Spring SpEL - Mathematical Operators
- Spring SpEL - Assignment Operator
- Spring SpEL - Constructor
- Spring SpEL - Variables
- Spring SpEL - Functions
- Spring SpEL - Expression Templating
Spring SpEL Expression Evaluation
Spring SpEL Bean Configuration
Spring SpEL Language Reference
Spring SpEL Operators
Spring SpEL Special Operators
Spring SpEL Collections
Spring SpEL Other Features
Spring SpEL - Useful Resources
Spring SpEL - Map
SpEL expression supports accessing map.
Following example shows the various use cases.
Example - Usage of Maps in SpEL
Let's update the project created in Spring SpEL - Create Project chapter. We're adding/updating following files −
Employee.java − Employee class.
MainApp.java − Main application to run and test.
Employee.java
Here is the content of Employee.java file −
package com.tutorialspoint;
import java.util.Map;
public class Employee {
private Map<String, String> offices;
public Map<String, String> getOffices() {
return offices;
}
public void setOffices(Map<String, String> offices) {
this.offices = offices;
}
}
MainApp.java
Here is the content of MainApp.java file −
package com.tutorialspoint;
import java.text.ParseException;
import java.util.HashMap;
import java.util.Map;
import org.springframework.expression.EvaluationContext;
import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
import org.springframework.expression.spel.support.StandardEvaluationContext;
public class MainApp {
public static void main(String[] args) throws ParseException {
ExpressionParser parser = new SpelExpressionParser();
Employee employee = new Employee();
Map<String, String> officeMap = new HashMap();
officeMap.put("IN", "Hyderabad");
officeMap.put("UK", "London");
employee.setOffices(officeMap);
EvaluationContext employeeContext = new StandardEvaluationContext(employee);
// evaluates to "Hyderabad"
String city = parser.parseExpression("offices['IN']").getValue(employeeContext, String.class);
System.out.println(city);
}
}
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 −
Hyderabad
Advertisements