計(jì)算機(jī)網(wǎng)絡(luò)文件傳輸及管理系統(tǒng)課程設(shè)計(jì)報(bào)告_第1頁(yè)
已閱讀1頁(yè),還剩28頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  目錄</b></p><p><b>  摘要3</b></p><p>  第一章 課程設(shè)計(jì)要求4</p><p><b>  一、設(shè)計(jì)任務(wù)4</b></p><p>  1.1.1 課程設(shè)計(jì)內(nèi)容4</p><p>

2、;  1.1.2、課程設(shè)計(jì)的基本要求4</p><p>  二、設(shè)計(jì)基本思路及相關(guān)理論4</p><p>  1.2.1、TCP/IP協(xié)議4</p><p>  1.2.2、客戶機(jī)/服務(wù)器模型5</p><p>  1.2.3、設(shè)計(jì)基本思路5</p><p>  第二章 設(shè)計(jì)概要6</p>&

3、lt;p>  2.1 功能設(shè)計(jì)6</p><p>  2.2 程序系統(tǒng)功能模塊7</p><p>  2.3 功能分析8</p><p>  2.3.1 功能流程圖:8</p><p>  2.3.2 程序主要功能說明8</p><p>  第三章 調(diào)試分析與測(cè)試結(jié)果24</p>

4、<p>  3.1服務(wù)器端與客戶端24</p><p>  3.2文件管理的過程27</p><p>  第四章 設(shè)計(jì)總結(jié)29</p><p><b>  參考文獻(xiàn)29</b></p><p>  課程設(shè)計(jì)評(píng)分表30</p><p><b>  摘要</b>

5、;</p><p>  網(wǎng)絡(luò)的Socket數(shù)據(jù)傳輸是一種特殊的I/O,Socket也是一種文件描述符。Socket也具有一個(gè)類似于打開文件的函數(shù)調(diào)用Socket(),該函數(shù)返回一個(gè)整型的Socket描述符,隨后的連接建立、數(shù)據(jù)傳輸?shù)炔僮鞫际峭ㄟ^該Socket實(shí)現(xiàn)的。</p><p>  Socket接口是TCP/IP網(wǎng)絡(luò)的API,Socket接口定義了許多函數(shù)或例程,程序員可以用它們來開發(fā)

6、TCP/IP網(wǎng)絡(luò)上的應(yīng)用程序。要學(xué)Internet上的TCP/IP網(wǎng)絡(luò)編程,必須理解Socket接口。</p><p>  Socket接口設(shè)計(jì)者最先是將接口放在Unix操作系統(tǒng)里面的。如果了解Unix系統(tǒng)的輸入和輸出的話,就很容易了解Socket了。常用的Socket類型有兩種:流式Socket (SOCK_STREAM)和數(shù)據(jù)報(bào)式Socket(SOCK_DGRAM)。流式是一種面向連接的Socket,針對(duì)于面

7、向連接的TCP服務(wù)應(yīng)用;數(shù)據(jù) 報(bào)式Socket是一種無連接的Socket,對(duì)應(yīng)于無連接的UDP服務(wù)應(yīng)用。</p><p>  Socket接口是TCP/IP網(wǎng)絡(luò)的API,Socket接口定義了許多函數(shù)或例程,程序員可以用它們來開發(fā)TCP/IP網(wǎng)絡(luò)上的應(yīng)用程序。要學(xué)Internet上的TCP/IP網(wǎng)絡(luò)編程,必須理解Socket接口。</p><p>  關(guān)鍵字: Socket、文件傳輸、多線

8、程</p><p><b>  課程設(shè)計(jì)要求</b></p><p><b>  一、設(shè)計(jì)任務(wù)</b></p><p>  1.1.1 課程設(shè)計(jì)內(nèi)容</p><p>  文件傳輸協(xié)議的簡(jiǎn)單設(shè)計(jì)與實(shí)現(xiàn):學(xué)會(huì)利用已有網(wǎng)絡(luò)環(huán)境設(shè)計(jì)并實(shí)現(xiàn)簡(jiǎn)單應(yīng)用層協(xié)議,掌握TCP/IP網(wǎng)絡(luò)應(yīng)用程序基本的設(shè)計(jì)方法和實(shí)現(xiàn)技巧,

