联系方式

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

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

日期:2021-10-09 10:22

CSCI 460: Networks and Communications

1 | P a g e

Project 1: File Transfer Protocol (FTP) Client

Software Application

Objectives

1. To learn how a computer network protocol is documented in a Request for Comments (RFC) by

Internet Engineering Taskforce (IETF) as an Internet Standard.

2. To understand File Transfer Protocol (FTP) from RFC 959.

3. To learn and use Unix Network or Socket programming API.

4. To implement FTP Client software according to Internet Standard outlined in RFC 959.

5. To implement FPT Client software using C++ programming language and Unix Network or Socket

programming API.

Specifications

You have been using File Transfer Protocol (FTP) to get or to store files from or to FTP servers.

You use a FTP Client software in your host computer to communicate with an FTP server. FTP

server runs a FTP Server software application. In this project, you are going to implement your

own FTP Client software application in C++ programming language using Unix Network or Socket

programming API.

FTP is a client-server protocol to transfer files to/from the servers. An FTP client sends FTP

request messagesto an FTP server. FTP server interprets the request message, takes appropriate

action, and sends back response message to the client. RFC 959 describes FTP and its request

and response messages in detail. You need to read and understand RFC 959 to complete this

project. Although, RFC 959 describes many request messages, you need to implement only the

followings:

o USER

o PASS

o PWD

o CWD

o CDUP

o PASV

o NLST

o RETR

o QUIT

CSCI 460: Networks and Communications

2 | P a g e

Your FTP Client software must have a command-line user interface (UI) so that the users can

enter commands through this interface. User commands of your application have different

syntax than that of FTP request messages. User commands are more human readable. A user

command has one or more corresponding FTP request message(s). Your software must accept

and process following user commands.

 help

 user <username>

 pass <password>

 pwd

 dir

 cwd <dirname>

 cdup

 get <filename>

 quit

Some of the user commands have an argument. For example, command user has an

argument <username>. A user command and its argument is always space separated.

– Command ‘help’ displays the list of commands supported by this software application, their

syntax, and meaning.

– Command ‘user’ sends username to the FTP server for authentication. You need to support

only one user with user name ‘csci460’ and password ‘460pass’.

– Command ‘pass’ sends the password to the FTP server for authentication.

– Command ‘pwd’ prints the current working directory of the FTP server.

– Command ‘dir’ lists the contents of the current working directory of the FTP server.

– Command ‘cwd’ changes the current working directory to another directory specified in the

argument. If the specified directory is beyond current working directory of FTP server, an

error is reported by the server.

– Command ‘cdup’ changes the current working directory to its parent directory. If the parent

directory is beyond server’s base directory, an error is reported by the server.

– Command ‘get’ fetches the specified file from the current working directory of FTP server. If

the specified file is not available an error is reported by the server.

– Command ‘quit’ informs FTP server that the client application is quitting, so that the server

can close the connection gracefully. It also closes the client connection gracefully and

terminates the software.

Your FTP client software application must interpret above user commands, translate them into

appropriate FTP request messages, send the FTP request messages to FTP server, receive the

CSCI 460: Networks and Communications

3 | P a g e

response messages from the server, and present the response to the user in a user-friendly

manner.

FTP Client and Server communicate request and response messages over a control connection.

Some requests/responsesinvolve a data transmission. For example, RETR request involves a data

transmission to transfer file content as the part of a successful response. FTP server uses a

separate connection for each data transmission. A data connection is opened on demand and

closed when a data transmission is complete. FTP server can operate either in active or in passive

mode. In active mode, FTP server opens the data connection with the client on demand. If the

client is behind a firewall, FTP active mode fails to open a data connection. In passive mode, when

a data connection is required the server opens a connection listener so that client can send

connection request to the listener and open a data connection. Client instructs the server to enter

into passive mode by sending a PASV request message to the server. The server opens the

connection listener on a port and sends the port number to the client in its PASV response. After

