Just curious about how jaxb works, I have a class annotated as follows:
@XmlRootElement(name = "MyJaxb")
Class MyJaxb
{
@XmlElement
protected String str;
public void setStr(String str)
{
this.str = str;
}
}
The access modifier of field str is protected, why Jaxb can still marshall and unmarshall it?
Beyond answer that reflection can by-pass checks (which is correct), this is also something that other JDK internal parts need, specifically default Object serialization and deserialization. In general this is allowed because many tools benefit from such access. And like others have correctly pointed out, access rights are not meant as real security barriers. They are there to help programmers design abstractions properly, make it easier to come up with good designs.
It uses reflection. A
protected
orprivate
field or method can be accessed using the reflection API (usingsetAccessible(true)
on the appropriateField
orMethod
object).Remember -
public
,protected
andprivate
are controls on default visibility, nothing more. They do not (and cannot) prevent access using reflection.