9、加深對(duì)客戶/服務(wù)器的工作模式的認(rèn)識(shí)。</p><p>  用socket 編程接口編寫程序,分別為客戶程序(ftpclient.cpp)和服務(wù)器程序(ftpserver.cpp)和管理程序。</p><p>  1.1.2、課程設(shè)計(jì)的基本要求</p><p>  .鞏固和加深對(duì)計(jì)算機(jī)網(wǎng)絡(luò)原理的理解,提高綜合運(yùn)用本課程所學(xué)知識(shí)的能力。</p><p

10、>  .培養(yǎng)選用參考書,查閱手冊(cè)及文獻(xiàn)資料的能力。培養(yǎng)獨(dú)立思考,深入研究,分析問題、解決問題的能力。</p><p>  .通過實(shí)際分析設(shè)計(jì)、編程調(diào)試,掌握計(jì)算機(jī)網(wǎng)絡(luò)通信的基本規(guī)程,以及協(xié)議的利用方法,體會(huì)體系結(jié)構(gòu)分層的思路。</p><p>  .能夠按要求編寫課程設(shè)計(jì)報(bào)告書,能正確闡述設(shè)計(jì)和設(shè)計(jì)結(jié)果、正確繪制系統(tǒng)和程序框圖。</p><p>  .通過課程

11、設(shè)計(jì),培養(yǎng)嚴(yán)謹(jǐn)?shù)目茖W(xué)態(tài)度,嚴(yán)肅認(rèn)真的工作作風(fēng),和團(tuán)隊(duì)協(xié)作精神。</p><p>  二、設(shè)計(jì)基本思路及相關(guān)理論</p><p>  1.2.1、TCP/IP協(xié)議</p><p>  TCP/IP協(xié)議是Internet最基本的協(xié)議、Internet國(guó)際互聯(lián)網(wǎng)絡(luò)的基礎(chǔ),由網(wǎng)絡(luò)層的IP協(xié)議和傳輸層的TCP協(xié)議組成。TCP/IP 定義了電子設(shè)備如何連入因特網(wǎng),以及數(shù)據(jù)如何在

12、它們之間傳輸?shù)臉?biāo)準(zhǔn)。協(xié)議采用了4層的層級(jí)結(jié)構(gòu),每一層都呼叫它的下一層所提供的網(wǎng)絡(luò)來完成自己的需求。通俗而言:TCP負(fù)責(zé)發(fā)現(xiàn)傳輸?shù)膯栴},一有問題就發(fā)出信號(hào),要求重新傳輸,直到所有數(shù)據(jù)安全正確地傳輸?shù)侥康牡亍?lt;/p><p>  TCP是面向連接的通信協(xié)議,通過三次握手建立連接,通訊完成時(shí)要拆除連接,由于TCP是面向連接的所以只能用于點(diǎn)對(duì)點(diǎn)的通訊。 </p><p>  TCP提供的是一種可靠

13、的數(shù)據(jù)流服務(wù),采用一種稱為“滑動(dòng)窗口”的方式進(jìn)行流量控制。TCP將它的信息送到更高層的應(yīng)用程序,例如Telnet的服務(wù)程序和客戶程序。應(yīng)用程序輪流將信息送回TCP層,TCP層便將它們向下傳送到IP層,設(shè)備驅(qū)動(dòng)程序和物理介質(zhì),最后到接收方。 </p><p>  1.2.2、客戶機(jī)/服務(wù)器模型</p><p>  網(wǎng)絡(luò)應(yīng)用層程序一般都是以客戶機(jī)/服務(wù)器模型的方式工作的,而因特網(wǎng)便是客戶機(jī)/服

14、務(wù)器模型的一個(gè)典型應(yīng)用。在這種工作方式中,一個(gè)服務(wù)器程序先啟動(dòng),并在一個(gè)熟知端口偵聽對(duì)服務(wù)器的請(qǐng)求,當(dāng)客戶機(jī)應(yīng)用程序需要某種服務(wù)時(shí),須向提供這種服務(wù)的服務(wù)器發(fā)出請(qǐng)求,服務(wù)器在接收到請(qǐng)求后,向客戶機(jī)發(fā)出響應(yīng)請(qǐng)求信息。這樣客戶機(jī)用用程序和服務(wù)器程序之間變建立了連接,此后可以進(jìn)行數(shù)據(jù)通信。通信任務(wù)完成后需要關(guān)閉它們之間的通信連接。</p><p>  圖1 客戶機(jī)/服務(wù)器模型的工作流程</p><

