Friday, March 29, 2019
The Data Inscription Standard Computer Science Essay
The Data Inscription Standard calculator Science EssayWhenever information is exchanged electronically legion(predicate) multiplication the privacy of the information is a require. encoding is apply to restrict unca social occasiond recipients from viewing the info, which argon deemed confidential and potentially dangerous if do know to irresponsible parties. In other word, encoding is the procedure of transforming plain school schoolbook info that tin open fire be read by some(prenominal) whizz to estimate text selective information that lav further be read by soulfulness with a secret decryption get wind.A message forrader being changed in any course is called plain text. Plain text messages argon converted to nulltext via roughly encoding method. An enryption method is called a cryptosystem.In 1972, the National billet of Standards (NBS), a part of the U.S. Department of Commerce, initiated a computer programme to develop ensamples for the pledge o f computer information. The imbed for Computer Sciences and Technology (ICST), one of the major operational units of the National Bureau of Standards, had been recently established in response to a 1965 federal law kn profess as the Brooks Act (PL89-306) that necessary novel standards for improving utilization of computers by the federal government. Computer certification had been identified by an ICST study as one of the high-priority areas requiring standards if computers were to be efficaciously spendd. A set of guidelines and standards were defined by the ICST that were to be developed as resources became available in computer security. The guidelines were to accommodate areas such as carnal security, risk management, contingency planning, and security inspecting. Guidelines were fitted in areas non requiring interoperability among variant computers. Standards were required in areas such as encoding, personal au thustication, gravel control, punch entropy sto r-age, and transmission because they could affect interoperability.Standards shadow be divided into diverse sections basic, interoperability, interface, and implementation.1. Basic standards ( excessively called 4standards of technical practice) are used to fixate generic functions (services, methods, results) required to achieve a sure set of common goals. Examples include standards for honour of chemicals, contents of food products, and in the computer house, grammatical constructiond programming practices.2. Interoperability standards specify functions and formats so that entropy transmitted from one computer grass be properly acted on when lift upd by a nonher computer.The implementation (hardware, firmware, software) or structure (integrated, isolated, interfaced layers) need non be specified in interoperability standards, since in that location is no intent of replacing one implementation or structure within a system with some other.3. Interface standards specify not only the function and format of information crossing the interface, except as well as include physical, electrical, and logical specifications sufficient to replace one implementation (device, program, atom) on all side of the interface with another.4. Implementation standards not only specify the interfaces, functions, and formats, yet also the structure and the method of implementation. These whitethorn be necessary to keep in line that split secondary characteristics such as speed, reliability, physical security, etc. also playact original needs. Such standards are often used to permit component replacement in an overall system.Services or ApplicationsThe basic diethylstilboestrol algorithm flock be used for both data encoding and data au sotication.1. Data encoding It is easy to try out how the stilbestrol whitethorn be used to encrypt a 64-bit plaintext input to a 64-bit cipher text output, nevertheless data are seldom peculiar(a) to 64 bits. In order to use stilboestrol in a descriptor of cryptological applications, four modes of operation were developed electronic codebook (ECB) cipher feed confirm (CFB) cipher ward off chaining (CBC) and output feedback (OFB) 26 (Figs. 1-4). Each mode has its advantages and disadvantages. ECB is excellent for encrypting pigments CFB is typically used for encrypting individual characters and OFB is often used for encrypting satellite communications. Both CBC and CFB tramp be used to au becauseticate data. These modes of operation permit the use of DES for interactive terminal to host encryption, crypto-graphic strike encryption for automated key management applications, level encryption, mail encryption, satellite data encryption, and other applications. In fact, it is extremely difficult, if not impossible, to find a cryptographic application where the DES cannot be applied.Figure 1 Electronic codebook (ECB) mode.Figure2 Cipher block chaining (CBC) mode. level of encryptionIn its earlies t form, people crap been attempting to conceal certain nurture that they wanted to keep to their own possession by change parts of the information with symbols, tropes and pictures. Ancient Babylonian merchants used intaglio, a piece of flat stone carved into a collage of images and several(prenominal) writing to identify themselves in trading transactions. Using this mechanism, they are producing what now we know as digital key signature. The public knew that a particular signature belonged to this trader, but only he had the intaglio to produce that signature.Of course, technology right a look has evolved at such rapid pace that the need to harbor information grows with the less(prenominal)ening reliability of older encryption techniques. Basic modern encryption is not much different from the ancient civilisations substitution use symbols. interlingual rendition circumvent, lends itself very well in making a piece of data generally unreadable. However computers today a re much too ground transgressing that translation defer is easily broken and thus no longish viable. Instead encryption today has grown into such specialised field that involve mathematical, non-linear cryptosystem that even a relatively aright computers take months or even yrs to break the ciphertext.The origins of DES go back to the former(a) 1970s. In 1972, after concluding a study on the US governments computer security needs, the US standards body NBS (National Bureau of Standards) now named NIST (National Institute of Standards and Technology) identified a need for a government-wide standard for encrypting unclassified, sensitive information.1 Accordingly, on 15 May 1973, after consulting with the NSA, NBS solicited proposals for a cipher that would meet slopped throw criteria. None of the submissions, however, turned out to be sui set back. A second request was issued on 27 August 1974. This time, IBM submitted a candidate which was deemed refreshing a cipher devel oped during the period 1973-1974 based on an preliminary algorithm, Horst Feistels compeer cipher. The team at IBM involved in cipher design and analysis included Feistel, Walter Tuchman, Don Coppersmith, Alan Konheim, Carl Meyer, Mike Matyas, Roy Adler, Edna Grossman, Bill Notz, Lynn Smith, and Bryant Tuckerman.NSAs involvement in the designOn 17 March 1975, the proposed DES was published in the Federal Register. Public comments were requested, and in the following year deuce on the fence(p) formulateshops were held to discuss the proposed standard. There was nigh criticism from various parties, including from public-key cryptography pioneers Martin Hellman and Whitfield Diffie, citing a shortened key length and the mysterious S-boxes as evidence of wrong(p) interference from the NSA. The suspicion was that the algorithm had been covertly weakened by the intelligence service agency so that they but no-one else could easily read encrypted messages.2 Alan Konheim (one of the designers of DES) commented, We sent the S-boxes finish up to Washington. They came back and were all different.3 The United States Senate Select Committee on intelligence reviewed the NSAs actions to act upon whether at that place had been any improper involvement. In the unclassified epitome of their findings, published in 1978, the Committee wroteIn the development of DES, NSA convinced IBM that a bring down key size was sufficient indirectly assisted in the development of the S-box structures and certified that the final DES algorithm was, to the best of their knowledge, innocuous from any statistical or mathematical weakness.4However, it also found thatNSA did not tamper with the design of the algorithm in any way. IBM invented and designed the algorithm, made all pertinent decisions regarding it, and concurred that the agreed upon key size was more than adequate for all mercenary applications for which the DES was intended.5Another member of the DES team, Walter Tuchm an, give tongue to We developed the DES algorithm entirely within IBM utilize IBMers. The NSA did not dictate a single wire6 In contrast, a free NSA book on cryptologic history statesIn 1973 NBS solicited private industry for a data encryption standard (DES). The first offerings were disappointing, so NSA began on the job(p) on its own algorithm. Then Howard Rosenblum, deputy director for research and engineering, find that Walter Tuchman of IBM was working on a modification to Lucifer for general use. NSA gave Tuchman a clearance and brought him in to work jointly with the Agency on his Lucifer modification.7and NSA worked closely with IBM to streng accordingly the algorithm against all except brute pull in attacks and to strengthen substitution tables, called S-boxes. Conversely, NSA tried to convince IBM to reduce the length of the key from 64 to 48 bits. Ultimately they compromised on a 56-bit key.8 many of the suspicions some privy weaknesses in the S-boxes were allay ed in 1990, with the independent discovery and open egress by Eli Biham and Adi Shamir of differential cryptanalysis, a general method for breaking block ciphers. The S-boxes of DES were much more resistant to the attack than if they had been chosen at random, strongly suggesting that IBM knew about the technique in the 1970s. This was indeed the case in 1994, Don Coppersmith published some of the original design criteria for the S-boxes.9 According to Steven Levy, IBM Watson researchers observed differential cryptanalytic attacks in 1974 and were asked by the NSA to keep the technique secret.10 Coppersmith explains IBMs secretiveness decision by saying, that was because differential cryptanalysis can be a very powerful tool, used against umteen schemes, and in that respect was concern that such information in the public domain could adversely affect national security. Levy quotes Walter Tuchman the asked us to stamp all our documents confidential We actually put a flesh on ea ch one and locked them up in safes, because they were considered U.S. government classified. They express do it. So I did it. Bruce Schneier observed that It took the academic community two decades to figure out that the NSA tweaks actually improved the security of DES.encryption straightaway a DaysIndustrial espionage among highly competitive businesses often requires that spacious security measures be put into place. And, those who wish to exercise their personal freedom, outdoor(a) of the oppressive nature of governments, whitethorn also wish to encrypt certain information to avoid legalities that entailed possession of such.With respect to the Internet, thither are many types of data and messages that people would want to be kept secret. Now that commercial trading on the Net is a reality, one of the main targets of data encryption is credit card numerates. Other information that could otherwise do good or educate a group or individual can also be used against such groups or individuals.Security Problems That encryption Does Not SolveWhile there are many good reasons to encrypt data, there are many reasons not to encrypt data. Encryption does not elucidate all security tasks, and may film some problems worse. The following sections describe some misconceptions about encryption of stored data belief 1 Encryption Does Not Solve Access Control Problems precept 2 Encryption Does Not treasure Against a Malicious Database decision maker rationale 3 Encrypting Everything Does Not play Data SecurePrinciple 1 Encryption Does Not Solve Access Control Problems around disposals must limit data nettle to users who must face this data. For usage, a human race resources system may limit employees to viewing only their own employment records, while allowing managers of employees to see the employment records of subordinates. Human resource specialists may also need to see employee records for multiple employees.Typically, you can use address path con trol mechanisms to address security policies that limit data admittance to those with a need to see it. Oracle Database has countenanced strong, independently evaluated opening control mechanisms for many years. It enables access control administerment to a fine level of granularity by Virtual Private Database.Because human resource records are considered sensitive information, it is tempting to stand for that all information should be encrypted for snap off security. However, encryption cannot enforce granular access control, and it may hinder data access. For physical exercise, an employee, his manager, and a human resources clerk may all need to access an employee record. If all employee data is encrypted, then all three must be able to access the data in unencrypted form. Therefore, the employee, the manager and the human resources clerk would have to office the corresponding encryption key to decrypt the data. Encryption would, therefore, not supply any additional s ecurity in the sense of better access control, and the encryption ability hinder the proper or efficient execution of the application. An additional issue is that it is difficult to gestate backly transmit and share encryption keys among multiple users of a system.A basic principle behind encrypting stored data is that it must not interfere with access control. For example, a user who has the take privilege on emp should not be limited by the encryption mechanism from seeing all the data he is otherwise allowed to see. Similarly, there is little benefit to encrypting part of a table with one key and part of a table with another key if users must see all encrypted data in the table. In this case, encryption adds to the overhead of decrypting the data beforehand users can read it. If access controls are implemented well, then encryption adds little additional security within the database itself. A user who has privileges to access data within the database has no more nor any les s privileges as a result of encryption. Therefore, you should never use encryption to solve access control problems.Principle 2 Encryption Does Not Protect Against a Malicious Database AdministratorSome organizations, concerned that a cattish user might gain elevated (database administrator) privileges by guessing a parole, like the idea of encrypting stored data to protect against this threat. However, the correct solution to this problem is to protect the database administrator account, and to change default countersigns for other privileged accounts. The easiest way to break into a database is by victimisation a default password for a privileged account that an administrator allowed to remain unchanged. One example is SYS/CHANGE_ON_INSTALL.While there are many destructive things a beady-eyed user can do to a database after gaining the DBA privilege, encryption entrust not protect against many of them. Examples include corrupting or deleting data, exportation user data to the record system to e-mail the data back to himself to run a password cracker on it, and so on.Some organizations are concerned that database administrators, typically having all privileges, are able to see all data in the database. These organizations feel that the database administrators should administer the database, but should not be able to see the data that the database tone downs. Some organizations are also concerned about concentrating so much privilege in one person, and would prefer to partition the DBA function, or enforce two-person access rules.It is tempting to think that encrypting all data (or pregnant amounts of data) entrust solve these problems, but there are better ways to protect against these threats. For example, Oracle Database supports limited segmentation of DBA privileges. Oracle Database provides native support for SYSDBA and SYSOPER users. SYSDBA has all privileges, but SYSOPER has a limited privilege set (such as startup and shutdown of the data base).Furthermore, you can induce smaller roles encompassing several system privileges. A jr_dba role might not include all system privileges, but only those prehend to a junior database administrator (such as raise TABLE, CREATE USER, and so on).Oracle Database also enables auditing the actions taken by SYS (or SYS-privileged users) and storing that audit trail in a potent operating system location. Using this model, a break off auditor who has root privileges on the operating system can audit all actions by SYS, enabling the auditor to hold all database administrators responsible for their actions.See Auditing SYS Administrative Users for information about ways to audit database administrators.You can also fine-tune the access and control that database administrators have by exploitation Oracle Database Vault. See Oracle Database Vault Administrators Guide for more information.The database administrator function is a trusted position. Even organizations with the most sensit ive data, such as intelligence agencies, do not typically partition the database administrator function. Instead, they manage their database administrators strongly, because it is a position of trust. Periodic auditing can help to produce inappropriate activities.Encryption of stored data must not interfere with the regime of the database, because otherwise, larger security issues can result. For example, if by encrypting data you corrupt the data, then you develop a security problem, the data itself cannot be interpreted, and it may not be recoverable.You can use encryption to limit the ability of a database administrator or other privileged user to see data in the database. However, it is not a substitute for managing the database administrator privileges properly, or for overbearing the use of powerful system privileges. If untrustworthy users have significant privileges, then they can pose multiple threats to an organization, some of them far more significant than viewing un encrypted credit card numbers.Principle 3 Encrypting Everything Does Not Make Data SecureA common error is to think that if encrypting some data strengthens security, then encrypting everything makes all data secure.As the discussion of the preceding(prenominal) two principles illustrates, encryption does not address access control issues well, and it is Copernican that encryption not interfere with normal access controls. Furthermore, encrypting an entire yield database means that all data must be decrypted to be read, updated, or deleted. Encryption is inherently a performance-intensive operation encrypting all data will significantly affect performance.Availability is a key aspect of security. If encrypting data makes data unavailable, or adversely affects availability by reducing performance, then encrypting everything will create a new security problem. Availability is also adversely affected by the database being inaccessible when encryption keys are changed, as good securit y practices require on a standard basis. When the keys are to be changed, the database is inaccessible while data is decrypted and re-encrypted with a new key or keys.There may be advantages to encrypting data stored off-line. For example, an organization may store backups for a period of 6 months to a year off-line, in a remote location. Of course, the first line of surety is to secure the facility storing the data, by establishing physical access controls. Encrypting this data before it is stored may provide additional benefits. Because it is not being accessed on-line, performance need not be a consideration. While an Oracle database does not provide this capability, there are vendors who provide encryption services. Before embarking on large-scale encryption of backup data, organizations considering this come out should thoroughly test the process. It is essential to verify that data encrypted before off-line storage can be decrypted and re-imported successfully.AdvantagesEFS technology makes it so that levels encrypted by one user cannot be opened by another user if the latter does not possess appropriate permissions. After encryption is activated, the file remains encrypted in any storage location on the disk, regardless of where it is moved. Encryption is can be used on any files, including executables.The user with permission to decrypt a file is able to work with the file like with any other, without experiencing any restrictions or difficulties. Meanwhile, other users receive a restricted access notification when they attempt to access the EFS encrypted file.This approach is definitely very convenient. The user gets the opportunity to reliably and quickly (using standard means) limit access to confidential information for other household members or colleagues who also use the computer.EFS seems like an all-around winning tool, but this is not the case. Data encrypted using this technology can be entirely lost, for example during operating system reinstallation.We should remember that the files on disk are encrypted using the FEK (File Encryption Key), which is stored in their attributes. FEK is encrypted using the master key, which in turn is encrypted using the respective keys of the system users with access to the file. The user keys themselves are encrypted with the users password hashes, and the password hashes use the SYSKEY security feature.This chain of encryption, according to EFS developers, should reliably protect data, but in practice, as explained below, the protection can be ultimately reduced to the good old login-pass-word combination.Thanks to this encryption chain, if the password is lost or reset, or if the operating system fails or is reinstalled, it becomes impossible to gain access to the EFS-encrypted files on the drive. In fact, access can be lost irreversibly. unvarying users do not fully understand how EFS works and often pay for it when they lose their data. Microsoft has issued EFS documentation t hat explains how it works and the main issues that may be encountered when encrypting, but these are difficult for regular users to understand, and few read the documentation before starting to work.Data Encryption ChallengesIn cases where encryption can provide additional security, there are some associated technical challenges, as expound in the following sections Encrypting Indexed Data Generating Encryption Keys transmit Encryption Keys Storing Encryption Keys Changing Encryption Keys Encrypting Binary Large ObjectsEncrypting Indexed DataSpecial difficulties purloin when encrypted data is baroned. For example, suppose a company uses a national indistinguishability number, such as the U.S. hearty Security number (SSN), as the employee number for its employees. The company considers employee numbers to be sensitive data, and, therefore, wants to encrypt data in the employee_number column of the employees table. Because employee_number contains unique values, the database desi gners want to have an index on it for better performance.However, if DBMS_CRYPTO or the DBMS_OBFUSCATION_TOOLKIT (or another mechanism) is used to encrypt data in a column, then an index on that column will also contain encrypted values. Although an index can be used for equality checking (for example, SELECT * FROM emp WHERE employee_number = 987654321), if the index on that column contains encrypted values, then the index is essentially unusable for any other purpose. You should not encrypt indexed data.Oracle recommends that you do not use national identity numbers as unique IDs. Instead, use the CREATE SEQUENCE statement to generate unique identity numbers. Reasons to avoid using national identity numbers are as follows There are privacy issues associated with overuse of national identity numbers (for example, identity theft). sometimes national identity numbers can have duplicates, as with U.S. Social Security numbers.Generating Encryption KeysEncrypted data is only as secure a s the key used for encrypting it. An encryption key must be unwaveringly generated using secure cryptographic key generation. Oracle Database provides support for secure random number generation, with the RANDOMBYTES function of DBMS_CRYPTO. (This function replaces the capabilities provided by the GetKey procedure of the rather DBMS_OBFUSCATION_TOOLKIT.) DBMS_CRYPTO calls the secure random number generator (RNG) previously certified by RSA Security.NoteDo not use the DBMS_RANDOM package. The DBMS_RANDOM package generates pseudo-random numbers, which, as sulphur Recommendations for Security (RFC-1750) states that using pseudo-random processes to generate secret quantities can result in pseudo-security.Be sure to provide the correct number of bytes when you encrypt a key value. For example, you must provide a 16-byte key for the ENCRYPT_AES128 encryption algorithm.Transmitting Encryption KeysIf the encryption key is to be passed by the application to the database, then you must encr ypt it. Otherwise, an intruder could get access to the key as it is being transmitted. Network encryption, such as that provided by Oracle advance(a) Security, protects all data in transit from modification or interception, including cryptographic keys.Storing Encryption KeysStoring encryption keys is one of the most important, yet difficult, aspects of encryption. To recover data encrypted with a symmetric key, the key must be accessible to an countenance application or user seeking to decrypt the data. At the same time, the key must be inaccessible to someone who is maliciously seek to access encrypted data that he is not supposed to see.The options available to a developer areStoring the Encryption Keys in the DatabaseStoring the Encryption Keys in the Operating clayUsers Managing Their Own Encryption KeysUsing liquid Database Encryption and Table plaza EncryptionStoring the Encryption Keys in the DatabaseStoring the keys in the database cannot always provide infallible s ecurity if you are trying to protect against the database administrator accessing encrypted data. An all-privileged database administrator could remedy access tables containing encryption keys. However, it can often provide good security against the casual curious user or against someone compromising the database file on the operating system.As a trivial example, suppose you create a table (EMP) that contains employee data. You want to encrypt the employee Social Security number (SSN) stored in one of the columns. You could encrypt employee SSN using a key that is stored in a separate column. However, anyone with SELECT access on the entire table could retrieve the encryption key and decrypt the matching SSN.While this encryption scheme seems easily defeated, with a little more effort you can create a solution that is much harder to break. For example, you could encrypt the SSN using a technique that performs some additional data transformation on the employee_number before using i t to encrypt the SSN. This technique might be as bare(a) as using an XOR operation on the employee_number and the birth date of the employee to determine the validity of the values.As additional protection, PL/SQL source code performing encryption can be seetheped, (using the WRAP utility) which changes (scrambles) the code. The WRAP utility processes an input SQL file and obfuscates the PL/SQL units in it. For example, the following command uses the keymanage.sql file as the input enwrap iname=/mydir/keymanage.sqlA developer can subsequently have a function in the package call the DBMS_OBFUSCATION_TOOLKIT with the key contained in the wrapped package.Oracle Database enables you to obfuscate dynamically generated PL/SQL code. The DBMS_DDL package contains two subprograms that allow you to obfuscate dynamically generated PL/SQL program units. For example, the following block uses the DBMS_DDL.CREATE_WRAPPED procedure to wrap dynamically generated PL/SQL code.BEGINSYS.DBMS_DDL.CREA TE_WRAPPED (function_returning_PLSQL_code()) abolishWhile wrapping is not unbreakable, it makes it harder for an intruder to get access to the encryption key. Even in cases where a different key is supplied for each encrypted data value, you should not embed the key value within a package. Instead, wrap the package that performs the key management (that is, data transformation or padding).An ersatz to wrapping the data is to have a separate table in which to store the encryption key and to envelope the call to the keys table with a procedure. The key table can be joined to the data table using a basal key to external key relationship. For example, employee_number is the primary key in the employees table that stores employee information and the encrypted SSN. The employee_number column is a foreign key to the ssn_keys table that stores the encryption keys for the employee SSN. The key stored in the ssn_keys table can also be transformed before use (by using an XOR operation), so the key itself is not stored unencrypted. If you wrap the procedure, then that can hide the way in which the keys are transformed before use.The strengths of this approach are Users who have direct table access cannot see the sensitive data unencrypted, nor can they retrieve the keys to decrypt the data. Access to decrypted data can be controlled through a procedure that selects the encrypted data, retrieves the decryption key from the key table, and transforms it before it can be used to decrypt the data. The data transformation algorithm is hidden from casual snooping by wrapping the procedure, which obfuscates the procedure code. SELECT access to both the data table and the keys table does not guarantee that the user with this access can decrypt the data, because the key is transformed before use.The weakness to this approach is that a user who has SELECT access to both the key table and the data table, and who can derive the key transformation algorithm, can break the encryption scheme.The preceding approach is not infallible, but it is adequate to protect against easy retrieval of sensitive information stored in clear text.Storing the Encryption Keys in the Operating SystemStoring keys in a flat file in the operating system is another option. Oracle Database enables you to make callouts from PL/SQL, which you could use to retrieve encryption keys. However, if you store keys in the operating system and make callouts to it, then your data is only as secure as the protection on the operating system. If your primary security concern is that the database can be broken into from the operating system, then storing the keys in the operating system makes it easier for an intruder to retrieve encrypted data than storing the keys in the database itself.Users Managing Their Own Encryption KeysUsing Transparent Database Encryption and Table space EncryptionTransparent database encryption and table space encryption provide secu
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment