Quick jump |
Encryption allows you to encrypt important data in the database, such as credit card numbers or Social Security Numbers. You need to select the encryption method, enter the encryption key, and choose the fields to be encrypted.
Note: the Encryption feature is available only in the Enterprise Edition of ASPRunner.NET. See Editions Comparison.
Press the Encryption button on the Security screen to open the Encryption popup.
You can select a Database-based or Code-based encryption method.
Note: the Database-based encryption method is available only for MySQL, Oracle, PostgreSQL, and MS SQL Server databases.
The Database-based method is preferable since it has more features than the Code-based method. With the Database-based encryption, for example, the encrypted fields can be sorted and grouped, the search offers suggestions and includes all operators (CONTAINS, EQUALS, MORE THAN, etc.).
Database-based encryption requirements
PostgreSQL:
•install the pgcrypto module.
Oracle:
•give users full rights to the SYS.DBMS_CRYPTO package;
•the Oracle version must be 10 or higher.
MySQL:
•enable SSL support.
We recommend using the encryption key that is at least 10 characters long. You can also use the Generate button to generate a random key.
ASPRunner.NET can encrypt only text fields. Since the encrypted value usually is at least 2-3 times longer than source value, you should choose the maximum length fields such as TEXT in MySQL or MEMO in MS Access.
Note: ASPRunner.NET does not encrypt the existing data. Encryption is applied to the record during the Add/Edit operations.
Note: once the encrypted data is stored in the database, you should not change the encryption type and key, or deactivate the encryption, as the data will remain encrypted.
Here is an example of encrypted data in the application:
Functions used for database-based encryption
Oracle:
•Encryption: DBMS_CRYPTO.ENCRYPT()
•Decryption: DBMS_CRYPTO.DECRYPT()
MS SQL Server:
•Encryption: EncryptByPassPhrase(), EncryptByKey()
•Decryption: DecryptByPassPhrase(), DecryptByKey()
MySQL:
•Encryption: DES_ENCRYPT(), AES_ENCRYPT()
•Decryption: DES_DECRYPT(), AES_DECRYPT()
PostgreSQL:
•Encryption: pgp_sym_encrypt()
•Decryption: pgp_sym_decrypt()
Encrypting the existing data in the database
Note:
1. Before starting this procedure, make a backup of the database!
2. You may encrypt the existing values only once. We do not recommend double encryption as it causes problems with decryption.
3. After the encryption, it Is not always possible tell whether the data had been encrypted or not.
1. Before enabling encryption export your table data to CSV or Excel
2. Turn on the encryption
3. If this table has key columns selected, simply import the data back. It will update the existing data with encrypted values.
4. If this table doesn't have key columns selected then delete all the data first and then run the import.
MySQL, AES encryption
The key variable should contain the encryption key specified in ASPRunner.NET on the Encryption screen.
//define encryption key
string key="09a308862fbe462095dd6eba33ab9dd21b8fd35b0d884b48819a34ce8636983b";
string sql = "SELECT cast(AES_DECRYPT(unhex(customer_name), '" + key +"') as char) AS custname FROM customers_table WHERE id = 'CUST123'";
XVar rs = tDAL.CustomQuery(sql);
XVar data = CommonFunctions.db_fetch_array(rs)
MVCFunctions.Echo(data["custname"]);
More about security:
•CAPTCHA on authentication pages
See also: