Spring AOP передать строковый аргумент метода контроллера - PullRequest
0 голосов
/ 14 мая 2019

У меня есть класс контроллера с одним методом RequestMapping, который принимает аргументы String.Я хочу передать этот аргумент с помощью Spring AOP, но при его сбое я получаю нулевое значение при печати значения.

Пробовал с приведенным ниже решением, но оно работает с картой, но не со строкой.

Аргумент прохода Spring AOP метода контроллера

@Controller
public class WelcomeController {
    @Autowired
    private FamilyService familyService;

    @RequestMapping(value = "/", method = RequestMethod.GET)
    public ModelAndView welcomePage(String welcomeMessage) {
        FamilyVO allFamilyMembers = familyService.getAllFamilyMembers();
        ModelAndView modelAndView = new ModelAndView("Index", "family", allFamilyMembers);
        List<String> familyMemberAges = new ArrayList<String>();
        for (int i = 0; i <= 100; i++) {
            familyMemberAges.add("" + i);
        }
        modelAndView.addObject("familyMemberAges", familyMemberAges);
        System.out.println(welcomeMessage);
        return modelAndView;
    }
}
@Component
@Aspect
public class WelcomeControllerAspect {
    @Before("execution(* com.kalavakuri.webmvc.web.controller.WelcomeController.welcomePage(..))")
    public void beforeWelcomePage(JoinPoint joinPoint) {
        joinPoint.getArgs()[0] = "Hellow";
        System.out.println(joinPoint.getArgs().length);
        System.out.println("Before welcomepage");
    }
}

Я ожидаю значение «Hello», когда я печатаю его в классе Controller, но печатает ноль.

Ответы [ 2 ]

0 голосов
/ 15 мая 2019

A @Before совет не предназначен для манипулирования параметрами метода. В приведенном вами примере это работает только потому, что аргумент является изменяемым объектом, а именно Map. String является неизменным, однако вы не можете его редактировать.

Сказав это, что вы должны делать? Используйте совет @Around, который был разработан для такого рода вещей. Там вы можете решить, как вы хотите продолжить, например,

  • вызов исходного метода с исходными параметрами,
  • вызов исходного метода с измененными параметрами,
  • сделать что-то до и / или после вызова оригинала,
  • не вызывать оригинальный метод, а вместо этого возвращать другой результат,
  • обработка исключений в исходном методе
  • или любое сочетание вышеперечисленного, которое имеет смысл (может быть, у вас есть несколько случаев и if-else или switch-case).

Я также предлагаю не работать напрямую с Object[] из JoinPoint.getArgs(), а связать соответствующие параметры метода с именованным и типобезопасным параметром рекомендации через args(). Попробуйте это:

package de.scrum_master.aspect;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;

@Component
@Aspect
public class WelcomeControllerAspect {
  @Around(
    "execution(* com.kalavakuri.webmvc.web.controller.WelcomeController.welcomePage(..)) && " +
    "args(welcomeMessage)"
  )
  public Object beforeWelcomePage(ProceedingJoinPoint joinPoint, String welcomeMessage) throws Throwable {
    System.out.println(joinPoint + " -> " + welcomeMessage);
    return joinPoint.proceed(new Object[] { "Hello AOP!" });
  }
}
0 голосов
/ 15 мая 2019

Вы должны использовать @Aroung совет вместо @Before.См. этот ответ для более подробной информации.

...