| 
Exam Details
Exam CodeNumber of Questions: 150Passing Score: 70%Test Duration: 4 HoursTest Format: Multiple ChoiceTest Delivery: Prometric Prime / Prometric APTC / VUE 
The exam code varies when taken at different testing centers. 
Prometric Prime: 312-92VUE: 312-92 
Skills Measured 
The exam 312-92 tests ECSP candidates on the following 29 domains. 
 Introduction to Secure CodingDesigning Secure ArchitectureCryptographyBuffer OverflowsSecure C and C++ ProgrammingSecure Java and JSP ProgrammingSecure Java Script and VB Script Programming Secure ASP ProgrammingSecure Microsoft.NET ProgrammingSecure PHP ProgrammingSecure PERL ProgrammingSecure XML, Web Services and AJAX ProgrammingSecure RPC, ActiveX and DCOM ProgrammingSecure Linux ProgrammingSecure Linux Kernel ProgrammingSecure Xcode ProgrammingSecure Oracle PL/SQL ProgrammingSecure SQL Server ProgrammingSecure Network ProgrammingWindows Socket ProgrammingWriting ShellcodesWriting ExploitsProgramming Port Scanners and Hacking ToolsSecure Mobile phone and PDA ProgrammingSecure Game DesigningSecuring E-Commerce ApplicationsSoftware Activation, Piracy Blocking, and Automatic UpdatesSecure Application TestingWriting Secure Documentation and Error Messages 
 
