<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body bgcolor="#ffffff" text="#000000">
While working on a unrelated issue, i noticed that the serialVersionUID
of org.jboss.security.SimplePrincipal (in jbosssx.jar) has changed
between JBossAS5.0 GA and the current 5.0 branch. The 5.0 branch uses
2.0.2.SP6 version of jbosssx.jar whereas JBossAS5.0 GA uses 2.0.2.SP3.
Between these versions, the serialVersionUID of the SimplePrincipal
class has changed from <br>
<br>
private static final long serialVersionUID = 1L; // In 2.0.2.SP3<br>
<br>
to <br>
<br>
private static final long serialVersionUID = 7701951188631723261L; //
In 2.0.2.SP6<br>
<br>
As a result JBossAS-5.0 GA clients (ex: servlets on JBossAS-5.0 GA)
fail against JBossAS-5.0.1.GA server (current 5.0 branch) when doing
the following:<br>
<br>
import org.jboss.security.client.SecurityClient;<br>
import org.jboss.security.client.SecurityClientFactory;<br>
<br>
// psuedo code - do login<big><big><big><br>
<small><small> </small></small></big></big></big>
SecurityClient securityClient =
SecurityClientFactory.getSecurityClient();<br>
securityClient.setSimple("jai", "pass");<br>
securityClient.login();<br>
<br>
// lookup bean hosted on 5.0.1 GA<br>
Properties props = new Properties();<br>
props.put(Context.INITIAL_CONTEXT_FACTORY,
"org.jnp.interfaces.NamingContextFactory");<br>
props.put(Context.PROVIDER_URL,"jnp://localhost:1199");<br>
Context ctx = new InitialContext(props);<br>
<br>
MySecureBean bean = (MySecureBean) ctx.lookup("MySecureBean");<br>
System.out.println("Got bean");<br>
bean.doSomethingSecure("jai", 2);<br>
<br>
<br>
12:33:51,261 ERROR [STDERR] Caused by: java.io.InvalidClassException:
org.jboss.security.SimplePrincipal; local class incompatible: stream
classdesc serialVersionUID = 1, local class serialVersionUID =
7701951188631723261<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:546)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1552)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1466)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1699)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1305)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1908)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1832)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1719)<br>
12:33:51,261 ERROR [STDERR] at
java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1305)<br>
<br>
... // trimmed most of the unrelevant logs<br>
12:33:51,264 ERROR [STDERR] at
org.jboss.ejb3.proxy.handler.ProxyInvocationHandlerBase.invoke(ProxyInvocationHandlerBase.java:261)<br>
12:33:51,264 ERROR [STDERR] at
org.jboss.ejb3.proxy.handler.session.SessionSpecProxyInvocationHandlerBase.invoke(SessionSpecProxyInvocationHandlerBase.java:101)<br>
12:33:51,264 ERROR [STDERR] at $Proxy95.doSomething(Unknown Source)<br>
12:33:51,264 ERROR [STDERR] at
org.myapp.servlet.SimpleServlet.doPost(SimpleServlet.java:40)<br>
<br>
The other way (5.0.1 GA clients against 5.0 GA server) fails too. From
SVN logs, it appears that the serialVersionUID change was meant for
compatibility with external tools like JBoss Tools. Any way to make
5.0.1.GA and 5.0 GA compatible?<br>
<br>
On a related note, in the component-matrix for Branch_5_x is see that
the jbosssx package is still at 2.0.2.SP3:<br>
<br>
<version.org.jboss.security>2.0.2.SP3</version.org.jboss.security><br>
<br>
It's only upgraded to 2.0.2.SP6 in 5.0 branch. <br>
<br>
regards,<br>
-Jaikiran <br>
<br>
</body>
</html>