Wednesday, July 18, 2018

Is it a good practice to nullifying String in java




I have a problem with storing a plain password in memory as a String. According to the reference, since Strings are immutable there is a vulnerability of using String data type for sensitive data storing in memory.



https://www.geeksforgeeks.org/use-char-array-string-storing-passwords-java/




Why is char[] preferred over String for passwords?



Can I overcome this security issue by nullifying the string variable instead of using char array or String buffer/builder.



eg : String password="password";
password = null;


Answer



No. Nullifying a string would only delink the reference. But the value will still exist in string pool. Because to conserve memory, string values are retained in the string pool.



Any potential hacker, can retrieve the value by gaining access to the string pool.




Whereas, using char[], you can simply treat that object as any other object. And nullifying the char object will wipe off the data from heap at the time of garbage collection.



An even better option will be using a byte array.



Read more about String Constant pool.


No comments:

Post a Comment

plot explanation - Why did Peaches' mom hang on the tree? - Movies & TV

In the middle of the movie Ice Age: Continental Drift Peaches' mom asked Peaches to go to sleep. Then, she hung on the tree. This parti...