Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.databases.ms-sqlserver > #1143
| From | Erland Sommarskog <esquel@sommarskog.se> |
|---|---|
| Newsgroups | comp.databases.ms-sqlserver, microsoft.public.sqlserver, microsoft.public.sqlserver.misc, microsoft.public.sqlserver.programming |
| Subject | Re: encrypt, not encrypt, why encrypt and how encrypt? |
| Followup-To | comp.databases.ms-sqlserver |
| Date | 2012-06-21 23:27 +0200 |
| Organization | Erland Sommarskog |
| Message-ID | <XnsA079EEA297B81Yazorman@127.0.0.1> (permalink) |
| References | <s72dnZ1liZTN8n7SnZ2dnUVZ8kOdnZ2d@brightview.co.uk> |
Cross-posted to 4 groups.
Followups directed to: comp.databases.ms-sqlserver
Mojo (please@dont.spam.com) writes: > Now I started to use an old Base64 encryption with a key bit of code > that I've had for a bit, but somebody told me that base64 just converts > the text into a better transport method rather than actually encrypting > it and its easy to hack, but I've put a long key in and it doesn't seem > to convert back and forth properly without knowing the key - are they > right?? Should I be using something else? I have never dived into Base64, but I have always thought of it as an encoding to make sure that binary data is not destroyed in transport. Maybe there is a key, but it is not likely to be a very strong encryption. And if you are going to encrypt, you might as well use somthing strong like RSA1024. > Having started to encrypt certain parts, eg a person's name, dob, etc, > it suddenly dawned on me that although I'm encrypting and decrypting as > I go if I want to do search queries then it ain't gonna work. For > example if I want to find all the people with 'gar' in their name then > this isn't going to work and if I want to find all the people who are > born between Apr and May then this isn't either. Yes, encryption comes with quite a cost in terms of reduced flexibility. Microsoft has a solution that circumvents the problem: Transperant Data Encryption. With TDE, the application can access the database and see all data as normal data. But if someone gets hold of the database file or the backup, all the thief sees is garbage. There is however quite a serious catch for you: TDE is only available in Enterprise Edition, which is quite different from Express in a budget perspective. SQL Server also offer encryption functions so that you can encrypt a column value - and this is avilable in Express. But then you will face the issues you mention above. The conclusion is that you should only encrypt data that is really sensitive like credit card numbers. If you need to search on encrypted columns, you can add a column with a strong one-way hash of the value. Then you can search on the hash. Of course, that only works if you search for the full value. -- Erland Sommarskog, SQL Server MVP, esquel@sommarskog.se Links for SQL Server Books Online: SQL 2008: http://msdn.microsoft.com/en-us/sqlserver/cc514207.aspx SQL 2005: http://msdn.microsoft.com/en-us/sqlserver/bb895970.aspx
Back to comp.databases.ms-sqlserver | Previous | Next — Previous in thread | Find similar
encrypt, not encrypt, why encrypt and how encrypt? "Mojo" <please@dont.spam.com> - 2012-06-21 20:00 +0100 Re: encrypt, not encrypt, why encrypt and how encrypt? Erland Sommarskog <esquel@sommarskog.se> - 2012-06-21 23:27 +0200
csiph-web