receiving the PASV response, the client retrieves listener port number and sends a connection

request to the listener port in order to open a data connection. In this project, you must

implement passive mode and your FTP client software application, must send a PASV request

before any data request, such as RETR and NLST.

Tasks

1. You will work on and submit this project using GIT submission system of the

department. A central repository named project1 has already been created for this

project.

2. You are allowed to do this project alone or with another student. Your team has to be

approved by your instructor before you proceed with your team work. If you are doing

the project alone, create your own fork of project1 on the central GIT repository using

following command. You should skip this step if you are doing the project in a team or

group.

ssh csci fork csci460/project1 csci460/$USER/project1

If you are working in a team, a forked repository for your team has already been

created. For example, the central repository for team1 is csci460/team1/project1. In

order to find out which team repository you have access to, type following command:

ssh csci info

3. Create a folder named csci460 in your home folder and go into your csci460 folder.

CSCI 460: Networks and Communications

4 | P a g e

4. Create a clone of your forked project1 repository using following command if you are

working alone:

git clone csci:csci460/$USER/project1

Create a clone of your forked team project1 repository using following command if you

are working in a team (assuming you are working in team1, replace team1 with your

own team):

git clone csci:csci460/team1/project1

5. Repository project1 has been organized as follows:

project1

bin

build

include

resource

src

Makefile

test

README

bin

build

include

src

example

bin

example

bin

CSCI 460: Networks and Communications

5 | P a g e

6. Continue your work in your cloned or local project1 repository and commit and push

your work to your central project1 repository as it progresses. Instructor is expecting

lots of incremental commits in the repository. Few number of commits is a red flag of

academic misconduct. Instructor, will take further steps to verify the integrity of your

work if there is any red flag of academic misconduct.

7. You will use supplied Makefile and Unix make utility to build, run, and test your

application. You don’t need to and should not modify this Makefile.

8. A README template file has been supplied. You will need to complete README file to

guide your user about your application. Complete your README file once you have

completed your project.

9. Following header (hpp) files have been supplied in include folder in the repository.

a. ftp_client_command.hpp

b. ftp_client_connection.hpp

c. ftp_client_session.hpp

d. ftp_client_ui.hpp

e. ftp_server_response.hpp

You will need to implement the functions specified in the header files in corresponding

source code files. For example, all functions in header file ‘ftp_client_command.hpp’

should be implemented in ‘ftp_client_command.cpp’ file. You are not allowed to

change any header file. If you modify any header file, your project will be evaluated to

zero.

10. All of your source code (cpp) files should be in src folder of the project. The source code

of ftp_client.cpp file has been supplied, you don’t need to and should not change this

code. Implement following cpp files in your src folder.

a. ftp_client_command.cpp

b. ftp_client_connection.cpp

c. ftp_client_session.cpp

d. ftp_client_ui.cpp

11. The lists of internal dependencies of the cpp files in this project are as follows.

i. ftp_client.cpp: ftp_client_session.hpp, ftp_client_ui.hpp,

ftp_client_command.hpp

ii. ftp_client_ui.cpp: ftp_client_ui.hpp

iii. ftp_client_connection.cpp: ftp_client_connection.hpp

CSCI 460: Networks and Communications

6 | P a g e

iv. ftp_client_sesion.cpp: ftp_client_session.hpp, ftp_client_connection.hpp,

ftp_client_command.hpp, ftp_client_ui.hpp, ftp_server_response.hpp

v. ftp_client_command.cpp: ftp_client_command.hpp, ftp_client_ui.hpp,

ftp_client_connection.hpp, ftp_client_session.hpp,

ftp_server_response.hpp

12. As mentioned earlier, you will build your FTP Client software application using build tool

make. Build tool make will compile your source codes from src folder and save all object

files in build folder. Build tool (make) will link all object files into a single executable and

save the binary file (‘ftpclient’) of the application in bin folder. Build tool will also link

necessary object files from test/build and build folders to create a test binary

(ftpclienttest) in test/bin folder.

13. An example FTP Client Application binary (ftpclient) and an example FTP Server

Application binary file (ftpserver) have been given in example/bin folder. An example

FTP Client Test binary (ftpclienttest) has been given in test/example/bin folder. Make

clean command will not delete these example binary files and don’t delete them

yourself either.

14. Test code file named ftp_client_test.cpp has been placed in test/src folder. Your

instructor has implemented all the functions prototyped in all the header files in

test/include folder in the corresponding source code files in test/src folder and these

source files are not exposed to you for technical reasons. You will not need to write

these test codes either. Compiled object file (ftp_client_test.o and

ftp_client_test_net_util.o) from your instructor’s test code have been supplied in

test/build folder and build tool make will use this object file and other object files from

your source code to create your test binary (ftpclienttest) in test/bin folder. Make clean

command will not delete this test object file and don’t delete them yourself either.

15. To see how the example ftpclienttest works for deliverable1 enter following from your

project root folder and observe console outputs.

>make test-example-deliverable1

These outputs will give you the idea about how many test cases your own code has to

pass. Your instructor recommends you to give close attention to these test cases. Your

project evaluation will suffer if your code does not pass all the test cases.

CSCI 460: Networks and Communications

7 | P a g e

16. To see how the example ftpclienttest works for deliverable2 enter following from your

project root folder and observe console outputs.

make test-example-deliverable2

17. To see how the example ftpclienttest works for deliverable1 and deliverable2 together

enter following from your project root folder and observe console outputs.

make test-example

18. In order to see how the example ftpclient works, you need to run both example

ftpserver and example ftpclient in separate shell terminals. You need to run the

example ftpserver first in one terminal and then the example ftpclient in another

terminal.

a. Open two terminals and go into your project root directory in both terminals.

b. In order to run example ftpserver, type following command in one terminal.

make run-example-server

c. In order to run example ftpclient, type following command in the other terminal.

make run-example-client

d. Example ftpclient will be connected to example ftpserver automatically and will

be ready to accept user commands and send the appropriate FTP requests to the

example server.

e. Play with all the commands that the FTP client has to support. If you play enough

with the example ftplclient and example ftpserver, it will give you good idea

what is expected from you to develop in this project.

Note that all the supplied binaries were built and tested only in Linux Debian machines

of the lab. Run them in other machines at your own risks.

19. Type make clean command from the project root folder to clean up the artefacts (binary

and object files) of the project and start with your own. Remember, not to delete any

artefact yourself using other means, always use make clean to clean up old artefacts.

20. Once your code is ready, build your own binaries ftpclient and ftpclienttest typing make

from the project root folder.

21. Type make test-deliverable1 to test the deliverable 1 using your own code.

22. Type make test-deliverable2 to test the deliverable 2 using your own code.

CSCI 460: Networks and Communications

8 | P a g e

23. Type make test to test both deliverable 1 and deliverable 2 together using your own

code.

24. In order to see how your own ftpclient performs, you will need to run it as well as the

example ftpserver in two separate terminals.

a) Open two terminals and go into your project root directory in both terminals.

b) In order to run the example ftpserver, type following command in one terminal.

make run-example-server.

c) In order to run your ftpclient, type following command in the other terminal.

make run-client.

d) Type user commands in your FTP Client application to see how the example server

responds against your commands.

25. Organize your code nicely and add adequate comments on your code. Type your name,

student number, and section number at the beginning of each cpp file that you have

contributed to. You can follow coding style shown in ‘ftp_client.cpp’. Make sure you have

deleted all debugging print codes that you were using to debug your code during your

development time but not necessary in the final code. Also, make sure you have deleted

all commented out codes from your final submission. The code with poor organization

and comments will also get poor evaluation.

26. Complete the README file. You need to give the general description of the application,

technologies that are used in the application, how a user can build (compile and link) and

install the application, how a user can run the application after the installation. Mention

instructor’s name and your name in the list of contributors. Give GPL license to the users

to use the application. You can google to find README examples if you are not sure how

to write one.

27. Commit and push your final code before the deadlines.

28. Commit and push the filled up contribution form if you have done your project in a

partnership with another student.

29. Your submission will be evaluated to zero if it does not compile and run.

30. Your submission will be tested by running automated test as well as by running as an

independent application for evaluation.

CSCI 460: Networks and Communications

9 | P a g e

Partnership

You are allowed to complete this project with another student. In that case, your

contributions must be marked in your source code. If you are the only contributor of a

function, you should mark yourself as the sole author of that function before the function

header. If you are the only contributor of all the functions in a file, you should mark yourself

as the sole author of the file at the beginning of the file. If both you and your partner have

contributed to write a function or all the functions of a file, both of you should mark

yourselves as the authors at appropriate place in the code. You and your partner must

complete, sign, and submit contribution form.

Deadlines and Submissions

This project has 2 incremental deliverables. The deadlines for the deliverables are as follows:

Project 1 S21N02 S21N01

Demonstration Code Submission Demonstration Code Submission

Deliverable 1 In the lab on

October 06,

2021

11:00 PM on

October 06, 2021

In the lab on

October 07,

2021

11:00 PM on

October 07, 2021

Deliverable 2 In the lab on

October 20,

2021

11:00 PM on

October 20, 2021

In the lab on

October 21`,

2021

11:00 PM on

October 21, 2021

Late completion/submission of any deliverable will be evaluated as zero.

Commit and push your work from your local repository to your remote repository regularly.

Use following git commands to commit and push your work from your local repository to your

remote repository from your project’s root folder:

git add --all

git commit –am”Commit message”

git push origin master

Remember ‘git add --all’ has double dashes before ‘all’. You can also use ‘git add .’ dot option

instead of ‘all’ option. Both options do the same, add all the new and the modified files into the

commit index. If you want to add only a specific file into the commit index, you can specify the

relative path of the file instead of dot or ‘all’ option. For example, if you want to add only prog.cpp

file of the src folder into the commit index, you can use ‘git add src/prog.cpp’ command. You can

also include multiple files or paths separated by space in the same ‘git add’ command instead of

CSCI 460: Networks and Communications

10 | P a g e

using multiple ‘git add’ commands. Command ‘git add’ is necessary before each ‘git commit’

command. If you skip ‘git add’ command before a ‘git commit’ command, it does not perform the

actual commit of the new and modified files into the repository. Always type a meaningful

message in your ‘git commit’ command’s ‘-m’ option. For example, if you are committing after

adding all the necessary comments into your ‘Makefile’, use ‘git commit –m“Added Makefile

comments”’. Remember there is a single dash before m in ‘git commit’ command. It is not

recommended to make a huge commit instead of a number of small commits. It is also

recommended to avoid unnecessary commits. Commits should reflect the check points of your

software development milestones. Command ‘git push’ is necessary to push the local commit to

the remote repository. If you skip ‘git push’ after a ‘git commit’, your local and remote repository

will become unsynchronized. You must keep your local and remote repositories synchronized

with each other using ‘git push’ after each ‘git commit’.

You will find most useful git commands in this git cheat sheet from GitLab. You will be allowed

to commit and push until the deadline is over. Incremental and frequent commits and pushes

are highly expected and recommended in this assignment.

Evaluation

Project1 Test Cases Commands Marks

Deliverable 1 ftp_client_ui 2.5

ftp_client_connection 20

ftp_client_session 5

ftp_client_command interpret 2.5

help 2.5

simple 5

user 2.5

pass 2.5

quit 2.5

45

Deliverable 2 ftp_client_command pwd 2.5

cwd 2.5

cdup 2.5

dir 15

get 15

README 5

Code Quality and

Comments

12.5 55

Total 100


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

python代写
微信客服:codinghelp