Community Tip - Did you get an answer that solved your problem? Please mark it as an Accepted Solution so others with the same problem can find the answer easily. X
I am getting nested exception java.lang.IllegalAccessError: tried to access field wt.method.MethodContext.sessionContext. my code snippet looks like
try {
MethodContext methodcontext = MethodContext.getContext();
if (methodcontext != null && methodcontext.sessionContext != null
&& methodcontext.sessionContext.toString().contains("authenticationName")){
return SessionHelper.manager.getPrincipal().getName();
} else {
return EMPTY_STRING;
}
} catch (Exception e) {
return EMPTY_STRING;
}
methodcontext.sessionContextgetting an error so couldn't even catch it, it is terminating flow of execution, I check the Apache Conf settings and all looks good. The logged in user is in session just getting an error on sessionContext. Any help around it would be appreciated.
Solved! Go to Solution.
I'm betting you took old customization code that was
If so, then that explains everything there is no such publicly accessible field in 10.2 M010. There is, however, a getSessionContext() method -- though it also is not a supported API currently.
[Unsupported APIs are subject to change at any time without notice.]
I'm betting you took old customization code that was
If so, then that explains everything there is no such publicly accessible field in 10.2 M010. There is, however, a getSessionContext() method -- though it also is not a supported API currently.
[Unsupported APIs are subject to change at any time without notice.]
It looks like you could get nearly the same result with
MethodContext.getContext().mbean.getUserName()
though this returns null rather than EMPTY_STRING when the user is not known.
Yes Jess, You are absolutely right, this is specific to 10.2 M010 release only. I did explored some API around this and could the SessionContext.getContext()
for 10.2 M010 API list, and same is not deprecated too. I used this and It did work as expected.
If what you want is the user name associated with the current method context, then the code snippet I gave should work as well.
SessionContext.getContext() is supported, but do note what the Javadoc says:
"Get current session context. Session context is determined by authentication information in the current Method context. If none exists, an unauthenticated session context will be established."
If you don't want the italicized piece to occur, then I'd go with "MethodContext.getContext().mbean.getUserName()" instead. If the method context will have an associated user by this point, then either approach should work just fine.
Jess, my intention is to check if any valid user is present in session(sessionContext) before accessing Principal to avoid null pointers, PTC told us that the sessionContext field in MethodContext has been made private in 10.2 M010 version, but we can access same by using public getter method. so instead methodContext.sessionContext we have to access session by calling this methodContext.getSessionContext(). Thanks for your help!