13

Several databases I am familiar with provide functions or modules for encryption. Examples include dbms_crypto for oracle databases and built-in functions for MySQL.

Most of the commonly used programming languages have cryptography libraries available.

From a security perspective, are there any issues that would lead to choosing one over the other? Is one method highly preferable over the other?

AviD
  • 72,708
  • 22
  • 137
  • 218

3 Answers3

6

The algorithms provided are almost the same. The choice would depend on your use cases. Some things to consider:

  1. If the encryption is on the servers side, considering encryption at the client side to avoid cleartext transmission over the wire.
  2. Deciding on reversible or non-reversible encryption based on type of data.
  3. In the case of non-reversible encryption, is hashing just to avoid tampering or using hashing as a subsequent comparison?
Akber Choudhry
  • 809
  • 7
  • 12
  • Another consideration is the type of application. I would not recommend encrypting data for storage in a windows desktop application because it means making the key available to all machines / users. – pipTheGeek Dec 07 '12 at 16:53
3

If you want to do encryption, then the data to encrypt and the key used for encryption will need to be transferred to the machine which does the job. If you do the encryption on the front-end, then you do not have to "trust" the database, but this may make things more complex if you have multiple front-ends. If you do the encryption on the database, then an hostile hijack of the database will leave you naked; e.g. successful SQL injection attacks are even more devastating.

Generally speaking, if you want to make a security distinction between doing the crypto on the front-end or on the database, then you have to imagine a scenario where one is compromised and not the other. Conversely, if you consider both machines to be "equally robust", then your question is about performance only.

Thomas Pornin
  • 322,884
  • 58
  • 787
  • 955
-1

I think that in encryption in webapp we have some separation, which can aid security. Mainly you hacked db you have data, now you have to hack our app to decrypt the data. In db crypto we have single point of failure. Plus if you need some info about a signature/encryption in your application you, woudl choose application level encryption.

damiankolasa
  • 347
  • 1
  • 6