ebook img

Specification-based security analysis of REST APIs PDF

103 Pages·2017·1.1 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Specification-based security analysis of REST APIs

Specification-based security analysis of REST APIs Petter Iversen Master of Science in Informatics Submission date: June 2018 Supervisor: Jingyue Li, IDI Co-supervisor: Edvard Karlsen, Kantega Bjarte Østvold, Norwegian Computing Center Norwegian University of Science and Technology Department of Computer Science Iwanttodedicateaspecialthankstomytwoexternalsupervisors,BjarteM.Østvoldand EdvardK.Karlsen,aswellasmyinternalsupervisoratNTNU,JingyueLi—withoutyour excellent guidance, commitment and encouragement, this thesis could not have been the same. Problem description In January 2014, news outlets reported that the usernames and passwords of 4.6 million Snapchatusershadleaked, whenintrudersexploitedcriticalsecurityholesinSnapchat’s “non-public” back-end API. While such catastrophic incidents are uncommon, security bugsthatcouldallowcriticaldataleaksareregularlydiscoveredinallkindsofwebAPIs. Most such bugs are simple to fix once discovered, and also possibly to spot given basic knowledgeofwebsecurity. However, lackofknowledgeorfailuretoallocatedeveloper resourcesisachallenge. Many web APIs are described using machine-readable modelling languages such as the OpenAPISpecification(formerlytheSwaggerSpecification)andRESTfulAPIModeling Language. A specification written in such a language should be an interesting starting pointforconductingautomatedsecuritytestingofanAPI. The goal of this project is to design and evaluate techniques for conducting such test- ing,emphasisinglowdeveloperefforttechniquesthatcanbedeployedbymostorganisa- tions. i Abstract In the modern Internet era, web applications are typically driven by web services (WS). WebservicesareaccessibleontheInternetthroughtheirapplicationprogramminginter- faces (APIs). Due to the continuous exposure on the Internet, and being accessible for anyone,securitytestingisanincreasinglyimportantpartofserioussoftwaredevelopment. Manualsecuritytestingis,however,anexpensiveandtime-consumingactivity. Automatedsecurityanalysesthatdonotrequiredeveloperstospecifyindividualtestcases couldreducetheentrybarriertogetdevelopersstartedwithsecuritytesting. Itwouldalso helpavoidlargeupfrontcostsforthedevelopmentteams. In this thesis, I introduce a set of such automated security analyses, a set of Representa- tional State Transfer (REST) related security testing techniques, a minimalist API mod- ellinglanguagethattheanalysesusetogeneratetestcases,andfinallyaproof-of-concept toolthatimplementsandvalidatesallofmyothercontributions. Animportantfocusinthethesishasbeentokeepprogrammereffortmodest,i.e.limiting the required programmer input and required security related knowledge to the minimum sensiblelevel,whilestillbeingabletofindrelevantandsecuritycrucialvulnerabilitiesin real-worldapplications. ii Sammendrag I den moderne Internettæra er web applikasjoner typisk drevet av webtjenester (WS). Webtjenesterertilgjengeligepa˚Internettgjennomderesprogrammeringsgrensesnitt(API). Pa˚ grunnavderesevigeeksponeringpa˚ Internett, samtdetfaktumatdeera˚penttilgjen- gelige,harsikkerhetstestingblittenviktigereogviktigeredelavseriøsprogramvareutvikling. Manuellsikkerhetstestingerdogendyrogtidskrevendeaktivitet. Automatiserte sikkerhetsanalyser hvor utviklere ikke spesifiserer individuelle testtilfeller kanredusereinngangsbarrierentilsikkerhetstesting.Detvilogsa˚kunnehjelpeutviklerteam a˚ unnga˚ storeforha˚ndskostnaderknyttettilsikkerhetstesting. I denne oppgaven introduserer jeg et sett av slike automatiske sikkerhetsanalyser, et sett medRepresentationalStateTransfer(REST)-relatertesikkerhetstestingsteknikker,etmin- imalistiskmodelleringsspra˚kforAPIer,samtetenkeltverktysomimplementererogvalid- ererallemineandrebidrag. Etviktigfokusgjennomheleoppgavenharværta˚ holdeprogrammererensinnsatsbeskje- den, altsa˚ a˚ minimere krav til input og sikkerhetsrelaterte forkunnskaper til et minimalt fornuftigniva˚,menfortsattklarea˚ finnerelevanteogsikkerhetskritiskesvakheterfraden virkeligeverden. iii iv Table of Contents Problemdescription i Abstract ii Sammendrag iii TableofContents vii 1 Introduction 1 1.1 Introductoryexample . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.2 Audience . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.3 Researchhypothesis. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.3.1 Researchquestions . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.4 Contributions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 2 Background 7 2.1 RepresentationalStateTransfer(REST) . . . . . . . . . . . . . . . . . . 7 2.1.1 Keyconcepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.1.2 ExaminationofasampleRESTAPI . . . . . . . . . . . . . . . . 10 2.2 Webservicesecurity . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 2.2.1 TheOpenWebApplicationSecurityProject(OWASP) . . . . . . 12 2.2.2 CommonWeaknessEnumeration(CWE) . . . . . . . . . . . . . 12 2.2.3 Cross-siterequestforgery(CSRF) . . . . . . . . . . . . . . . . . 12 2.3 Softwaresecurity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 2.3.1 Black-boxtesting . . . . . . . . . . . . . . . . . . . . . . . . . . 13 2.3.2 Hacking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 2.3.3 Cryptographichashing . . . . . . . . . . . . . . . . . . . . . . . 13 2.3.4 Dictionaryattack . . . . . . . . . . . . . . . . . . . . . . . . . . 14 2.3.5 Thesevensecuritytouchpoints . . . . . . . . . . . . . . . . . . . 14 2.4 Webservices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 2.5 Authenticationandauthorisation . . . . . . . . . . . . . . . . . . . . . . 18 v 2.5.1 Authenticationandwebservices . . . . . . . . . . . . . . . . . . 18 2.5.2 Session-basedauthentication . . . . . . . . . . . . . . . . . . . . 18 2.5.3 Token-basedauthentication. . . . . . . . . . . . . . . . . . . . . 18 2.6 JSONWebToken(JWT) . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.6.1 Header . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.6.2 Payload . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.6.3 Signature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 2.6.4 Registeredclaims . . . . . . . . . . . . . . . . . . . . . . . . . . 20 2.6.5 Tyingitalltogether . . . . . . . . . . . . . . . . . . . . . . . . . 21 2.7 RESTAPImodelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 3 Analysisandvulnerabilities 23 3.1 Analysistechniques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 3.1.1 Staticanddynamicanalysis . . . . . . . . . . . . . . . . . . . . 23 3.1.2 Staticanalysiscategories . . . . . . . . . . . . . . . . . . . . . . 25 3.1.3 ST1-Dictionary-basedanalysis . . . . . . . . . . . . . . . . . . 25 3.1.4 ST2-Algorithmicanalysis . . . . . . . . . . . . . . . . . . . . 26 3.1.5 Dictionary-basedanalysisandfalsepositives . . . . . . . . . . . 27 3.2 Vulnerabilitypatterns . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 3.2.1 B1-JWTmisuse . . . . . . . . . . . . . . . . . . . . . . . . . . 28 3.2.2 B2-Bypassingaccesscontrol . . . . . . . . . . . . . . . . . . . 31 3.2.3 Actingoutsideofintendedscope . . . . . . . . . . . . . . . . . . 33 4 Staticspecification-basedsecurityanalysis 35 4.1 IntroducingmyAPImodel . . . . . . . . . . . . . . . . . . . . . . . . . 36 4.1.1 RootURL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.1.2 Userlevels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.1.3 Endpoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 4.2 Staticanalysistechniques . . . . . . . . . . . . . . . . . . . . . . . . . . 38 4.2.1 ST1-Algorithmicanalyses . . . . . . . . . . . . . . . . . . . . 38 4.2.2 ST2-Dictionarybasedanalyses . . . . . . . . . . . . . . . . . . 38 4.2.3 Dictionary-basedanalysesandfalsepositives . . . . . . . . . . . 39 4.3 SA1-JWTspoofing . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 4.4 SA2-AnalysingJWTpayload . . . . . . . . . . . . . . . . . . . . . . . 40 4.4.1 AnalysingJWTpayloadbyfieldnames . . . . . . . . . . . . . . 40 4.4.2 AnalysingJWTpayloadbyregularexpression . . . . . . . . . . 41 4.5 SA3-AnalysingJWTduration . . . . . . . . . . . . . . . . . . . . . . . 41 4.6 SA4-UnsecuredJWT . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 4.7 SA5-AnalysingtheAPImodel . . . . . . . . . . . . . . . . . . . . . . 43 5 Dynamicspecification-basedsecurityanalysis 45 5.1 Dynamicanalysistechniques . . . . . . . . . . . . . . . . . . . . . . . . 45 5.1.1 DT1-InterpretingHTTPresponsecodes . . . . . . . . . . . . . 49 5.1.2 DT2-Comparingexpectedandactualresponses . . . . . . . . . 50 5.2 DA1-Readablestateanalysis . . . . . . . . . . . . . . . . . . . . . . . 52 5.3 DA2-Mutablestateanalysis . . . . . . . . . . . . . . . . . . . . . . . . 53 vi

Description:
as well as lightweight automated test suite for them. According to the cheat sheet, there seems to be a convergence towards using Burp Suite.
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.