15、;p>  1.2.3、設(shè)計(jì)基本思路</p><p>  設(shè)計(jì)程序使客戶端連接的時(shí)候,服務(wù)器將會(huì)向客戶端發(fā)回一條消息告知它的IP地址,然后關(guān)閉連接并繼續(xù)接收端口的連接。建立各個(gè)命令功能對(duì)應(yīng)的函數(shù),發(fā)送請(qǐng)求,等待服務(wù)器端的服務(wù)。服務(wù)器端初始化WinSock,創(chuàng)建SOCKET,獲取主機(jī)信息,并對(duì)客戶端進(jìn)行會(huì)話,發(fā)送回復(fù)訊息給客戶端,響應(yīng)完畢后關(guān)閉連接,釋放WinSock。</p><p>

16、  模擬TCP/IP協(xié)議的工作模式,在雙方工作的時(shí)候開設(shè)一個(gè)熟知端口(4523),進(jìn)行數(shù)據(jù)的傳送與接收。</p><p>  模擬TCP工作機(jī)制,確定數(shù)據(jù)端口傳送數(shù)據(jù)時(shí),進(jìn)行分組傳送。</p><p>  服務(wù)器從打開開始,保持監(jiān)聽控制端口,當(dāng)用戶登陸成功后,主動(dòng)分配該用戶服務(wù)線程。</p><p>  在傳送數(shù)據(jù)的時(shí)候,為了確保不影響原程序的工作,應(yīng)獨(dú)立分配線程。

17、</p><p><b>  本設(shè)計(jì)基本圖如下:</b></p><p><b>  第二章 設(shè)計(jì)概要</b></p><p><b>  2.1 功能設(shè)計(jì)</b></p><p>  本項(xiàng)目是為了實(shí)現(xiàn)基于Socket進(jìn)行文件傳輸?shù)墓δ?。?xiàng)目的分析及設(shè)計(jì)要求如下:</p

18、><p>  1)整個(gè)系統(tǒng)中分為服務(wù)器端(Server)和客戶端(Client)</p><p>  2)服務(wù)器端可以對(duì)文件進(jìn)行管理,包括上傳,下載,刪除文件,重命名等</p><p>  3)客服端可以實(shí)現(xiàn)文件的上傳、下載以及查看服務(wù)器下默認(rèn)目錄的文件列表</p><p>  4)在程序中應(yīng)用多線程來實(shí)現(xiàn)多個(gè)客戶端同時(shí)對(duì)一個(gè)服務(wù)器端進(jìn)行請(qǐng)求操作

19、</p><p>  2.2 程序系統(tǒng)功能模塊</p><p><b>  圖2.1</b></p><p><b>  2.3 功能分析</b></p><p>  2.3.1 功能流程圖:</p><p>  圖2.2 面向連接的客戶機(jī)/服務(wù)器程序工作模型<

20、/p><p>  2.3.2 程序主要功能說明</p><p>  主要功能實(shí)現(xiàn)代碼如下:</p><p><b>  服務(wù)器端</b></p><p>  //server.cpp</p><p>  #include <stdio.h></p><p>  #i

21、nclude <stdlib.h></p><p>  #include <WinSock2.h></p><p>  #include <io.h></p><p>  #define LISTENPORT 12345</p><p>  #pragma comment(lib,"Wsock32

22、")</p><p>  #pragma comment(lib,"ws2_32")</p><p>  sendFile(SOCKET conSock)</p><p><b>  {</b></p><p>  printf("Prapare to send file\n&qu

