《管理系統(tǒng)中計算機(jī)應(yīng)用》實踐報告材料(總37頁)_第1頁
《管理系統(tǒng)中計算機(jī)應(yīng)用》實踐報告材料(總37頁)_第2頁
《管理系統(tǒng)中計算機(jī)應(yīng)用》實踐報告材料(總37頁)_第3頁
《管理系統(tǒng)中計算機(jī)應(yīng)用》實踐報告材料(總37頁)_第4頁
《管理系統(tǒng)中計算機(jī)應(yīng)用》實踐報告材料(總37頁)_第5頁
已閱讀5頁,還剩32頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、管理系統(tǒng)中計算機(jī)應(yīng)用實踐報告設(shè)計題目: 管理系統(tǒng)中計算機(jī)應(yīng)用 助學(xué)院校: 河南理工大學(xué) 自考助學(xué)專業(yè): 機(jī)電設(shè)備管理與維修 姓 名: 賀珂珂 自考助學(xué)學(xué)號: 040213200112 成 績: 指導(dǎo)教師簽名: 河南理工大學(xué)成人高等教育2O 年 月 日目 錄1.軟件編譯理論及實踐教程實習(xí)內(nèi)容42.套接字編程62.1使用說明書62.2原理說明書72.3程序注釋73.連接數(shù)據(jù)庫193.1使用說明書193.2原理說明書203.3程序注釋204.實習(xí)總結(jié)、體會與收獲261.軟件編譯理論及實踐教程實習(xí)內(nèi)容一:我的電腦磁盤分析:0000000000 管理節(jié)點(diǎn)1000000003F000000003F C盤(

2、48.8GB)00061AB82700061AB827 管理節(jié)點(diǎn)200061AB86600061AB866 D盤(73.4GB)000F48CDDA000F48CDDA 分區(qū)間隙000F48CE18000F48CE18 管理節(jié)點(diǎn)3000F48CE19000F48CE19 E盤(73.4GB)001876E38D001876E38D 分區(qū)間隙001876E3CB001876E3CB 管理節(jié)點(diǎn)4001876E3CC001876E3CC F盤(102.4GB)0025422D6C1 剩余扇區(qū) 二. PING.EXE十六進(jìn)制源碼分析在文件存儲空間中,ping.exe十六進(jìn)制源碼分析如下:2. 套接字編

3、程2.1.使用說明書:第一步:先打開服務(wù)器端(server.exe).根據(jù)提示輸入端口號,需要輸入大于5001小于65535的值,否則就是用默認(rèn)的5001作為端口值第二步:創(chuàng)建套接字并選擇協(xié)議。第三步:打開客戶端(client.exe),根據(jù)提示,將客戶端(server.exe)所在的服務(wù)器的IP地址輸入進(jìn)去。第四步:輸入在服務(wù)器端(server.exe)中建立的端口號值。第五步:選擇和服務(wù)器端(server.exe)中一樣的協(xié)議第六步:收發(fā)數(shù)據(jù)第七步:關(guān)閉連接。2.2原理說明書2.3程序注釋/* client.c - 簡單的 TCP/UDP 套接字客戶程序 windows環(huán)境 */#incl

4、ude /關(guān)于套接字的頭文件#include #include #include #include #pragma comment (lib,ws2_32)/添加ws2_32庫int main(void) unsigned short port = 5001;/端口號 int socket_type = SOCK_STREAM;/缺省使用TCP連接 char Buffer1280;/收發(fā)緩沖區(qū) unsigned int addr;/IP地址變量 int retval,i;/臨時變量 struct sockaddr_in server, from; /套接字地址結(jié)構(gòu)變量 struct hoste

5、nt *hp;/主機(jī)信息結(jié)構(gòu)變量指針 WSADATA wsaData;/windows套接字信息 SOCKET conn_socket;/套接字變量/先輸入客戶程序所需要的基本信息:服務(wù)器地址,端口號,套接字類型printf(請輸入服務(wù)器地址:);scanf(%s, Buffer);printf(請輸入端口號( 5000 ):);scanf(%d, &i);if(i 65535)printf(不正確的端口號%d,用缺省端口號5001n, i);elseport = i;printf(請輸入套接字類型( 1,TCP; 2, UDP ):);scanf(%d,&i);if(i = 1)socket

6、_type = SOCK_STREAM;/設(shè)定為SOCK_STREAMelse if(i = 2)socket_type = SOCK_DGRAM;/設(shè)定為SOCK_DGRAMelseprintf(不正確的輸入%d,使用TCP數(shù)據(jù)流n, i);/在windows環(huán)境下,需要先初始化協(xié)議棧if (retval = WSAStartup(0x202, &wsaData) != 0) /WSAStartup函數(shù)調(diào)用,用來初始/socket printf(WSAStartup 失敗,錯誤號:%dn,retval); WSACleanup();/當(dāng)調(diào)用了WSAStartup之后,就需要調(diào)用WSAClea

