联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2020-03-03 10:09

IY2840 Coursework 2:

UNIX and Application Security

This is a blind submission, and submissions must be made in a ZIP compressed file on

Moodle. This compressed file should include the coursework report and necessary source-code

files. The report must be in file PDF format, other formats such as: .docx or .pages are not

accepted. This coursework counts for 10% of your grade on this module and is worth 100

marks in total. We expect a good submission to be succinct and be less than six pages in

length. Learning outcomes assessed are:

• Understanding of UNIX/Linux security and vulnerabilities.

• Understanding of UNIX/Linux Applications security and vulnerabilities.

• Understanding of how to exploit vulnerabilities and steps involved in their exploitation.

• Understanding of the countermeasures and mitigation for protecting applications.

This coursework aims to have you reflect on Unix and Application security. To get started,

it is important to review the lecture notes and lab materials, the course text, but also to

investigate online resources. We are not after essays in this coursework. We are after concise

and succinct responses to each question with some proof of implementation (code snippets

and screenshots). Do share useful resources that you find with others on the Moodle forum,

but do not give any answers away. Note: All the work you submit must be solely

your own work. Submissions are routinely checked for plagiarism.

IMPORTANT:

• SEEDLab VM (https://seedsecuritylabs.org/lab_env.html) should be used to

develop and test some solutions for this coursework, you can use the SEEDLab VM which

is already installed in the lab machines.

• Use the source file attachment (source − f iles − coursework.zip) for Question 2.e and

Question 3b & 3c.

• Keep in mind, all answers related to developing a program solution will be checked in the

SEEDLab VM, so it is important to make sure that your solutions being provided are

executable in this platform.

1

Questions

1. Question 1 (Total 25 marks):

(a) Briefly explain what these functions do in Linux: system(), popen(), and execve().

(3 marks)

(b) Briefly explain the name and the parameters of the execve() function. (2 marks)

(c) Write a small C program to show the /etc/passwd file using the execve() function

with a Linux command and report the output of running the program (show as a

screenshot). Briefly explain the program as comments in your code and submit the

C program. (5 marks)

(d) If we change the file to the /etc/shadow file in the previous program and run it

again. Briefly explain: what is the outcome? Why does this occur? Propose a

solution to defeat this without having a root access [hint: you may need to do some

investigation online to answer this question]. Briefly explain the commands used

and provide the results of applying them (screenshots). Submit the C program.

(15 marks)

2. Question 2 (Total 35 marks): Below follows a simple C program that spawns a shell with

execve(). Note: it invokes /bin/sh without any arguments, with an empty environment.

#include <unistd.h>

int main( ) {

char *name[2];

name[0] = "/bin/sh";

name[1] = NULL;

execve(name[0], name, NULL);

}

(a) Briefly explain what /bin/sh is in your own words? (3 marks)

(b) Compile and run the above program and briefly explain the output. (2 marks)

(c) In order to use the above program in buffer-overflow exploitation, we need

to disassemble the program to obtain its machine code. However, obtaining

self-contained, reproducible assembly program, across different compilers from this

C program, can be challenging and difficult if not done right. Therefore, it needs to

be simplified (see the code below). Briefly explain what these simplifications are in

the following code. Run the code and briefly explain the output to verify that it

works as expected. (5 marks)

2

#include <unistd.h>

int main(void) {

char buf[7 + 1 + 4 + 4] = "/bin/sh<garbage>";

*(buf + 7) = 0;

*((char**)(buf + 8)) = buf;

*((char**)(buf + 12)) = NULL;

syscall(11, buf + 0, buf + 8, buf + 12);

}

(d) When we disassemble the program above, we should get assembly code that resembles

the code below:

1 main: movl $buf, %esi

2 mov %esi,0x8(%esi)

3 mov $0,%eax

4 mov %al,0x7(%esi)

5 mov %eax,0xc(%esi)

6 mov $11,%al

7 mov %esi,%ebx

8 lea 0x8(%esi),%ecx

9 lea 0xc(%esi),%edx

10 int $0x80

11 buf: .ascii "/bin/sh<garbage>"

Briefly explain what each line do? Justify your answer by matching each

assembly-code line to the simplified version of C program (15 marks).

(e) Before you write your buffer overflow, you will need to make other changes to the

previous assembly code. We already did changes to generate a new version of this

program. Then, we converted it to an ASCII-coded program (opcode) to suite the

C input data as shown in the SHELLCODE macro within the code below. See if

you recognise those differences between the previous assembly program and the new

one being generated. Briefly explain: Why are these arrangements required? You

need to show how to reverse the value of SHELLCODE macro in the C program to

assembly instructions in order to be able to perform the comparison. For more guide

to answer this question, refer to Lab6 and the lecture notes. Finally, compile and run

code.c, then briefly explain the output (screenshots) (10 marks)

3

#include <stdio.h>

#include <string.h>

#define SHELLCODE "\xeb\x18\x5e\x89\x76\x08\x31\xc0\x88\x46

\x07\x89\x46\x0c\xb0\x0b\x89\xf3\x8d\x4e

\x08\x8d\x56\x0c\xcd\x80\xe8\xe3\xff\xff

\xff/bin/sh"

typedef void (*call)(void);

int main(void) {

unsigned char code[1024];

memcpy(code, SHELLCODE, strlen(SHELLCODE));

printf("Before.\n");

((call)code)();

printf("After.\n");

}

3. Question 3 (Total 40 marks):

(a) Briefly explain three countermeasures used in Linux to prevent stack-overflow

attacks . Include in your answer how to enable them or how to check if they are

already enabled. (10 marks)

(b) We have a C program (vulnerable.c) that is vulnerable to buffer-overflow (see the

source file attachment). In order to take advantage of this vulnerability to spawn a

shell, it is important to create an exploit program (see exploit.c). This program relies

on some of the code and instructions from the previous question (e.g. SHELLCODE,

execve(), etc.). However, this file becomes corrupted by having missing code and

values which are indicated by a question mark sign (?).

i. Fix the exploit.c file by completing the missing parts of this file, in other words,

replacing “?” with appropriate instructions or values to be able to compile

and run the exploit program. However, you need beforehand to understand the

buffer-overflow exploit program and how the shell code is injected to have such

an successful attack [Hint: you may need to review the stack frame layout]. You

may need to turn off the buffer-overflow countermeasure feature while compiling

and running the program. Explain the entire program after fixing it and provide

the output, justify your answer. To get the full mark of this part, the new

exploit program must be executable, so include the amended exploit.c file in

the submission. (18 marks)

ii. Briefly explain why the line below is desired for this particular exploitation.

(2 marks)

memset(envbuf + 10, 0x90, ENV_BLOCK_SIZE - 10 - strlen(SHELLCODE));

4

(c) Turn on the countermeasure which is associated with the space address randomisation

and run the exploit program again. Briefly explain the observation and provide a

screenshot. Then, write a shell script to defeat this countermeasure. The shell

script should also include a feature to display the cost of defeating using the metric

of either the actual time (hh:mm:ss) or the number of runs. Briefly explain the

scripts and provide a screenshot for the output. Also, include the shell script in the

submission. Note: In order to answer this part, you should have already solved the

previous question (Question 3a). (10 marks)

SD & JH 28 February 2020

5


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp