Secure and Resilient Software Development
eBook - ePub

Secure and Resilient Software Development

  1. 392 pages
  2. English
  3. ePUB (mobile friendly)
  4. Available on iOS & Android
eBook - ePub

Secure and Resilient Software Development

About this book

Although many software books highlight open problems in secure software development, few provide easily actionable, ground-level solutions. Breaking the mold, Secure and Resilient Software Development teaches you how to apply best practices and standards for consistent and secure software development. It details specific quality software developmen

Frequently asked questions

Yes, you can cancel anytime from the Subscription tab in your account settings on the Perlego website. Your subscription will stay active until the end of your current billing period. Learn how to cancel your subscription.
At the moment all of our mobile-responsive ePub books are available to download via the app. Most of our PDFs are also available to download and we're working on making the final remaining ones downloadable now. Learn more here.
Perlego offers two plans: Essential and Complete
  • Essential is ideal for learners and professionals who enjoy exploring a wide range of subjects. Access the Essential Library with 800,000+ trusted titles and best-sellers across business, personal growth, and the humanities. Includes unlimited reading time and Standard Read Aloud voice.
  • Complete: Perfect for advanced learners and researchers needing full, unrestricted access. Unlock 1.4M+ books across hundreds of subjects, including academic and specialized titles. The Complete Plan also includes advanced features like Premium Read Aloud and Research Assistant.
Both plans are available with monthly, semester, or annual billing cycles.
We are an online textbook subscription service, where you can get access to an entire online library for less than the price of a single book per month. With over 1 million books across 1000+ topics, weโ€™ve got you covered! Learn more here.
Look out for the read-aloud symbol on your next book to see if you can listen to it. The read-aloud tool reads text aloud for you, highlighting the text as it is being read. You can pause it, speed it up and slow it down. Learn more here.
Yes! You can use the Perlego app on both iOS or Android devices to read anytime, anywhere โ€” even offline. Perfect for commutes or when youโ€™re on the go.
Please note we cannot support devices running on iOS 13 and Android 7 or earlier. Learn more about using the app.
Yes, you can access Secure and Resilient Software Development by Mark S. Merkow,Lakshmikanth Raghavan in PDF and/or ePUB format, as well as other popular books in Computer Science & Cyber Security. We have over one million books available in our catalogue for you to explore.

Information

Chapter 1

How Does Software Fail Thee? Let Us Count the Ways

Software is ubiquitous, even in places you wouldnโ€™t imagine.
Software is so seamlessly interwoven into the fabric of modern living that it fades into the background without notice. We interact with software not only on home or office computers, but in our routine everyday activitiesโ€”as we drive to the office in our cars, as we buy things at the supermarket, as we withdraw cash from an ATM, and even when we listen to music or make a phone call.

Chapter Overview

Chapter 1 surveys the landscape of software failures due to bad security, bad design, and bad development practices. Weโ€™ll look at the increasing volume of vulnerabilities, the breadth of their exposure, and the depth of the problems they cause. Finally, weโ€™ll examine the true costs of problematic software and begin to explore solutions related to people, process, and technology to end the chaos once and for all.
Software is not used just by a small cross section of the modern-day societyโ€”the entire population depends on it. Airlines, banks, telecommunications companies, hospitals, supermarkets, gas stations, voting infrastructures, and countless other institutions rely on software.
Automated teller machines (ATMs) make our lives easierโ€”24ร—7 access, depositing checks or cash, drive-up access, and even postage stamp purchasing. As you witness people in checkout lines starting writing checks for their groceries, you may grow frustrated or impatient because you know that payment cards (debit and credit) take only a few seconds to complete a purchase, and you wonder why anyone bothers with checks or paper anymore.
At this stage of technological innovation, weโ€™ve come to realize that software must not only function properly but also be available to us at all times and in all places so that we can continue to thrive in the digital ways of life to which weโ€™ve grown accustomed.
When software and the networked devices that it runs on fail, we often canโ€™t figure out what to do and begin to panic. Think of a typical Sunday morning: Youโ€™re shopping at your local neighborhood supermarket and the checkout lines stop because of a widespread system crash. What do you do? Abandon your cart and start over somewhere else? Stick around to see whether the problem is resolved soon? Wait for further instructions?
Now think about the same thing happening in an online store such as Amazon.com. Between the losses of revenue, the bad press theyโ€™re certainly likely to receive, the loss of shoppersโ€™ confidence, and the eventual hit their stock prices will take, companies and organizations simply canโ€™t afford to take a risk with unreliable software, yet they stake their businesses on it daily.
While weโ€™d like to believe that software is as reliable as it needs to be, reality proves us wrong every time. Throughout this book, weโ€™ll examine what makes software fragile, brittle, and resistant to reliability and resilience. What we refer to as software resilience is an adaptation of the National Infrastructure Advisory Council (NIAC) definition of infrastructure resilience:
Software resilience is the ability to reduce the magnitude and/or duration of disruptive events. The effectiveness of a resilient application or infrastructure software depends upon its ability to anticipate, absorb, adapt to, and/or rapidly recover from a potentially disruptive event.1

1.1 Vulnerabilities Abound

The Computer Emergency Response Team (CERT) Program is part of the Software Engineering Institute (SEI), a federally funded research and development center at Carnegie Mellon University in Pittsburgh, Pennsylvania. The center was formed following the Morris worm incident, which brought roughly 10% of Internet systems to a complete halt back in 1988. The Defense Advanced Research Projects Agency (DARPA) established a mandate for the SEI to set up a center to coordinate communication among experts during computer security emergencies and to help prevent future incidents. Table 1.1 shows CERT statistics on the number of vulnerabilities it has cataloged since 1998. CERT has since stopped publishing these statistics, but it provides the historical data for research value.
Table 1.1
CERT Security Vulnerabilities by Year
Year
Total Vulnerabilities Cataloged
Q1โ€“Q3 2008
6,058
2007
7,236
2006
8,064
2005
5,990
2004
3,780
2003
3,784
2002
4,129
2001
2,437
2000
1,090
1999
417
1998
262
Source: http:/...

Table of contents

  1. Preliminaries
  2. Preface
  3. About the Authors
  4. Acknowledgments
  5. Chapter 1 How Does Software Fail Thee? Let Us Count the Ways
  6. Chapter 2 Characteristics of Secure and Resilient Software
  7. Chapter 3 Security and Resilience in the Software Development Life Cycle
  8. Chapter 4 Proven Best Practices for Resilient Applications
  9. Chapter 5 Designing Applications for Security and Resilience
  10. Chapter 6 Programming Best Practices
  11. Chapter 7 Special Considerations for Embedded Systems, Cloud Computing, and Mobile Computing Devices
  12. Chapter 8 Security Testing of Custom Software Applications
  13. Chapter 9 Testing Commercial off-the-Shelf Systems
  14. Chapter 10 Implementing Security and Resilience Using CLASP
  15. Chapter 11 Metrics and Models for Security and Resilience Maturity
  16. Chapter 12 Taking It to the Streets
  17. Glossary
  18. Appendix A 2010 CWE/SANS Top 25 Most Dangerous Programming Errors
  19. Appendix B Enterprise Security API