Получение NullPointerException при получении свойства из хранилища в ATG
Я пытаюсь получить свойства, такие как имя и фамилия, из репозитория профиля, отображая его в jsp, используя дроплет. Ниже приведен мой пример кода: SampleDroplet.java
public class SampleDroplet extends DynamoServlet {
private Repository mProfileRepository;
@Override
public void service(DynamoHttpServletRequest pReq, DynamoHttpServletResponse pRes)
throws ServletException, IOException {
String lFirstName = null;
String lLastName = null;
String lProfileId = pReq.getParameter("profileId");
try {
RepositoryItem lItem = getProfileRepository().getItem(lProfileId, "user");
lFirstName = (String) lItem.getPropertyValue("firstName");
lLastName = (String) lItem.getPropertyValue("lastName");
} catch (RepositoryException e) {
e.printStackTrace();
}
pReq.setParameter("firstName", lFirstName);
pReq.setParameter("lastName", lLastName);
pReq.serviceParameter("output", pReq, pRes);
}
SampleDroplet.properties
$class=com.tap.droplet.SampleDroplet
scope=global
profileRepository=/atg/userProfiling/ProfileAdaptarRepository
SampleDroplet.jsp
<dsp:page>
<dsp:importbean bean="/atg/userprofiling/Profile" var="profile" />
<dsp:importbean bean="/com/tap/droplet/SampleDroplet" />
<dsp:getvalueof var="profileId" bean="Profile.id"/>
<dsp:droplet name="SampleDroplet">
<dsp:param name="profileId" value="${profileId}" />
<dsp:oparam name="output">
Profile's First Name : <dsp:valueof param="firstName"/>
Last Name : <dsp:valueof param="lastName"/>
</dsp:oparam>
</dsp:droplet>
</dsp:page>
Я попытался отобразить profileId в JSP, он работает. Но когда я передал его капле, это показывает NullPointerException
java.lang.NullPointerException
at com.tap.droplet.SampleDroplet.service(SampleDroplet.java:26)
at atg.servlet.DynamoServlet.service(DynamoServlet.java:152)
at atg.taglib.dspjsp.DropletTag.invokeServlet(DropletTag.java:420)
at atg.taglib.dspjsp.DropletTag.doAfterBody(DropletTag.java:705)
at jsp_servlet._test._droplet.__sampledroplet._jsp__tag18(__sampledroplet.java:874)
Truncated. see log file for complete stacktrace
Если кто-нибудь знает, в чем проблема, пожалуйста, помогите мне.
заранее спасибо
1 ответ
Похоже, проблема здесь:
profileRepository=/atg/userProfiling/ProfileAdaptarRepository
Ядро не может найти этот компонент:
- "userprofiling" должен быть в нижнем регистре.
- ProfileAdaptarRepository -> ProfileAdapterRepository