Featured post
c# - Asp MVC 2: Obfusicate Entity-IDs -
project type: asp mvc 2/nhibernate/c#
problem
if have edit page in web application come problem have send , receive id of entity you're editing, ids of sub-entities, entities can selected dropdownmenus,...
as possible modify form-post, evil user try send another id maybe grant him more rights (if i.e. id related security entity).
my approach
- create guid , associate id
- save association in http session
- wait response , extract real id out of received guid.
question:
what techniques use obfusicate entity-id?
if you're doing guids, why not use guids identity of entity that's stored in database (though i'd advise against it)?
or have server side encryption scheme encrypts , subsequently decrypts id (this long same lines you're doing except you're not storing random in session (yuck :) ).
you forget trying @ since lot of sites "affected" issue, , it's not problem (stackoverflow example). overhead much.
also, if you're worried security, why don't have sort of granular permissions set on individual action/even entity level. solve problems well.
edit:
another problem solution inconsistent unique identifiers. if user says "id as23423he423fsda has 'invalid' data", how know id belongs if it's changing on every request (assuming you're going change id in url well)? you'd much better of encryption algorithm hashes same value therefore, can perform lookup (if need it) , user has consistent identifiers.
- Get link
- X
- Other Apps
Comments
Post a Comment