Bài giảng Database systems - 8. Functional dependencies & normalization
Challenges of Database Security (2)
Database Survivability: Database systems
need to operate and continue their functions,
even with reduced capabilities, despite
disruptive events such as information warfare attacks.
Confinement.
Damage assessment.
Reconfiguration.
Repair.
Fault treatment.
110 trang |
Chia sẻ: vutrong32 | Lượt xem: 1304 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Bài giảng Database systems - 8. Functional dependencies & normalization, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
DATABASE SYSTEMS
Nguyen Ngoc Thien An
FUNCTIONAL DEPENDENCIES
& NORMALIZATION
Spring 2014
Contents
2
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Reading Suggestion: [1] Chapter 24
Contents
3
Introduction to Database Security
Database Security Issues
Threats to Databases
Countermeasures
Database Security Mechanisms
Database Security and the DBA
Access Protection, User Accounts, and Database
Audits
Sensitive Data
Database Security Issues
4
Legal and ethical issues: privacy issues.
Policy issues: what a government or
corporate entity allows or disallows.
System-related issues: handle a security
issue at hardware, OS, DBMS level.
The need to identify multiple security
levels: identify security levels and categorize
the data and users based on these
classifications (e.g.: top secret, secret,
confidential, and unclassified).
Threats to Databases
5
Threats: Any situation or event, whether
intentional or unintentional, that will adversely
affect a system and consequently an organization.
Threats to:
Computer systems.
Databases.
Threats to databases:
Loss of integrity.
Loss of availability.
Loss of confidentiality.
6
Threats to Computer Systems
7
Scope of Data Security Needs
•Must protect databases & the servers on which they reside
•Must administer & protect the rights of internal database
users
•Must guarantee the confidentiality of ecommerce
customers as they access the database
•With the Internet continually growing, the threat to data
traveling over the network increases exponentially
Contents
8
Introduction to Database Security
Database Security Issues
Threats to Databases
Countermeasures
Database Security Mechanisms
Database Security and the DBA
Access Protection, User Accounts, and Database
Audits
Sensitive Data
Countermeasures (1)
9
To protect databases against these types of
threats, four main kinds of countermeasures
(control measures) can be implemented:
Access control.
Inference control.
Flow control.
Data encryption.
Countermeasures (2)
10
Access Control
The security mechanism of a DBMS which must
include provisions for restricting access to the
database as a whole.
Authentication: a mechanism that determines
whether a user is who he or she claims to be.
Authorization: granting a right or privilege, which
enables a subject to legitimately have access to a
system or a system’s objects.
Access control is handled by creating user
accounts and passwords to control login process
by the DBMS.
Countermeasures (3)
11
Inference Control
The countermeasures to statistical database
security problem.
Statistical databases: used to provide statistical
information or summaries of values based on
various criteria.
Statistical database security must ensure:
Information about individuals cannot be accessed.
Cannot deduce or infer certain facts concerning
individuals from queries that involve only summary
statistics on groups.
Countermeasures (4)
12
Flow control
Prevent information from flowing in such a way
that it reaches unauthorized users.
Covert channels: channels that are pathways for
information to flow implicitly in ways that violate
the security policy of an organization.
Countermeasures (5)
13
Data encryption
Protect sensitive data (e.g.: credit card numbers)
that is being transmitted via some type
communication network.
The data is encoded using some encoding
algorithm.
An unauthorized user who access encoded data
will have difficulty deciphering it, but authorized
users are given decoding or decrypting algorithms
(or keys) to decipher data.
Contents
14
Introduction to Database Security
Database Security Issues
Threats to Databases
Countermeasures
Database Security Mechanisms
Database Security and the DBA
Access Protection, User Accounts, and Database
Audits
Sensitive Data
Database Security Mechanisms
15
A DBMS typically includes a database
security and authorization subsystem that
is responsible for ensuring the security
portions of a database against unauthorized
access.
Two types of database security mechanisms:
Discretionary security mechanisms.
Mandatory security mechanisms: users at certain
classifications can access certain data.
Database Security and the DBA (1)
16
The database administrator (DBA) is the
central authority for managing a database
system.
The DBA’s responsibilities include:
Granting privileges to users who need to use the
system.
Classifying users and data in accordance with the
policy of the organization.
The DBA is responsible for the overall security
of the database system.
Database Security and the DBA (2)
17
The DBA has a DBA account in the DBMS.
Also called a system or superuser account.
These accounts provide powerful capabilities such
as:
1. Account creation.
2. Privilege granting.
3. Privilege revocation.
4. Security level assignment.
Action 1 is access control, whereas 2 and 3 are
discretionary and 4 is used to control mandatory
authorization.
Access Protection, User Accounts,
and Database Audits (1)
18
Whenever a person or a group of persons
needs to access a database system, the
individual or group must first apply for a user
account.
The DBA will then create a new account id and
password for the user if if there is a legitimate
need to access the database.
The user must log in to the DBMS by entering
account id and password whenever database
access is needed.
Access Protection, User Accounts,
and Database Audits (2)
19
The database system must also keep track of
all operations on the database that are applied
by a certain user throughout each login
session.
Modify system log to keep a record of all updates
applied to the database and of the particular user
who applied each update.
System log includes an entry for each operation
applied to the database that may be required for
recovery from a transaction failure or system
crash.
Access Protection, User Accounts,
and Database Audits (3)
20
If any tampering with the database is
suspected, a database audit is performed.
A database audit consists of reviewing the log to
examine all accesses and operations applied to
the database during a certain time period.
A database log that is used mainly for security
purposes is sometimes called an audit trail.
Sensitive Data (1)
21
Sensitivity of data is a measure of the
importance assigned to the data by its owner
for the purpose of denoting its need for
protection.
Factors making data sensitive:
Inherently sensitive.
From a sensitive source.
Declared sensitive.
A sensitive attribute or sensitive record.
Sensitive in relation to previously disclosed data.
Sensitive Data (2)
22
Information Security vs. Information Privacy:
Information Security: refer to many aspects of
protecting a system from unauthorized use,
including authentication of users, information
encryption, access control, firewall policies, and
intrusion detection.
Information Privacy: the ability of individuals to
control the terms under which their personal
information is acquired and used.
Privacy Issues and Privacy Preservation.
Contents
23
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Contents
24
Discretionary Access Control
Account Level Privileges
Relation Level Privileges
Use Views
Propagation of Privileges
Trojan Horse Example
DAC
25
Discretionary Access Control (DAC)
The typical method of enforcing discretionary access
control in a database system is based on the
granting and revoking privileges.
User can protect what they own.
Owners, DBA or selected users may grant access to others.
Owners, DBA or selected users can define the types of
access (read/write/execute/) given to others.
In SQL:
Use GRANT statement for granting privileges.
Use REVOKE statement for revoking privileges.
DAC - Types of Privileges
26
Types of discretionary privileges:
The account level (or system level)
At this level, the DBA specifies the particular privileges
that each account holds independently of the relations
in the database.
The relation level (or table level)
At this level, the DBA can control the privilege to
access each individual relation or view in the
database.
DAC - Account Level
27
The privileges at the account level apply to the
capabilities provided to the account itself.
E.g.:
The CREATE SCHEMA or CREATE TABLE privilege, to
create a schema or base relation.
The CREATE VIEW privilege.
The ALTER privilege, to apply schema changes such
adding or removing attributes from relations.
The DROP privilege, to delete relations or views.
The MODIFY privilege, to insert, delete, or update tuples.
The SELECT privilege, to retrieve information from the
database by using a SELECT query.
DAC - Relation Level (1)
28
Privileges at the relation level specify for each user
the individual relations on which each type of
command can be applied.
Some privileges also refer to individual columns (attributes)
of relations.
Access Matrix Model: an authorization model for
discretionary privileges.
The rows of a matrix M represent subjects (users,
accounts, programs).
The columns represent objects (relations, records,
columns, views, operations).
Each position M(i,j) in the matrix represents the types of
privileges (read, write, update,) that subject i holds on
object j.
DAC - Relation Level (2)
29
O1 Oi Om
S1 A[s1,o1] A[s1,oi] A[s1,om]
Si A[si,o1] A[si,oi] A[si,om]
Sn A[sn,o1] A[sn,oi] A[sn,om]
DAC - Relation Level (3)
30
To control the granting and revoking of relation
privileges, for each relation R in a database:
Its owner is given all privileges on that relation.
The owner account holder can pass privileges on
any of the owned relation to other users by
granting privileges to their accounts.
The owner account holder can also take back the
privileges by revoking privileges from their
accounts.
DAC - Relation Level (4)
31
Types of privileges can be granted on each
relation R:
SELECT (retrieval or read) privilege:
Give the retrieval privilege to the account .
The SELECT statement is used to retrieve tuples from R.
MODIFY privileges on R:
Give the account the capability to modify tuples of R.
Divided into UPDATE, DELETE, and INSERT privileges to
apply the corresponding SQL command to R.
INSERT and UPDATE privileges can be granted on only
certain attributes.
DAC - Relation Level (5)
32
Types of privileges can be granted on each
relation R (cont.):
REFERENCES privilege on R:
Give the account the capability to reference relation R
when specifying integrity constraints.
The privilege can also be restricted to specific
attributes.
Notice: to create a view, the account must
have SELECT privilege on all relations
involved in the view definition.
Contents
33
Discretionary Access Control
Account Level Privileges
Relation Level Privileges
Use Views
Propagation of Privileges
Trojan Horse Example
DAC - Use Views
34
Specifying privileges through the use of views is an
important discretionary authorization mechanism in its
own right.
E.g.:
If the owner A of a relation R wants another account B to
be able to retrieve only some fields of R,then A can create
a view V of R that includes only those attributes and then
grant SELECT on V to B.
The same applies to limiting B to retrieving only certain
tuples of R. A view V’ can be created by defining the view
by means of a query that selects only those tuples from R
that A wants to allow B to access.
Contents
35
Discretionary Access Control
Account Level Privileges
Relation Level Privileges
Use Views
Propagation of Privileges
Trojan Horse Example
DAC - Propagation of Privileges (1)
36
Propagation of account level privileges:
Whenever an authorized user A grants an account
level privilege to a user B, this privilege can be given
to B with or without the ADMIN OPTION.
If the ADMIN OPTION is given, this means that B can
also grant that privilege to other accounts with or
without ADMIN OPTION.
User A does not know about the propagation of that
privilege to other users.
If the privilege is revoked from B, then accounts who
have received that privilege from B still hold that
privilge.
DAC - Propagation of Privileges (2)
37
Propagation of relation level privileges:
Whenever an authorized user A grants a privilege on
a relation R to a user B, this privilege can be given to
B with or without the GRANT OPTION.
If the GRANT OPTION is given, this means that B can
also grant that privilege on R to other accounts with or
without GRANT OPTION.
User A does not know about the propagation of that
privilege on R to other users.
If the privilege on R is revoked from B, then that
privilege on R is also revoked automatically from
accounts who have received it from B.
DAC - Propagation of Privileges (3)
38
DAC - Propagation of Privileges (4)
39
Techniques to limit the propagation of
privileges have been developed, although they
have not yet been implemented in most
DBMSs and are not a part of SQL.
Limiting horizontal propagation to an integer
number i means that an account B given the
GRANT OPTION can grant the privilege to at
most i other accounts.
Limiting vertical propagation is more
complicated. It limits the depth of the granting of
privileges.
DAC - Propagation of Privileges (5)
40
Limit
horizontal
propagation
DAC - Propagation of Privileges (6)
41
Limit
vertical
propagation
DAC - An Example (1)
42
Suppose that the DBA creates 4 accounts: A1, A2,
A3, A4.
For only A1 to be able to create base relations, DBA
must issue the following GRANT command in SQL:
GRANT CREATETAB TO A1;
DBA creates schema EXAMPLE and grants privileges
on it to A1:
CREATE SCHEMA EXAMPLE AUTHORIZATION A1;
DAC - An Example (2)
43
A1 can create tables under the schema
EXAMPLE.
A1 creates the 2 relations EMPLOYEE and
DEPARTMENT so that A1 is the owner of
these relations and hence have all the relation
privileges on each of them.
DAC - An Example (3)
44
A1 wants to grant A2 the privilegea to insert and
delete tuples in both of these relations but does not
want A2 to be able to propagate these privileges to
other accounts:
GRANT INSERT, DELETE
ON EMPLOYEE, DEPARTMENT TO A2;
A1 wants to allow A3 to retrieve information from
either of the two tables and also to be able to
propagate the SELECT privilege to other accounts.
GRANT SELECT ON EMPLOYEE, DEPARTMENT
TO A3 WITH GRANT OPTION;
DAC - An Example (4)
45
A3 can grant the SELECT privilege on the
EMPLOYEE relation to A4:
GRANT SELECT ON EMPLOYEE TO A4;
Notice that A4 cannnot propagate the SELECT
privilege because GRANT OPTION was not
given to A4.
DAC - An Example (5)
46
A1 decides to revoke the SELECT privilege on
EMPLOYEE from A3:
REVOKE SELECT ON EMPLOYEE FROM A3;
The DBMS must now automatically revoke the
SELECT privilege on EMPLOYEE from A4,
because A3 granted that privilege to A4 and A3
does not have the privilege any more.
DAC - An Example (6)
47
A1 wants to give back A3 a limited capability to
SELECT from the EMPLOYEE relation and allow A3
to be able to propagate the privilege.
The limitation is to retrieve only the NAME, BDATE, and
ADDRESS attributes and only for the tuples with DNO = 5.
A1 then creates the view:
CREATE VIEW A3_EMPLOYEE AS
SELECT NAME, BDATE, ADDRESS
FROM EMPLOYEE WHERE DNO = 5;
After the view is created, A1 can grant SELECT on the
view A3_EMPLOYEE to A3 as follows:
GRANT SELECT ON A3_EMPLOYEE
TO A3 WITH GRANT OPTION;
DAC - An Example (7)
48
A1 wants to allow A4 to update only the SALARY attribute of
EMPLOYEE:
GRANT UPDATE ON EMPLOYEE (SALARY) TO
A4;
The UPDATE and INSERT privileges can specify particular
attributes that may be updated or inserted in a relation.
Other privileges (SELECT, DELETE) are not attribute specific.
Contents
49
Discretionary Access Control
Account Level Privileges
Relation Level Privileges
Use Views
Propagation of Privileges
Trojan Horse Example
DAC
50
Advantages
Govern the access to the information on the basic of
discretionary protection policies flexible.
Suitable for various types of systems and applications.
Be widely used in a variety of implementations, especially
in the commercial and industrial environments.
Disadvantages
The main drawback is vulnerability to malicious attacks:
Allow information from an object which can be read by a
subject to be written to any other objects.
E.g.: Bob is denied access to file A, so he asks cohort Alice to copy A
to B that he can access.
Suppose the users are trusted not to do this deliberately, it is
still possible for Trojan Horses to copy information from one
object to another.
Trojan Horse Example (1)
51
Trojan Horse Example (2)
52
Trojan Horse Example (3)
53
Contents
54
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Contents
55
Mandatory Access Control
Bell-LaPadula Model
Multilevel Relation
Comparing DAC and MAC
MAC - Introduction
56
DAC has traditionally been the main security
mechanism for relational database systems.
All-or-nothing method: A user either has or does not
have a certain privilege.
Mandatory Access Control (MAC)
Applied to large amounts of information requiring
strong protect in environments where both the system
data and users can be classified clearly.
A mechanism for enforcing multiple level of security:
classify data and users based on security classes.
It would typically be combined with the DAC.
MAC - Bell-LaPadula Model
57
Bell-LaPadula Model
Common multilevel security model.
Classify each subject (user, account, program)
and object (relation, tuple, column, view,
operation) into one security classification.
Class(S): clearance (classification) of a subject S.
Reflect the user’s degree of trust.
Class(O): classification of an object O.
Reflect the sensitivity of the information.
Grant access to data based on subject clearance
and object classification.
Principles: no read-up & no write-down secrecy.
MAC - Classification Levels
58
Typical classification levels are:
Top secret (TS)
Secret (S)
Confidential (C)
Unclassified (U)
Where TS is the highest level and U is the
lowest:
TS ≥ S ≥ C ≥ U
MAC - Properties
59
Simple security property (ss-property): A subject S
is not allowed to read an object O unless
class(S) ≥ class(O)
No read-up
Star property (or * property): A subject S is not
allowed to write an object O unless
class(S) ≤ class(O)
No write-down
These restrictions together ensure that there is no
direct flow of information from high secure objects to
low ones!!!
MAC - Why Star Property? (1)
60
MAC - Why Star Property? (2)
61
MAC - Why Star Property? (3)
62
Contents
63
Mandatory Access Control
Bell-LaPadula Model
Multilevel Relation
Comparing DAC and MAC
MAC - Multilevel Relation (1)
Multilevel relation: MAC + relational database model
Deal with multilevel data.
Data objects: attributes, tuples.
A multilevel relation is represented by a schema:
R (A1,C1,A2,C2, , An,Cn,TC)
Each data attribute Ai is associated with a classification
attribute Ci .
Each tuple is associated with a tuple classification attribute
TC.
TC is equal to the highest of all attribute classification
values.
The apparent key of a multilevel relation is the set of
attributes that would have formed the primary key in a regular
(single-level) relation.
64
MAC - Multilevel Relation (2)
65
Subjects with different classes may retrieve
data from a multilevel relation but will see
different versions that data.
EMPLOYEE S > C > U
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
MAC - Multilevel Relation (3)
66
A user with security level S
EMPLOYEE S > C > U
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
SELECT * FROM EMPLOYEE
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
MAC - Multilevel Relation (4)
67
A user with security level C
EMPLOYEE S > C > U
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
SELECT * FROM EMPLOYEE
Smith U 40000 C Null C C
Brown C Null C Good C C
MAC - Multilevel Relation (5)
68
A user with security level U
EMPLOYEE S > C > U
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
SELECT * FROM EMPLOYEE
Smith U Null U Null U U
MAC - Multilevel Relation (6)
A multilevel relation appears to contain
different data to subjects with different
clearance levels.
It may store a single tuple at a higher
classification level and produce the corresponding
tuples at lower-level classifications through a
process known as filtering.
Sometimes it must store two or more tuples at
different classification levels with the same
apparent key value.
69
MAC - Multilevel Relation (7)
70
Integrity rules for multilevel relation:
Entity integrity.
Null integrity and interinstance integrity.
Polyinstantiation.
MAC - Multilevel Relation (8)
71
Entity integrity
All attributes that are members of the apparent key:
Must not be null.
And must have the same security classification within each
individual tuple.
All the other attribute values in the tuple:
Must have a security classification greater than or equal to
that of the apparent key.
This constraint ensures that a user can see the key if
the user is permitted to see any part of the tuple at all.
MAC - Multilevel Relation (9)
72
Null integrity and interinstance integrity
Ensure that if a tuple value at some security level
can be filtered (derived) from a higher-classified
tuple, then it is sufficient to store the higher-
classified tuple in the multilevel relation.
Polyinstantiation
Where several tuples can have the same
apparent key value but have different attribute
values for users at different classification levels.
MAC - Multilevel Relation (10)
73
A user with security level C
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Brown C 80000 S Good C S
Smith U 40000 C Null C C
Brown C Null C Good C C
A user with security level C tries to update the value of
JobPerformance of Smith to ‘Excellent’:
UPDATE EMPLOYEE
SET JobPerformance = ‘Excellent’
WHERE Name = ‘Smith’;
Errors?
MAC - Multilevel Relation (11)
74
Name Salary JobPerformance TC
Smith U 40000 C Fair S S
Smith U 40000 C Excellent C C
Brown C 80000 S Good C S
Contents
75
Mandatory Access Control
Bell-LaPadula Model
Multilevel Relation
Comparing DAC and MAC
DAC vs. MAC
76
Mandatory policies:
Ensure a high protection degree by preventing
any illegal flow of information.
Being too rigid Only applicable in limited
environments.
Discretionary policies:
Offer a better trade-off between security and
applicability.
Be preferred in many practical situations.
Contents
77
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
RBAC (1)
78
Role-Based Access Control (RBAC)
A viable alternative to traditional DAC and MAC.
Emerged rapidly in the 1990s as a proven
technology for managing and enforcing security in
large-scale enterprisewide systems.
Many DBMSs have allowed the concept of roles,
where privileges can be assigned to roles.
RBAC (2)
79
Role-Based Access Control (RBAC)
Permissions are associated with roles, and users
are assigned to appropriate roles.
Roles can be created using the CREATE ROLE
and DESTROY ROLE commands.
The GRANT and REVOKE commands are used
to assign and revoke privileges from roles.
Role hierarchy in RBAC is a natural way of
organizing roles to reflect the organization’s lines
of authority and responsibility.
Contents
80
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Contents
81
Encryption & Public Key Infrastructure (PKI)
Terminology
Classification
DES, AES, RSA
Digital Signatures
Public Key Infrastructure
Encryption - Terminology
82
Encryption / Decryption: the process of the making /
breaking of “secret codes”.
Cipher: an algorithm for performing encryption or
decryption.
Plaintext: a message input needing protecting. It may
or may not be intelligible.
Ciphertext: the result of encryption performed on
plaintext.
Cryptosystem = encryption + decryption algorithms.
Encryption and decryption processes need keys.
Encryption - Classification (1)
Symmetric cryptosystems: 𝐾𝐸 = 𝐾𝐷
Asymmetric cryptosystems: 𝐾𝐸 ≠ 𝐾𝐷
83
Cryptosystem
Hello,
This content is
confidential
...................
01000100..
.
À¿¾«§¶
..
Encryption
Decryption
KE
KD
Plaintext Ciphertext
Encryption - Classification (2)
84
Asymmetric cryptosystems
Also called Public-key cryptosystems.
Use two different keys for (en/de)cryption algorithms.
Public key & Private key.
More secure but expensive in terms of computational
costs.
Symmetric cryptosystems
Use the same key for (en/de)cryption algorithms.
Symmetric key = Shared-secret-key.
Faster than encryption and decryption in public-key
cryptosystems.
Less security comparing to encryption and decryption in
public-key cryptosystems.
Encryption - Classification (3)
Symmetric cryptosystems:
Stream ciphers: A5/1, RC4.
Block ciphers: DES, Triple DES, AES.
Asymmetric cryptosystems:
RSA, DSA.
Secret Key Establishment.
Digital Signatures.
Digital Certificate.
85
Contents
86
Encryption & Public Key Infrastructure (PKI)
Terminology
Classification
DES, AES, RSA
Digital Signatures
Public Key Infrastructure
Encryption - DES
87
DES (Data Encryption Standard)
Published by the USA’s National Bureau of Standards
(NBS).
Be used as the encryption standard for unclassified data
(information not concerned with national security).
A message is divided into 64-bit blocks.
Key: 56 bits Brute-force (exhaustive key search) attack
in some hours Today, it’s too small.
Triple DES: run the DES algorithm a multiple number
of times using different keys
Encryption: 𝒄 ← 𝓔𝒌𝟏(𝓓𝒌𝟐(𝓔𝒌𝟏(𝒎)))
Decryption: 𝒎 ← 𝓓𝒌𝟏(𝓔𝒌𝟐(𝓓𝒌𝟏(𝒄)))
The triple DES can also use three different keys.
Encryption - AES
88
AES (Advanced Encryption Standard / Rijndael)
Chosen and introduced by the National Institute of
Standards and Technology (NIST) (known as NBS before).
Be secure and can be implemented efficiently.
The new encryption standard to replace for DES and
multiple encryption (as Triple DES)
Reduce the cost of managing keys.
Simplify the design of security protocols and systems.
A block cipher with a variable block size and variable key
size.
The key size and the block size can be independently
specified to 128, 192 or 256 bits
The enlarged and variable key and data-block sizes can
accommodate a wide spectrum of security strengths for
various application needs.
Encryption - RSA
89
RSA (named after 3 inventors Rivest, Shamir
and Adleman)
Public key is used for encrytion.
Private key is used for decrytion.
Encryption - Hybrid Scheme
90
Hybrid scheme
Asymmetric technique: establish a symmetric key.
Symmetric technique: encrypt data by that
symmetric key.
Sender Receiver
Encrypted message
using a symmetric key
Use public key of receiver
to encrypt the message
encryption key
Contents
91
Encryption & Public Key Infrastructure (PKI)
Terminology
Classification
DES, AES, RSA
Digital Signatures
Public Key Infrastructure
Digital Signatures (1)
92
Digital Signature: a message signed with a user's
private key and can be verified by anyone who has
access to the user's public key.
Thus:
Authentication: Anyone with the user’s public key can verify
his digital signature Easy to verify who is the owner of
the message.
Data integrity: The message cannot be modified without
being detected during decryption time Verify whether
the message is modified or not.
Non-repudiation: Only the holder of the private key can
digitally sign Prevent the sender from claiming that he
did not actually send the information.
Digital Signatures (2)
93
Simple Digital Signatures
Digital Signatures (3)
94
Secure Digital Signatures
Contents
95
Encryption & Public Key Infrastructure (PKI)
Terminology
Classification
DES, AES, RSA
Digital Signatures
Public Key Infrastructure
Public Key Infrastructure (1)
96
Public Key Infrastructure (PKI)
The sum total of everything required to securely use
public key crypto.
Digital Certificate
Also called Identity Certificate, or Public Key
Certificate.
An electronic document which is used to verify that a
public key belongs to an individual.
Use a digital signature to bind a public key with an
identity.
In most situations the certificate must be signed by a
Certificate Authority (CA), which acts as a trusted
third party.
Public Key Infrastructure (2)
97
Each digital certificate contains basic information:
The owner’s identity: information such as the name of a person or an
organization, their address or their server address, and so forth.
The owner’s public key.
The date of issue of the certificate.
Valid time (‘Valid From’ and ‘Valid To’ dates).
Name and URL of the CA.
The digital signature of the issuing CA.
CA
Public Key Infrastructure (3)
98
Sender S Receiver R
Certificate Authority
(CA)
Encrypted message
using a symmetric key
Use R’s public key to
encrypt the message
encryption key
3 - Send data 4 - Receive
data &
decrypt it
TRUSTED
How does PKI work?
Public Key Infrastructure (4)
99
A digital certificate can be revoked if:
Its private key is compromised.
The relationship of the public key and the
owner is changed.
A certificate was issued in error.
Use the Certificate Revocation List.
The largest commercial source for certificates
is VeriSign.
Contents
100
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Common Attacks on Databases
101
Some of quite frequent attacks on databases:
Unauthorized Privilege Escalation.
Privilege Abuse.
Denial of Service (DOS attack).
Weak Authentication.
SQL Injection.
Contents
102
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
SQL Injection (1)
103
SQL Injection Attack
Web programs and applications that access a
database can send commands and data to the
database.
The attacker injects a string input through the
application, which changes or manipulates the
SQL statement to the attacker’s advantage.
Most commonly done directly through web forms, but
can be directed through URL hacking.
SQL Injection (2)
104
SQL Injection
Exploit a security vulnerability in application.
Authentication bypass, information disclosure,
compromised data integrity.
Harm the database
Unauthorized manipulation of the database, or
retrieval of sensitive data.
Execute system level commands that may cause
the system to deny service to the application.
SQL Injection (3)
105
Consider an embedded code:
$query = “SELECT prodinfo FROM prodtable
WHERE prodname = ‘ “$_INPUT(‘prod_search’)” ’ ”
User enters the following:
blah’ OR ‘x’ = ‘x’
SQL statement created:
SELECT prodinfo FROM prodtable WHERE
prodname = ‘blah’ OR ‘x’ = ‘x’;
SQL Injection (4)
106
A more serious problem, a user enters:
blah'; DROP TABLE prodinfo;
SQL statement created:
SELECT prodinfo FROM prodtable WHERE
prodname = ‘blah’; DROP TABLE prodtable;
Another example:
SELECT * FROM Users WHERE username =
‘John’ and (PASSWORD = ‘JohnPass’ or ‘x’ = ‘x’);
Contents
107
Introduction to Database Security
Discretionary Access Control (DAC)
Mandatory Access Control (MAC)
Role-Based Access Control (RBAC)
Encryption & Public Key Infrastructure (PKI)
Common Attacks on Databases
SQL Injection
Challenges of Database Security
Challenges of Database Security (1)
108
Data Quality
Need techniques and organizational solutions to
assess and attest the quality of data.
Need techniques providing more effective integrity
semantics verification.
Need tools for the assessment of data quality.
Intellectual Property Rights
Digital watermarking techniques.
Challenges of Database Security (2)
109
Database Survivability: Database systems
need to operate and continue their functions,
even with reduced capabilities, despite
disruptive events such as information warfare
attacks.
Confinement.
Damage assessment.
Reconfiguration.
Repair.
Fault treatment.
Q & A
110
Các file đính kèm theo tài liệu này:
- 8_database_security_861.pdf