ECSP Certification Test Objectives
Module 01: Introduction to Secure Coding 
Module 02: Designing Secure ArchitectureExplain the need for secure codingDiscuss the vulnerabilities statistics and programming errorsDiscuss why security mistakes are madeDiscuss the need for secure programming and why secure coding is importantDetermine the building blocks of software security and explains the various types of security vulnerabilitiesDetermine the software vulnerability cycle, and types of attacksExplain the various secure coding principles and guidelines for developing the secure codesPrepare a checklist for software security mechanisms 
Module 03: CryptographyExplain about the secure architecture and application securityDetermine the factors affecting the security of the applicationDefine the software engineering concept and SDLCExplain what is extreme programming and it roles and practicesDescribe Unified Modeling Language (UML) and its goalsDiscuss on UML tools such as Rational Rose and Borland TogetherExplain about threat modeling and their aspects of securityDiscuss on STRIDE threat modelWhat are the common criteria and software development best practicesExplain the working of Microsoft SDL threat modeling toolSummarize the working of the tool: Borland® TeamInspector™ 
Module 04: Buffer OverflowsDefine Cryptography, Encryption, and DecryptionDiscuss cryptographic techniques such as Classic Cryptographic and Modern CryptographicDefine RSA (Rivest Shamir Adleman) and attacks against itExplain how to implement RSA in C++Discuss the Diffie-Hellman Key Agreement Standard and its algorithmExplain Data Encryption Standard (DES), overview and its implementation of DES in JavaDescribe Rijndael Algorithm, RC4, RC5, RC6, and Blowfish, and describes Blowfish algorithm in CWhat are Message digest, One-way bash, and MD5 functionsDescribe the implementation of MD5 in JavaExplain the implementation of SHA (Secure Hash Algorithm) in Java, and Collision Search Attacks on SHA1Describe  Modern Cipher Breaking, the Keyed-Hash Message Authentication Code (HMAC), and its algorithmWhat is SSL, and SSHDetermine algorithms and security, explain disk encryption, and Government Access to Keys (GAK)What are the components of a Digital Signature, method of Digital Signature technology, use of Digital Signature, and Digital Signature Standard (DSS)Determine Digital Signature algorithms such as Signature Generation/Verification and ECDSA, ElGamal Signature SchemeExplain Hashing techniques, Hashing, MACs, and Digital Signatures using C# in .NETWhat are the challenges and Opportunities of digital signaturesProvides an overview of Digital Certificates, creating and verifying a simple XML Digital Signature in C#Explain about Cleversafe Grid Builder, Pretty Good Privacy, CypherCalc, CryptoHeaven, and Command Line ScriptorExplain about JavaScrypt: Browser-Based Cryptography tool and steps to use JavaScrypt Encryption and Decryption toolDetermine cryptanalysis, cryptography attacks, cryptography attacks, brute-force attack, and the distributed.net organization 
Module 05: Secure C and C++ ProgrammingDescribe buffer overflows and reasons for buffer overflow attacksExplain why programs/applications are vulnerableExplain the concepts of Stacks and HeapsDescribe Stack-based and Heap-based buffer overflowsWhat are the countermeasures against Buffer Overflow attacksExplain how an attacker can attack a Real ProgramWhat is Return Address DefenderList and summarize the tools to defend buffer overflows  What are the buffer overflow protection solutionsProvide a comparison of the functions of libc and Libsafe toolsExplain how buffer over flow occurs in C and how to analyze the code 
Module 06: Secure Java and JSP ProgrammingList the important features of object oriented programming such as C/C++List and explain the vulnerable C/C++ functionsWhat are the types of buffer overflows and explain each of themDescribe the dangling pointers, stack smashing, and GCC extension to protect the stack-smashing attacksHow to determine integer vulnerabilities, Truncation, and Sign ErrorDiscuss on Pointer Subterfuge and Bugs with Pointers and MemoryDescribe about dynamic memory management, double free vulnerability, and secure memory allocation tipsExplain symmetric and symmetric encryption in C++Explain the Blowfish Algorithm in CDescribe public key cryptography in C++Discuss on  networking, creating an SSL Client in C++, and creating an SSL ServerDetermine the random number generation problem, anti-tampering, and its techniquesExplain the process of erasing data from memory securely using C/C++How to prevent memory from paging to diskExplain how to use the variable arguments properlyDiscuss on signal handling, encapsulation in C++, and best practices for input validationDefine Code Profiling, list and explain the working of memory debugging tools 
Module 07: Secure JavaScript and VBScript ProgrammingDiscuss the features of Java Programming language, explain what is Java virtual Machine(JVM), and discuss the byte code basicsDescribe Java security, access controls, and Sandbox modelList the security issues with JavaDescribe the SQL injection attack and explain how to preventDescribe about URL TamperingDiscuss the various attacks on Applet, and explain the prevention of DoS attacksDiscuss on Byte Code attack and Reverse Engineering/Decompilation by MochaList and summarize the Obfuscation ToolsExplain how to build a simple ClassLoaderExplain what is a security managerList and explain the signing toolsHow to get RSA certificatesDescribe the process of bundling Java Applets as JAR Files, and signing Java Applets using the Netscape signing toolDiscuss about the Java Security and basic security architectureDetermines Java Cryptography Architecture (JCA) and sample code for encryption and decryptionExplain how to create Secure Client and Server Sockets, and how to choose the Cipher SuitesDiscuss about Java GSS securityList and explain the security issues with JSPExplain Cross-Site scripting, countermeasures, and how to create new types of permissionsExplain what is a Security Policy, and describe policy toolsDetermine the best practices for developing secure Java code 
Module 08: Secure ASP ProgrammingDiscuss on Java Script and vulnerabilities associated with itDescribe the XSS attack, and explain how to avoid the attacksDefine JavaScript Hijacking and how to defend against JavaScript HijackingExplain the effects and solutions to prevent malicious script embedded in client web requestsExplain the Thicket Obfuscator for JavaScript toolDiscuss on JavaScript security in Mozilla, the Same Origin Policy and Signed Script PolicyExplain the Netscape's SignToolList and summarize the encryption toolsDiscuss on signing a script (Windows Script Host), verifying a script, and Signature Verification PolicyDetermine software restriction policies for Windows XP/Vista, and Server 2008Discuss on designing a software restriction policy and creating additional rulesDescribe the procedure to block the malicious scripts 
Module 09: Secure Microsoft.NET Programming
Describe about ASP and improving ASP designDetermine the #include directive and .BAK files on the serverExplain about  detecting exceptions with scripting language error-handling mechanisms, using VBScript and Jscript to detect an errorDiscuss about attacks on ASPExplain insufficient validation of fields in SQL queriesDescribe ASP DypsAntiSpam: A CAPTCHA for ASP and preventing automatic submission with DypsAntiSpamDescribe using database and ASP sessions to implement ASP security and steps for designing the mechanismExplain about protecting ASP pages and encoding ASP code: Script EncoderDescribe protecting passwords of ASP pages with a one-way hash function and ASP best practices 
Module 10: Secure PHP Programming
Describe about common terminology, Microsoft.NET, .NET framework, and .NET framework security policy modelExplain the security policy levels and security features in .NETExplain about Code Access Security (CAS)List the steps to use CAS in ASP.NET applicationsDescribe evidence-based security, role-based security, declarative, and imperative securityExplain the process involved in key generationDiscuss the methods to protect client and server data using encryptionDescribe the cryptographic signatures and hash code generationDescribe about classes implementing the public-key encryption algorithmsCreate a security checklist for .NET framework and permissions Describe skipverification and stack walkDetermine runtime security policy and list the step-by-step configuration of the runtime security policiesDiscuss on creating a security policy deployment packageDescribe type safety, canonicalization, Access Control List (ACL) editor, and securing user credentials and logon information, and obfuscationList and explain the working of .NET obfuscator tool and Administration toolsDescribe ASP.NET security architecture and authentication and authorization strategiesExplains about various authorizations in .NETDevelop a security checklist for ASP.NETList the steps to encrypt configuration sections in ASP.NET using DPAPI and the steps for configuring security with Mscorcfg.mscDiscuss how to identity a ASP.NET processDescribe secure communication, storing secrets, and web.config vulnerabilitiesDescribe how to secure session and view state, web form considerations, and how to secure web servicesExplain the web application security frame, and its threats, attacks, and countermeasuresDescribe secure remoting, creating remotable object, and secure data accessExplain how to protect ASP.NET from SQL injection attackList the steps to prevent cross-site scripting in ASP.NETDescribe about  .NET security toolsList the best practices for .NET security 
Module 11: Secure Perl ProgrammingDescribe the PHP security blunders, and give example of PHP attackDetermine solution for: access control flaws and session ID protectionDescribe error reporting and data handling errorsExplain security sensitive PHP functions: file functions and ezmlm_hashList the PHP exploits and explain them with examplesDescribe about spoofed form submissions, spoofed HTTP requests, and sessions and cookiesDescribe about cookie theft, exposed session data, session fixation, and session hijackingList the vulnerabilities in PHP, attack vulnerabilities, and common PHP attacksDiscuss how to defend against file system attacks, information gathering attacks, and PHP injection attacksDescribe ten PHP best practices and secure PHP practicesDetermine the best practices for PHP securityExplain various PHP encoders 
Module 12: Secure XML, Web Services and AJAX ProgrammingExplain the common terminology of PERL programming language, and security issues in Perl scriptsExplain about basic user input vulnerabilities and how to overcoming the basic user input vulnerabilitiesDescribe insecure environmental variablesDescribe algorithmic complexity attacks and Perl: Taint, Strict, and WarningsExplain Setuid command, authenticating the user with setuid, security bugs with setuid, Perl crypt() functionDescribe logging into a secure website with Perl scriptDescribe secure log-in checklist, unicodes, and displaying unicode as text 
Module 13: Secure RPC, ActiveX and DCOM ProgrammingDescribe about web application and web services and its vulnerabilitiesDescribe XML introduction, XSLT and XPath, XML signature, applying XML signatures to security, and XML encryptionDetermine security considerations for the XML encryption syntaxDescribe canonicalization, validation process in XML, XML web services security, and security of URI in XMLDetermine security of opaque data in XML and XML web services security the best practicesList and summarize XML toolsDescribe about AJAX, anatomy of an AJAX interaction, security issues, how to prevent the attacks and the toolsDescribe about  HP WebInspect software 
Module 14: Secure Linux Programming
Explain the terms: RPC, Authentication, Authentication protocol, NULL authentication, Unix authentication, and DES authenticationExplain about  Diffie-Hellman encryption, security methods, SSPI, and SSPsDescribe the secure RPC protocol and RpcServerRegisterAuthInfoDetermine RPC programming best practices, making RPC function calls, and RPC and the networkDescribe ActiveX programming, preventing repurposing, and sitelock templateDescribe about IObjectSafety interface, code signing, and creating a code signing certificate and signing an ActiveX component in WindowsDetermine how to protect the ActiveX controlsExplain the concept of DCOMExplain application-level security, security by configuration, and programmatic securityExplain heap overflow vulnerabilityDescribe the tool: DCOMbobulator and the security best practices of DCOM 
Module 15: Secure Linux Kernel ProgrammingWhat is open source with respect to Linux and the security associated with itDescribe the basic Linux commands, networking commands, processes, and POSIX capabilitiesExplain UTF-8 security issues, UTF-8 legal values, and secure Linux programming advantagesDetermine the requirements for security measure assuranceDiscuss on enabling the source address verification, Linux iptables and ipchains, and code to save the ip6tables stateExplain how to control access by MAC address  and permitting the SSH access onlyExplain about network access control and layers of security for incoming network connectionsDescribe prohibiting root logins on the terminal devices and authentication techniquesDiscuss on authorization controls, running a root login shell, and protecting the outgoing network connectionsExplain logging into a remote host, invoking remote programs and copying remote filesDescribe about public-key  authentication between OpenSSH client and server and authenticating in Cron JobsDescribe how to protect files, file permissions, shared directory, and encrypting filesExplain about listing the keyring, signing files, encrypting directories, and POP/IMAP mail serverDescribe about testing an ssl mail connection, securing POP/IMAP with SSL and Pine and SMTP serverDiscuss on testing and monitoring, testing login passwords (John the Ripper), testing login passwords (CrackLib), and testing search pathExplain how to search file systems effectively, secure device special files, look for rootkits, and tracing processesDescribe how to observe the network traffic, detect insecure network protocols and intrusion detection with snortDiscuss on testing a syslog configuration and logwatch filterDetermine structure program internals and approach, sample code for minimizing privileges, and filters cross-site malicious content on inputDescribe about filter HTML/URIs and avoid buffer overflow,Discuss on language-specific issues: C/C++, Perl, Ada, Java, Tcl, and PHPDetermine Linux application auditing tool: grsecurity 
Module 16: Secure Xcode ProgrammingExplain what is a kernelsDescribe how to build a Linux kernel and the procedures to be followed post-buildDetermine Linux kernel configuration menuDiscuss on compiling a Linux kernel 
Module 17: Secure Oracle PLSQL ProgrammingExplain what is XcodeExplain Mac OS X applications, Cocoa, Carbon, AppleScript, Script Editor, and Script windowDescribe about common data security architecture and securetransport API Set and CSPDiscuss how to create SSL certificates on Mac OS X server, using SSL with the web server, setting up SSL for LDAP, and how to protect security informationDescribe security in Mac OS X and security management using system preferencesList the recommended steps to secure Mac OS X 
Module 18: Secure SQL Server ProgrammingExplain about PL/SQL and security issues in OracleDiscuss on SQL injection attacks and how to defend against SQL injection attacksDescribe SQL manipulation, code injection attacks, function call injection attacks, buffer overflows, and other vulnerabilitiesExplain DBMS_SQL  vulnerability in PL/SQL and protecting DBMS_SQL in PL/SQLDiscuss on types of database vulnerabilities/attacks and how to establish security policiesList and explain the password management policiesList the steps for creating an Oracle label security policyDescribe Oracle identity management  Discuss on security tools, Oracle secure backup tool, obfuscation, and encryption using DBMS_CRYPTODescribe advanced security options and low level securityExplain Oracle database vaults: tool, auditing, auditing methods, audit options, view audit trail, FGA, and Oracle auditing toolsDescribe about testing PL/SQL programs and SQL unit testing tools 
Module 19: Secure Network ProgrammingExplain the SQL server security model, and how to create an SQL server loginDescribe about database user, guest user, permissions, and rolesDetermine the security features of MS-SQL Server 2005 and the additional security features in MS-SQL Server 2008List and explain the vulnerabilities in SQL server securityDiscuss on SQL injection attacks and methods to prevent the SQL injection attacksDescribe Sqlninja: SQL Server Injection and Takeover toolDescribe data encryption, built-in encryption capabilities, and encryption keysDiscuss on Transact-SQL, creating asymmetric and symmetric key in T-SQLExplain how to create a certificate in T-SQLExplain the method to determine SQL server securityDetermine the database programming best practicesExplain the process of authentication and authorization in SQL server installationDescribe the process of auditing and intrusion detectionList and summarize the database security auditing tools 
Module 20: Windows Socket ProgrammingExplain basic network concepts  and basic web conceptsExplain about network programming and benefits of the secure network programmingDescribe about network interface, securing sockets: server and client programDiscuss on ports, UDP datagram and sockets, Internet address, and content handlerDescribe cookie policy, RMI connector, and .Net: Internet authenticationDescribe network scanning tool- Security Manager Plus, and network programming best practices 
Module 21: Writing ShellcodesExplain about Windows Sockets, Windows NT and Windows 2000 Sockets architecture, and socket programmingDiscuss on Winsock 2.0, Winsock linking methods, how to start a Winsock 2 API, and grabbing a web page using WinsockDiscuss on writing client and server applications, TCP client, and server application sample codeDescribe Winsock secure socket extensions, WSAQuerySocketSecurity, SOCKET_SECURITY_SETTINGStructureExplain how to use WinSock to execute a web attack, how to use Winsock to execute a remote buffer overflow and MDACDos application 
Module 22: Writing Exploits
Explain about shellcode and shellcode development toolsDescribe remote shellcode, port binding shellcode, and clean port binding shellcodeDiscuss on socket descriptor reuse shellcode and socket descriptor reuse shellcode in CDescribe socket descriptor reuse shellcode: sample code, local shellcode, and byte codeDiscuss on how to break chroot jails and breaking chroot jails on Linux kernelsDescribe Windows shellcode and list the steps to execute the shell code assemblyExplain the write system call, Linux shellcode for “Hello, world!”, the write system call in FreeBSDDiscuss on  various system calls and assembly creation 
Module 23: Programming Port Scanners and Hacking ToolsExplain the steps involved in writing exploits and targeting vulnerabilitiesDiscuss on the remote and local exploits and a two-stage exploitDescribe format string attacks, fixing format string bugs, and user-supplied format string vulnerability CVE-2000-0763 in xlockmoreExplain TCP/IP vulnerabilities and race conditionsDiscuss on file race conditions, signal race conditions, and input validation error in man programDescribe writing exploits and vulnerability checking programs and stack overflow exploitsDescribe memory organization, stack overflows, heap corruption exploits, Doug Lea malloc, and Dlmalloc chunkDiscusse on OpenSSL SSLv2 malformed client key remote buffer overflow vulnerability CAN-2002-0656Describe about exploitation, complication, integer bug exploits, integer wrapping, and bypassing size checksDiscuss on how to use the metasploit frameworkExplain how to determine attack vector, select a control vector, find a return address, and select the search method in the metasploit Opcode databaseExplain the how to insert the return address, verify return address reliability, and increase reliability with a Nop SledHow to choose a payload and encoder and list of available encodersDescribe integrating exploits into framework 
Module 24: Secure Mobile Phone and PDA ProgrammingExplain about port scanner, simple port scanners, and prerequisites for writing a port scannerDescribe port scanner in C++, port scanner in C#, building a simple port scanner in VC++, port scanner in Java, port scanner in ASP.Net, port scanner in Perl, and port scanner in PHPDiscuss on libpcap, saving captured packets to a file, and the Wiretap libraryExplain Nessus Attack Scripting Language (NASL), and porting to and from NASLDescribe Metasploit Framework (MSF), executing an exploit using msfconsole and writing basic rulesDiscuss on rule header, rule options, optimizing rules, testing rules, and writing detection plugins, and Netcat source code 
Module 25: Secure Game DesigningExplain about mobile phone programming and different OS architectures in the mobile phoneDiscuss on Symbian Operating System and guidelines for securing Symbian OSDescribe about Palm OS, Palm OS vulnerabilities, HotSync vulnerability, and Creator ID switchingDetermine Windows mobile, calling secure web services, and security practices for Windows mobile programmingDiscuss on comparison of the common programming tasks, PDA programming, PDA security issues, and security policies for PDAsDiscuss on PDA security products and security vendorsDescribe Java platform, Micro edition (Java ME), Java ME architecture, and Java ME security issuesDescribe about the CLDC security, Mobile Information Device Profile (MIDP), MIDP security, and programming the BlackBerry with Java MEDetermine Security and Trust Services API (SATSA) for Java ME: the security APIs and certificate enrollment in SATSADiscuss on data integrity with message digests, data confidentiality: using ciphers for data encryptionExplain security issues and attacks in bluetooth and bluetooth securityDescribe various tools such as BlueKey, BlueWatch, BlueSweep, etc.,Determine mobile phone security tips and defending cell phones and PDAs against attackDescribe the antivirus tools for mobile devices 
Module 26: Securing E-Commerce ApplicationsExplain about game designing, console games, mobile games, online games, offline games, and Wii gamesDetermine threats to online gaming, threats to online gaming: cheatingDescribe about various tools such as Multimedia Fusion 2, Adventure Game Studio, Game Maker, FPS and Stagecast Creator and the Scrolling Game Development KitExplain about game engine and best practices for secure game designing 
Module 27: Software Activation, Piracy Blocking, and Automatic Updates
Describe the purpose of secure E-Commerce application, and E-Business concepts: Secure Electronic Transaction (SET)Discuss on using SETDiscuss about Secure Socket Layer (SSL) and SSL certificatesDiscuss about VeriSign SSL certificates and Entrust SSL certificatesExplain about concept and functioning of: Digital certificates, Digital Signature, and Digital Signature technologyDescribe about Digital Signature algorithm: Signature Generation/Verification and ECDSA, ElGamal signature schemeExplain guidelines for developing secure E-Commerce applications 
Module 28: Secure Application TestingExplain about software activation and software activation processDescribe about software activation and its advantagesDiscuss on activation explained, online license management server, and activation policiesDescribe policy control parameters, piracy, and the effects of piracyExplain piracy blocking, Digital Rights Management (DRM), and software piracy protection strategiesDescribe copy protection for DVD, Application Framework: DVD Copy Protection System, and content protection during digital transmissionExplain about watermark system design issues, cost effectiveness, false positives rate, and interaction with MPEG compressionDescribe about detector placement, copy generation management, and the Crypkey toolDescribe about EnTrial key generation, EnTrial distribution file, and EnTrial product and package initialization dialogDiscuss on Windows automatic updates, options for setting up Windows automatic updates on XP and Vista, automatic updates option on: AVG antivirus, Internet Explorer, and Mozilla Firefox 
Module 29: Writing Secure Documentation and Error MessagesExplain the Software Development Life Cycle (SDLC), introduction to testing, and the types of testingDiscuss on white box testing, types of white box testing, dynamic white box testing, integration testing, regression testing, system testing, and black box testingDescribe about load testing and strategies, functional testing, and list the testing stepsExplain how to create a test strategy, test plans, test cases, and test dataDiscuss bug fixing, and retestingDiscuss on classic testing mistakes and user interface errorsDetermine good user interfacesDiscuss on use of the automatic testing and toolsPrepare a generic code review checklist, and software testing best practicesList and summarize various testing toolsDescribe real-time testing 
Describe about error messages, the categories and what a good error message isDetermine error messages in well-designed applications, examples, and miscommunications in the error messagesPrepare a error message usability checklistDescribe guidelines for creating effective error messagesList the best practices for designing error messagesExplain the security issues in error messagesDescribe about security precautions in documentation | 
No comments:
Post a Comment