23、ot;);</p><p>  char *sendBuf = new char[100];</p><p><b>  FILE *in;</b></p><p>  char infile[50] ; </p><p>  printf("選擇要傳輸?shù)奈募?quot;);</p><p&

24、gt;  scanf("%[^\n]s",infile);</p><p>  if((in=fopen(infile,"rb"))==NULL)</p><p><b>  {</b></p><p>  printf("Can't open the source file"

25、);</p><p><b>  exit(0);</b></p><p><b>  }</b></p><p>  printf("File name is %s\n", infile);</p><p>  // send file name to the client&l

26、t;/p><p>  send(conSock, infile, sizeof(infile), 0);</p><p>  int handle = open(infile, 0x0001);</p><p>  long file_len = filelength(handle);</p><p>  long file_len_bak =

27、file_len;</p><p>  printf("Size of the file is %d\n", file_len);</p><p>  // store the length of the file in sendBuffer</p><p><b>  int i;</b></p><p

28、>  for (i = 0; file_len > 9; i++)</p><p><b>  {</b></p><p>  sendBuf[i] = (file_len % 10);</p><p>  file_len = file_len / 10;</p><p><b>  }</

29、b></p><p>  sendBuf[i] = file_len % 10; </p><p>  send(conSock, sendBuf, i + 1, 0); </p><p>  printf("Transmission started\n");</p><p><b>  Sleep(1

30、);</b></p><p><b>  char ch;</b></p><p>  char chack;</p><p>  while (file_len_bak != 0)</p><p><b>  {</b></p><p>  ch = fgetc

31、(in);</p><p>  send(conSock, &ch, 1, 0);</p><p>  recv(conSock, &chack, 1, 0);</p><p>  file_len_bak--;</p><p>  printf(".");</p><p><

32、b>  }</b></p><p><b>  ch = EOF;</b></p><p>  send(conSock, &ch, 1, 0);</p><p>  printf("\nTransmission finished");</p><p><b>  

33、}</b></p><p>  int main()</p><p><b>  {</b></p><p>  WSADATA words; </p><p>  if(WSAStartup(MAKEWORD(2,2),&words)!=0) </p><p><

34、;b>  {</b></p><p>  printf("Winsock init failed!\n");</p><p><b>  } </b></p><p>  SOCKET listenSock, conSock;</p><p>  sockaddr_in r

35、emoteAddr;</p><p>  int remoteAddrLen, int ServerAddrLen;</p><p>  listenSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);</p><p>  if (listenSock == INVALID_SOCKET)</p><

