Code A (below) first checks the status of a file and then opens it and uses it. It contains a vulnerability. Explain what the vulnerability is and why Code B (below) resolves the vulnerability.

Programming with Microsoft Visual Basic 2017
8th Edition
ISBN:9781337102124
Author:Diane Zak
Publisher:Diane Zak
Chapter5: The Repetition Structure
Section: Chapter Questions
Problem 1MQ6: Write an Add method that adds the contents of the decPrice variable to the lstPrices control.
icon
Related questions
Question

Code A (below) first checks the status of a file and then opens it and uses it. It contains a vulnerability.
Explain what the vulnerability is and why Code B (below) resolves the vulnerability.

Code B:
1. struct stat lstat_info, fstat_info;
2. int fd;
3. if (lstat("some_file", &lstat_info) == -1) {
4. err (1, "lstat");
5. }
6. if ((fd = open("some_file", O_EXCL | O_RDWR, 0600))
7. err(2, "some_file");
8. }
9. if (fstat (fd, &fstat_info) == -1)
10. {
11.
12.
}
13. if (lstat_info.st_mode == fstat_info.st_mode &&
14.
lstat_info.st_ino == fstat_info.st_ino)
15. //process the file
-
err (3, "fstat");
== -1)
{
Transcribed Image Text:Code B: 1. struct stat lstat_info, fstat_info; 2. int fd; 3. if (lstat("some_file", &lstat_info) == -1) { 4. err (1, "lstat"); 5. } 6. if ((fd = open("some_file", O_EXCL | O_RDWR, 0600)) 7. err(2, "some_file"); 8. } 9. if (fstat (fd, &fstat_info) == -1) 10. { 11. 12. } 13. if (lstat_info.st_mode == fstat_info.st_mode && 14. lstat_info.st_ino == fstat_info.st_ino) 15. //process the file - err (3, "fstat"); == -1) {
Code A:
1. struct stat lstat_info;
2. int fd;
3. if (1stat ("some_file", &lstat_info) == -1) {
4. err (1, "lstat");
5. }
6. if ((fd = open("some_file", O_EXCL | O_RDWR, 0600))
7. err (2, "some_file");
8. }
9. //process the file
== -1) {
Transcribed Image Text:Code A: 1. struct stat lstat_info; 2. int fd; 3. if (1stat ("some_file", &lstat_info) == -1) { 4. err (1, "lstat"); 5. } 6. if ((fd = open("some_file", O_EXCL | O_RDWR, 0600)) 7. err (2, "some_file"); 8. } 9. //process the file == -1) {
Expert Solution
steps

Step by step

Solved in 4 steps

Blurred answer
Knowledge Booster
Parallel and Distributed Storage
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Programming with Microsoft Visual Basic 2017
Programming with Microsoft Visual Basic 2017
Computer Science
ISBN:
9781337102124
Author:
Diane Zak
Publisher:
Cengage Learning
Programming Logic & Design Comprehensive
Programming Logic & Design Comprehensive
Computer Science
ISBN:
9781337669405
Author:
FARRELL
Publisher:
Cengage
EBK JAVA PROGRAMMING
EBK JAVA PROGRAMMING
Computer Science
ISBN:
9781337671385
Author:
FARRELL
Publisher:
CENGAGE LEARNING - CONSIGNMENT