7、nup函數(shù)釋放內(nèi)存 return -1; /取得主機(jī)IP地址 if (isalpha(Buffer0) /是域名或命名地址,用首字母的是否在A-Z,或者a-z來判斷是域名還是IP地址 hp = gethostbyname(Buffer);/從一個主機(jī)數(shù)據(jù)庫中提取出主機(jī)信息 else addr = inet_addr(Buffer);/是點(diǎn)分地址 hp = gethostbyaddr(char *)&addr,4,AF_INET);/根據(jù)網(wǎng)絡(luò)地址,獲得主機(jī)信息,執(zhí)行成功,就返回一個指向主機(jī)信息的結(jié)構(gòu) if (hp = NULL ) printf(不能解析地址%s: 錯誤號%dn, Buffer,

8、 WSAGetLastError();/用于獲取錯誤信息 WSACleanup(); exit(1); / 拷貝 解析的信息到sockaddr_in結(jié)構(gòu)中 memset(&server,0,sizeof(server);/分配內(nèi)存空間,由server返回 memcpy(&(server.sin_addr),hp-h_addr,hp-h_length);/信息的copy server.sin_family = hp-h_addrtype;/組協(xié)議初始化 server.sin_port = htons(port);/端口號初始化/建立套接字 conn_socket = socket(AF_INET

9、,socket_type,0); if (conn_socket h_name);if (connect(conn_socket,(struct sockaddr*)&server,sizeof(server) = SOCKET_ERROR) printf(connect()失敗,錯誤號:%dn,WSAGetLastError(); closesocket(conn_socket);/如果創(chuàng)建失敗,就關(guān)閉連接套接字WSACleanup();return -1; while(1) /得到要發(fā)送的信息字符串 puts(n輸入送到服務(wù)器的信息:);gets(Buffer);if(!strlen(Bu

10、ffer) /如果沒有輸入信息,繼續(xù)循環(huán)continue;/發(fā)送網(wǎng)絡(luò)信息if(socket_type != SOCK_DGRAM) retval = send(conn_socket, Buffer, strlen(Buffer)+1, 0);/面向tcp,類似BSD write()else retval = sendto(conn_socket, Buffer, strlen(Buffer)+1, 0,/發(fā)送字符串的時候,須將字符串的結(jié)束符0發(fā)送(struct sockaddr*)&server, sizeof(server);/面向UDP if (retval = SOCKET_ERROR

11、) printf(發(fā)送失敗,錯誤號: %dn, WSAGetLastError(); break; elseprintf(發(fā)送信息:%sn, Buffer);/接收網(wǎng)絡(luò)信息i = sizeof(from);if(socket_type != SOCK_DGRAM) retval = recv(conn_socket, Buffer, sizeof(Buffer), 0 );/面向tcp,類似BSD read()elseretval = recvfrom(conn_socket, Buffer, sizeof(Buffer), 0,(struct sockaddr*)&from, &i);/面向

12、UDP if (retval = SOCKET_ERROR) printf(接收信息失敗,錯誤號:%dn,WSAGetLastError(); break; else if (retval = 0) / 對于面向連接的套接字,需要判斷對方是否關(guān)閉連接 printf(服務(wù)器關(guān)閉連接n); break; else /正確接收到網(wǎng)絡(luò)信息printf(收到 %d 字節(jié)信息:%s n, retval, Buffer);/程序的一個退出條件if(!stricmp(Buffer, quit) break; /關(guān)閉套接字 closesocket(conn_socket); WSACleanup();retur

13、n 0;/* server.c - 簡單 TCP/UDP 套接字服務(wù)器程序 windows環(huán)境 */#include /套接字頭文件#include #include #include #include #pragma comment(lib,ws2_32)/添加庫int main(void) unsigned short port= 5001;/端口號 int socket_type = SOCK_DGRAM;/缺省使用TCP連接 char Buffer1024;/收發(fā)緩沖區(qū) int retval, fromlen, i, isconnected = 0;/臨時變量 struct socka

14、ddr_in local, from;/套接字地址結(jié)構(gòu)變量 SOCKET listen_socket, msgsock;/套接字變量 WSADATA wsaData;/windows套接字信息/先輸入服務(wù)器程序所需要的基本信息:端口號,套接字類型printf(請輸入端口號( 5000 ):);scanf(%d, &i);if(i 65535)printf(不正確的端口號%d,用缺省端口號5001n,i);elseport = i;printf(請輸入套接字類型( 1,TCP; 2, UDP ):);scanf(%d, &i);if(i = 1)socket_type = SOCK_STREAM

15、;else if(i = 2)socket_type = SOCK_DGRAM;elseprintf(不正確的輸入%d,使用TCP數(shù)據(jù)流n,i);/在windows環(huán)境下,需要先初始化協(xié)議棧 if (retval = WSAStartup(0x202, &wsaData) != 0) /初始化套接字版本等信息 printf(WSAStartup 失敗,錯誤號:%dn, retval); WSACleanup();/在創(chuàng)建失敗,或者程序結(jié)束,都要調(diào)用 return -1; /建立套接字 listen_socket = socket(AF_INET, socket_type, 0); if (li

16、sten_socket = INVALID_SOCKET) printf(socket()失敗,錯誤號:%dn, WSAGetLastError(); WSACleanup(); return -1; / 拷貝 解析的信息到sockaddr_in結(jié)構(gòu)中 local.sin_family = AF_INET; local.sin_addr.s_addr = INADDR_ANY; local.sin_port = htons(port);/邦定網(wǎng)絡(luò)地址到套接字 if (bind(listen_socket,(struct sockaddr*)&local, sizeof(local) ) = S

17、OCKET_ERROR) /綁定網(wǎng)絡(luò)地址 printf(bind()失敗,錯誤號:%dn, WSAGetLastError(); WSACleanup(); return -1; /對于流式套接字,讓套接字處于監(jiān)聽狀態(tài),等待連接到來 if (socket_type != SOCK_DGRAM) if (listen(listen_socket,5) = SOCKET_ERROR) /監(jiān)聽網(wǎng)絡(luò) printf(listen()失敗,錯誤號:%dn, WSAGetLastError(); WSACleanup(); return -1; printf(監(jiān)聽端口:%d, 使用協(xié)議:%sn, port,

18、(socket_type = SOCK_STREAM)? TCP: UDP); while(1) fromlen =sizeof(from); if (socket_type = SOCK_DGRAM ) msgsock = listen_socket;else if( isconnected = 0)/對于TCP連接,如果沒有連接,等待一個連接的到來 msgsock = accept(listen_socket,(struct sockaddr*)&from, &fromlen); if (msgsock = INVALID_SOCKET) printf(accept()失敗,錯誤號:%dn

19、,WSAGetLastError(); WSACleanup(); return -1; isconnected = 1; printf(從%s收到連接, 端口是:%dn, inet_ntoa(from.sin_addr), htons(from.sin_port); /等待接收網(wǎng)絡(luò)信息 if (socket_type != SOCK_DGRAM) retval = recv(msgsock, Buffer, sizeof (Buffer), 0 ); /面向tcp,類似BSD read() else retval = recvfrom(msgsock, Buffer, sizeof (Buf

20、fer), 0, (struct sockaddr *)&from, &fromlen);/面向UDP printf(從%s收到數(shù)據(jù)報,端口是:%dn, inet_ntoa(from.sin_addr), htons(from.sin_port); /結(jié)果判斷 if (retval = SOCKET_ERROR) printf(recv()失敗,錯誤號:%dn, WSAGetLastError(); closesocket(msgsock); continue; else if (retval = 0) printf(客戶端關(guān)閉連接n); closesocket(msgsock); conti

21、nue; else /正常接收printf(收到 %d 字節(jié)的數(shù)據(jù):%s n, retval, Buffer);if (socket_type != SOCK_DGRAM)/對于TCP連接,我們收到exit有一個關(guān)閉連接的操作if(!stricmp(Buffer, exit) printf(關(guān)閉TCP 連接,等待下一次連接.n);closesocket(msgsock);isconnected = 0;continue;/信息回送 printf(將同樣的信息回送給客戶端.nn);printf(please input the message:n);scanf(%s,Buffer); if (s

22、ocket_type != SOCK_DGRAM) retval = send(msgsock, Buffer, strlen(Buffer)+1, 0);/面向tcp,類似BSD write() else retval = sendto(msgsock, Buffer, strlen(Buffer)+1, 0, (struct sockaddr *)&from, fromlen);/面向UDP if (retval = SOCKET_ERROR) printf(send()失敗,錯誤號:%dn, WSAGetLastError(); /程序的一個退出條件if(!stricmp(Buffer,

23、 quit)break; WSACleanup();return 0;3.連接數(shù)據(jù)庫3.1使用說明書第一步:在開始菜單中找到SQL SERVER并打開 第二步:建立一個新的數(shù)據(jù)庫。在SQL SERVER中建立一個名為student的數(shù)據(jù)庫第三步:在student庫下創(chuàng)建一個Stu_Info表,并在表中包含以下字段名:snum,sname,ssex,sage,smajor。輸入一些數(shù)據(jù),進(jìn)行測試。第四步:在安全性中設(shè)置密碼為123.第三步:編譯生成可執(zhí)行的文件,點(diǎn)擊運(yùn)行。根據(jù)提示框中的信息,輸入我們需要插入的數(shù)據(jù)。關(guān)閉程序。第四步:在次點(diǎn)擊運(yùn)行,查看我們插入的數(shù)據(jù)是否成功的插入。3.2原理說明通

24、過ADO訪問數(shù)據(jù)庫的技術(shù)進(jìn)行數(shù)據(jù)庫編程。我們需要在計算機(jī)上配置數(shù)據(jù)源。配置數(shù)據(jù)源的過程,就是和讓數(shù)據(jù)庫的驅(qū)動程序來對數(shù)據(jù)庫進(jìn)行操作,以便使我們再程序中,可以調(diào)用驅(qū)動程序來完成我們需要完成的工作。處理ADO訪問技術(shù)之外,還有ODBC(開放式數(shù)據(jù)庫互聯(lián))等。3.3程序注釋/*利用ADO訪問MS SQL2000要求: 【1】輸出Stu_Info表內(nèi)的每一條記錄【2】添加一條新記錄【3】刪除名字為李立的記錄 */#import c:Program FilesCommon FilesSystemADOmsado15.dll /導(dǎo)入動態(tài)鏈接庫,使我們可以使用ADO編程no_namespace rename

25、(EOF, EndOfFile) /為了防止命名沖突,不使用命名空間#include /標(biāo)準(zhǔn)輸入輸出流#include /for setw() using namespace std; class STU /定義學(xué)生類 public: char snum10; /學(xué)號 char sname10; /姓名 char ssex2; /姓別 long sage; /年齡 char smajor20; /專業(yè) public: STU() STU() ; int main() STU student; /定義學(xué)生對象 :CoInitialize(NULL); / 初始化OLE/COM庫環(huán)境 ,為訪問AD

26、O接口做準(zhǔn)備 _RecordsetPtr m_pRecordset(ADODB.Recordset); /建立記錄集 _ConnectionPtr m_pConnection(ADODB.Connection); /建立連接 _bstr_t bstrSQL(select * from stu_info); /查詢語句 char * query_cmd = DELETE FROM stu_info WHERE sname = 李立; try /異常處理 / 創(chuàng)建Connection對象 m_pConnection.CreateInstance(ADODB.Connection); / 設(shè)置連接字

27、符串,必須是BSTR型或者_(dá)bstr_t類型 _bstr_t strConnect= Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123; /若數(shù)據(jù)庫在網(wǎng)絡(luò)上則Server為形如(192.168.1.5,3340) /用戶sa和密碼123只是針對我的庫 m_pConnection-Open(strConnect,adModeUnknown); if(m_pConnection=NULL) cerrOpen(bstrSQL,m_pConnection.GetInterfacePtr(), adOpenDynamic

28、,adLockOptimistic,adCmdText); _variant_t vsnum,vsname,vsage,vssex,vsmajor; /對應(yīng)庫中的snum,sname,sage,ssex,smajor cout 學(xué)號 姓名 年齡 姓別 專業(yè); cout EndOfFile) /如果記錄集沒有到記錄的尾端 vsnum = m_pRecordset-GetCollect(_variant_t(long)0);/這兒給字段編號和字段名都可以 vsname = m_pRecordset-GetCollect(sname); vsage = m_pRecordset-GetCollect

29、(sage); vssex = m_pRecordset-GetCollect(ssex); vsmajor = m_pRecordset-GetCollect(smajor); if (vsnum.vt != VT_NULL&vsname.vt != VT_NULL&vsage.vt != VT_NULL&vssex.vt != VT_NULL&vsmajor.vt != VT_NULL)/如果不為空 cout.setf(ios:left); /設(shè)置左對齊cout setw(14) (char*)(_bstr_t)vsnum; /輸出學(xué)號cout setw(14) (char*)(_bstr_t)vsname; /輸出姓名cout setw(8) vsage.lVal; /輸出年齡cout setw(8) (char*)(_bstr_t)vssex; /輸出性別cout setw(20) (char*)(_bstr_t)vsmajor; /輸出專業(yè)cout.unsetf(ios:left); /取消左對齊cout MoveNex

溫馨提示

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

評論

0/150

提交評論