36、p><b>  {</b></p><p>  printf("ListenSocket create failed!\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  soc

37、kaddr_in sin;</p><p>  sin.sin_family = AF_INET;</p><p>  sin.sin_port = htons(LISTENPORT);</p><p>  sin.sin_addr.S_un.S_addr = INADDR_ANY;</p><p>  ServerAddrLen = siz

38、eof(sin);</p><p>  if (bind(listenSock, (sockaddr *)&sin, ServerAddrLen) == SOCKET_ERROR)</p><p><b>  {</b></p><p>  printf("Bind error!\n");</p>&l

39、t;p><b>  return 0;</b></p><p><b>  }</b></p><p>  if (listen(listenSock, 2) == SOCKET_ERROR)</p><p><b>  {</b></p><p>  printf(&q

40、uot;Can't listen!\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  remoteAddrLen = sizeof(remoteAddr);</p><p>  while (TRUE)&l

41、t;/p><p><b>  {</b></p><p>  conSock = accept(listenSock, (sockaddr *)& remoteAddr, &remoteAddrLen);</p><p>  if (conSock == INVALID_SOCKET)</p><p><

42、;b>  {</b></p><p>  printf("Accept failed!\n");</p><p><b>  continue;</b></p><p><b>  }</b></p><p><b>  else</b>&

43、lt;/p><p><b>  {</b></p><p>  printf("Accept a new connect : %s \r\n", inet_ntoa(remoteAddr.sin_addr));</p><p>  sendFile(conSock);</p><p><b> 

44、 }</b></p><p><b>  }</b></p><p>  closesocket(conSock);</p><p>  closesocket(listenSock);</p><p>  WSACleanup();</p><p><b>  return

45、 1;</b></p><p><b>  }</b></p><p><b>  客戶端</b></p><p>  //client.cpp</p><p>  #include <stdio.h></p><p>  #include <s

46、tdlib.h></p><p>  #include <WinSock2.h></p><p>  #include <fstream></p><p>  using namespace std;</p><p>  #define SERVERPORT 12345</p><p> 

47、 #pragma comment(lib, "Wsock32")</p><p>  #pragma comment(lib, "ws2_32")</p><p>  receiveFile(SOCKET consock)</p><p><b>  {</b></p><p> 

48、 printf("Prepare to receive file\n");</p><p>  FILE *dest;</p><p>  char destfile[50];</p><p>  char recvBuff[100];</p><p>  // Receive name of the file</p

49、><p>  int namelen = recv(consock, recvBuff, 100, 0);</p><p>  memcpy(destfile, recvBuff, namelen);</p><p>  printf("Name of the file is %s \n", destfile);</p><p&g

50、t;  if((dest=fopen(destfile,"wb"))==NULL)</p><p><b>  {</b></p><p>  printf("Can't open the dest file");</p><p><b>  exit(0);</b><

51、/p><p><b>  } </b></p><p>  // Receive size of the file</p><p>  int flag_file_len = recv(consock, recvBuff, 100, 0);</p><p>  long file_len = 0;</p>&

52、lt;p>  for (int i = 0; flag_file_len != 0; i++)</p><p><b>  {</b></p><p>  long temp = recvBuff[i];</p><p>  for (int j = 0; j != i; j++)</p><p><b>

53、;  {</b></p><p>  temp = temp * 10;</p><p><b>  }</b></p><p>  file_len = file_len + temp; </p><p>  flag_file_len--;</p><p><b>  }

54、</b></p><p>  printf("Size of the file is %ld\n", file_len);</p><p>  printf("Ready to receive file\n");</p><p><b>  char ch;</b></p>&l

55、t;p>  char chack = 1;</p><p><b>  int n;</b></p><p>  while ( recv(consock, &ch, 1, 0))</p><p><b>  {</b></p><p>  fputc(ch, dest);</p

56、><p>  send(consock, &chack, 1, 0);</p><p>  file_len--;</p><p>  if (file_len == 0)</p><p><b>  {</b></p><p><b>  break;</b></

57、p><p><b>  }</b></p><p>  printf(".");</p><p><b>  }</b></p><p>  printf("\nTransmission finished\n");</p><p><

58、b>  }</b></p><p>  int main()</p><p><b>  {</b></p><p>  WSADATA words;</p><p>  if(WSAStartup(MAKEWORD(2,2),&words)!=0) </p><p&

59、gt;<b>  {</b></p><p>  printf("Winsock init failed\n");</p><p><b>  }</b></p><p>  SOCKET conSock;</p><p>  conSock = socket(AF_IN

60、ET, SOCK_STREAM, IPPROTO_TCP);</p><p>  if (conSock == INVALID_SOCKET)</p><p><b>  {</b></p><p>  printf("Socket create failed\n");</p><p><b&g

61、t;  return 0;</b></p><p><b>  }</b></p><p>  sockaddr_in servAddr;</p><p>  servAddr.sin_family = AF_INET;</p><p>  servAddr.sin_port = htons(SERVERPO

62、RT);</p><p>  servAddr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");</p><p>  if (connect(conSock, (sockaddr *)& servAddr, sizeof(servAddr)) == -1)</p><p><b>  

63、{</b></p><p>  printf("Connect failed\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p><b>  else</b></p>

64、;<p><b>  {</b></p><p>  printf("Connect to server succeed\n");</p><p>  receiveFile(conSock);</p><p><b>  }</b></p><p>  close

65、socket(conSock);</p><p>  WSACleanup();</p><p><b>  return 1;</b></p><p><b>  }</b></p><p><b>  管理系統(tǒng)</b></p><p>  #incl

66、ude <stdio.h></p><p>  #include <stdlib.h></p><p>  #include <ctype.h></p><p>  #include <string.h></p><p>  #include <time.h></p>

67、<p>  #define SYS_SIZE 0XFFFFF*100 </p><p>  #define BLOCK_SIZE 512 </p><p><b>  FILE *f;</b></p><p>  struct filsys{ </

68、p><p>  int s_nfree; </p><p>  long s_free[100]; </p><p>  int s_ninode; </p><p>  int s_inode[96]; </

69、p><p><b>  }*p;</b></p><p>  struct index_block{ </p><p>  int s_nfree;</p><p>  long s_free[96];</p><p><b>  }q;</b>&

70、lt;/p><p>  struct filelist{ </p><p>  char name[14]; </p><p>  int inode_num; </p><p><b>  }file;</b><

71、/p><p>  struct inode{ </p><p>  int i_size; </p><p>  int block_amount; </p><p>  long i_addr[16];

72、</p><p>  char create_time[25]; </p><p><b>  }inode;</b></p><p>  struct fcb{ </p><p>  char name[12]; &l

73、t;/p><p>  int inode_num; </p><p>  int used; </p><p>  int i_size; </p><p>  int block_amount; &l

74、t;/p><p>  long i_addr[16]; </p><p>  }fcb[5],*ptr;</p><p>  struct open_file_table{ </p><p>  int offset; </p><p

75、>  struct fcb* f_node; </p><p>  }table[5];</p><p>  struct fd{ </p><p>  struct open_file_table* t_node; </p><p><b>  }fd

76、[5];</b></p><p>  FILE* apply_room(char *sys_name) </p><p><b>  { </b></p><p>  f = fopen(sys_name,"w+b"); //創(chuàng)建一個(gè)新的可讀寫的二進(jìn)制文件</p><p&g

77、t;  fseek(f,SYS_SIZE,SEEK_SET); </p><p>  fputc(EOF, f); </p><p>  fclose(f);</p><p>  return fopen(sys_name,"r+b"); //打開一個(gè)可讀寫的二進(jìn)制文件</p>&l

78、t;p><b>  }</b></p><p>  void myfree(long block_num) </p><p><b>  { </b></p><p><b>  int i;</b></p><p>  if(p->s_nfree

79、<100) </p><p>  { </p><p>  p->s_free[p->s_nfree]=block_num;</p><p>  p->s_nfree++;</p><p><b>  }</b></p><p&

80、gt;  else </p><p>  { </p><p>  q.s_nfree=p->s_nfree; </p><p>  for(i=0;i<100;i++)</p><p>  q.s_free[i]=p->s_free[i];<

81、/p><p>  fseek(f,(block_num-1)*BLOCK_SIZE,SEEK_SET);</p><p>  fwrite(&q,sizeof(struct index_block),1,f); </p><p>  p->s_nfree=1; </p><p>  p->s_fr

82、ee[0]=block_num;</p><p><b>  }</b></p><p><b>  }</b></p><p>  long myalloc() </p><p>  { </p><p><b>

83、  int i;</b></p><p><b>  long a;</b></p><p>  p->s_nfree--;</p><p>  if(p->s_nfree==0){ </p><p>  a=p->s_free[0];</p><

84、;p>  fseek(f,(a-1)*BLOCK_SIZE,SEEK_SET);</p><p>  fread(&q,sizeof(struct index_block),1,f);</p><p>  p->s_nfree=q.s_nfree; </p><p>  for(i=0;i<100;i++)</p>

85、<p>  p->s_free[i]=q.s_free[i];</p><p><b>  return a;</b></p><p>  }else return p->s_free[p->s_nfree];</p><p><b>  }</b></p><p>

86、  void init() </p><p><b>  { </b></p><p><b>  int j;</b></p><p><b>  long i;</b></p><p>  p->s_nfree=1;&

87、lt;/p><p>  p->s_free[0]=0;</p><p>  p->s_ninode=96;</p><p>  for(i=0;i<96;i++)</p><p>  p->s_inode[i]=-1; </p><p>  for(i=22;i<=SYS

88、_SIZE/BLOCK_SIZE;i++)</p><p>  myfree(i); </p><p>  j=p->s_nfree+1;</p><p>  while(j<100)</p><p>  p->s_free[j++]=0; </p>&

89、lt;p>  fseek(f,0,SEEK_SET);</p><p>  fwrite(p,sizeof(struct filsys),1,f);</p><p><b>  }</b></p><p>  int ialloc(){ </p><p><b>

90、;  int i=0;</b></p><p>  while(p->s_inode[i]>=0) i++; </p><p>  p->s_inode[i]=0; </p><p>  p->s_ninode--;</p><p><b>  return i

91、;</b></p><p><b>  }</b></p><p>  int namei(char *name) </p><p><b>  { </b></p><p><b>  int k=0;</b></p>&l

92、t;p>  while(k<96){</p><p>  if(p->s_inode[k]!=-1){ </p><p>  fseek(f,BLOCK_SIZE+k*16,SEEK_SET);</p><p>  fread(&file,sizeof(struct filelist),1,f);</p><p&

93、gt;  if(!strcmp(file.name,name))</p><p>  return file.inode_num;</p><p><b>  }</b></p><p><b>  k++;</b></p><p><b>  };</b></p>

94、<p>  return -1; </p><p><b>  }</b></p><p>  int name_i(char *name) </p><p><b>  { </b></p><p><b>  in

95、t k=0;</b></p><p><b>  do</b></p><p><b>  {</b></p><p>  if(fcb[k].used==1) </p><p><b>  { </b></p><p

96、>  if(!strcmp(fcb[k].name,name)) </p><p>  return fcb[k].inode_num;</p><p><b>  }</b></p><p><b>  k++;</b></p><p>  }while(k<5);</p>

97、<p>  return -1; </p><p><b>  }</b></p><p>  void create() </p><p><b>  { </b></p><p>  int i,inode

98、_num;</p><p><b>  long t;</b></p><p>  char name[12];</p><p>  printf("input file name:");</p><p>  scanf("%s",name);</p><p&g

99、t;  getchar();</p><p>  if(namei(name)!=-1) printf("file exited!\n");</p><p><b>  else</b></p><p>  { </p><p>  inode_nu

100、m=ialloc(); </p><p>  strcpy(file.name,name);</p><p>  file.inode_num=inode_num;</p><p>  fseek(f,BLOCK_SIZE+inode_num*16,SEEK_SET);</p><p>  fwrite(&file,size

101、of(struct filelist),1,f);</p><p>  inode.i_size=0; </p><p>  inode.block_amount=0;</p><p>  for(i=0;i<16;i++) inode.i_addr[i]=0;</p><p><b>

102、  time(&t);</b></p><p>  strcpy(inode.create_time,ctime(&t));</p><p>  fseek(f,4*BLOCK_SIZE+inode_num*sizeof(struct inode),SEEK_SET);</p><p>  fwrite(&inode,sizeof

103、(struct inode),1,f);</p><p>  p->s_inode[inode_num]=0; </p><p>  printf("create sucessfully!\n");</p><p><b>  }</b></p><p><b>  }</

104、b></p><p>  void display() </p><p><b>  { </b></p><p><b>  int k;</b></p><p>  for(k=0;k<96;k++)</p><p><b&

105、gt;  {</b></p><p>  if(p->s_inode[k]>=0) </p><p><b>  {</b></p><p>  fseek(f,BLOCK_SIZE+k*16,SEEK_SET);</p><p>  fread(&file,sizeof(struct

106、filelist),1,f); </p><p>  printf("%s ",file.name);</p><p>  fseek(f,4*BLOCK_SIZE+file.inode_num*sizeof(struct inode),SEEK_SET);</p><p>  fread(&inode,sizeof(struct

107、 inode),1,f); </p><p>  printf("size:? ",inode.i_size);</p><p>  printf("time:%s\n",inode.create_time);</p><p><b>  }</b></p><p>&l

108、t;b>  };</b></p><p>  printf("\n");</p><p>  getchar();</p><p><b>  }</b></p><p>  void open_file() </p><p> 

109、 { int i=0,j=0,k=0;</p><p><b>  int m,n;</b></p><p>  char name[12];</p><p>  printf("input file's name:");</p><p>  scanf("%s",na

110、me);</p><p>  getchar();</p><p>  n=namei(name); </p><p>  if(n==-1) printf("file not exits!\n");</p><p>  else if(p->s_inode[n]>0) printf(&

111、quot;file have already been opened!\n");</p><p><b>  else{</b></p><p>  while(fcb[i].used==1) i++; </p><p>  while(table[j].f_node) j++; </p><p> 

112、 while(fd[k].t_node) k++; </p><p>  fd[k].t_node=&table[j]; </p><p>  table[j].f_node=&fcb[i]; </p><p>  strcpy(fcb[i].name,name);</p><p>  fcb[

113、i].inode_num=n;</p><p>  fcb[i].used=1;</p><p>  fseek(f,4*BLOCK_SIZE+n*sizeof(struct inode),SEEK_SET);</p><p>  fread(&inode,sizeof(struct inode),1,f);</p><p>  fc

114、b[i].i_size=inode.i_size;</p><p>  fcb[i].block_amount=inode.block_amount;</p><p>  for(m=0;m<16;m++) fcb[i].i_addr[m]=inode.i_addr[m];</p><p>  p->s_inode[n]=k+100;

115、</p><p>  printf("file is open!\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  void write_file() </p><p>  

116、{ int sizeQ2;</p><p>  int k,block_amount,n,size=0,i=0;</p><p>  long block_num;</p><p>  char ch,name[12];</p><p>  printf("input file's name:");</p&

117、gt;<p>  scanf("%s",name);</p><p>  getchar();</p><p>  n=name_i(name); </p><p>  if(n==-1) printf("file not exits or not open!\n");</p>&

118、lt;p><b>  else{</b></p><p>  k=p->s_inode[n]-100; </p><p>  ptr=fd[k].t_node->f_node;</p><p>  while(i<ptr->block_amount)</p><p><b>  

119、{</b></p><p>  block_num=ptr->i_addr[i];</p><p>  myfree(block_num);</p><p><b>  i++;</b></p><p><b>  }</b></p><p>  block

120、_amount=0;</p><p>  printf("input the context of the file:(end the file with '*')\n");</p><p>  while((ch=getchar())!='*'&&block_amount<16){</p><p

121、><b>  size++;</b></p><p>  if(sizeQ2==1){ </p><p>  block_num=myalloc(); </p><p>  inode.i_addr[block_amount]=ptr->i_addr[block_amount]=block_num;</p

122、><p>  block_amount++;</p><p>  fseek(f,(block_num-1)*BLOCK_SIZE,SEEK_SET);</p><p><b>  }</b></p><p>  fputc(ch,f);</p><p><b>  }</b>&

123、lt;/p><p>  getchar();</p><p>  inode.i_size=ptr->i_size=size;</p><p>  inode.block_amount=ptr->block_amount=block_amount;</p><p>  fseek(f,4*BLOCK_SIZE+n*sizeof(str

124、uct inode),SEEK_SET);</p><p>  fwrite(&inode,sizeof(struct inode),1,f); </p><p><b>  }</b></p><p><b>  }</b></p><p>  void read_file()

125、 </p><p><b>  { </b></p><p>  int k,n,block_amount,size;</p><p><b>  int i=0;</b></p><p>  long block_num;</p><p>  char nam

126、e[12],buf[512];</p><p>  printf("input file's name:");</p><p>  scanf("%s",name);</p><p>  getchar();</p><p>  n=name_i(name); </p>

127、<p>  if(n==-1) printf("file not exits or not open!");</p><p><b>  else</b></p><p><b>  {</b></p><p>  k=p->s_inode[n]-100;</p>&l

128、t;p>  ptr=fd[k].t_node->f_node;</p><p>  size=ptr->i_size;</p><p>  block_amount=ptr->block_amount;</p><p>  for(i=0;i<block_amount;i++)</p><p><b>

129、  {</b></p><p>  block_num=ptr->i_addr[i]; </p><p>  fseek(f,(block_num-1)*BLOCK_SIZE,SEEK_SET); </p><p>  if(size>512) {fread(buf,sizeof(char),512,f

130、); size=size-512;}</p><p><b>  else</b></p><p><b>  {</b></p><p>  fread(buf,sizeof(char),size,f); </p><p>  buf[size]='\0';</p&g

131、t;<p><b>  }</b></p><p>  printf("%s",buf);</p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n");<

132、;/p><p><b>  }</b></p><p>  void del_file() </p><p>  { int n,i=0;</p><p>  long block_num;</p><p>  char name[12];</p><p

133、>  printf("input file's name:");</p><p>  scanf("%s",name);</p><p>  getchar();</p><p>  n=namei(name); </p><p>  if(n==-1) printf(&

134、quot;file not exits!\n"); </p><p>  else if(p->s_inode[n]>0) printf("file is open now!Close it first\n");</p><p><b>  else{</b></p><p>  p->s

135、_inode[n]=-1; </p><p>  fseek(f,4*BLOCK_SIZE+n*sizeof(struct inode),SEEK_SET);</p><p>  fread(&inode,sizeof(struct inode),1,f); </p><p>  while(i<inode.block_amount){<

136、/p><p>  block_num=inode.i_addr[i];</p><p>  myfree(block_num); </p><p><b>  i++;</b></p><p><b>  }</b></p><p>  strcpy(file.name,

137、""); </p><p>  file.inode_num=0;</p><p>  fseek(f,BLOCK_SIZE+n*16,SEEK_SET);</p><p>  fwrite(&file,sizeof(struct filelist),1,f);</p><p>  printf("

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論