




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、精選文檔管理系統(tǒng)中計(jì)算機(jī)應(yīng)用實(shí)踐報(bào)告設(shè)計(jì)題目: 管理系統(tǒng)中計(jì)算機(jī)應(yīng)用 助學(xué)院校: 河南理工高校 自考助學(xué)專業(yè): 機(jī)電設(shè)備管理與修理 姓 名: 賀珂珂 自考助學(xué)學(xué)號(hào): 040213200112 成 績: 指導(dǎo)老師簽名: 河南理工高校成人高等教育2O 年 月 日目 錄1.軟件編譯理論及實(shí)踐教程實(shí)習(xí)內(nèi)容42.套接字編程62.1使用說明書62.2原理說明書72.3程序注釋73.連接數(shù)據(jù)庫193.1使用說明書193.2原理說明書203.3程序注釋204.實(shí)習(xí)總結(jié)、體會(huì)與收獲261.軟件編譯理論及實(shí)踐教程實(shí)習(xí)內(nèi)容一:我的電腦磁盤分析:0000000000 管理節(jié)點(diǎn)1000000003F000000003F
2、 C盤(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)制源碼分析在文件存儲(chǔ)空間中,ping.exe十六進(jìn)制源碼分析如下:2.
3、套接字編程2.1.使用說明書:第一步:先打開服務(wù)器端(server.exe).依據(jù)提示輸入端口號(hào),需要輸入大于5001小于65535的值,否則就是用默認(rèn)的5001作為端口值其次步:創(chuàng)建套接字并選擇協(xié)議。第三步:打開客戶端(client.exe),依據(jù)提示,將客戶端(server.exe)所在的服務(wù)器的IP地址輸入進(jìn)去。第四步:輸入在服務(wù)器端(server.exe)中建立的端口號(hào)值。第五步:選擇和服務(wù)器端(server.exe)中一樣的協(xié)議第六步:收發(fā)數(shù)據(jù)第七步:關(guān)閉連接。2.2原理說明書2.3程序注釋/* client.c - 簡潔的 TCP/UDP 套接字客戶程序 windows環(huán)境 */#
4、include <winsock2.h>/關(guān)于套接字的頭文件#include <stdlib.h>#include <stdio.h>#include <string.h>#include <conio.h>#pragma comment (lib,"ws2_32")/添加ws2_32庫int main(void) unsigned short port = 5001;/端口號(hào) int socket_type = SOCK_STREAM;/缺省使用TCP連接 char Buffer1280;/收發(fā)緩沖區(qū) unsig
5、ned int addr;/IP地址變量 int retval,i;/臨時(shí)變量 struct sockaddr_in server, from; /套接字地址結(jié)構(gòu)變量 struct hostent *hp;/主機(jī)信息結(jié)構(gòu)變量指針 WSADATA wsaData;/windows套接字信息 SOCKET conn_socket;/套接字變量/先輸入客戶程序所需要的基本信息:服務(wù)器地址,端口號(hào),套接字類型printf("請輸入服務(wù)器地址:");scanf("%s", Buffer);printf("請輸入端口號(hào)( >5000 ):"
6、);scanf("%d", &i);if(i < 5000 | i > 65535)printf("不正確的端口號(hào)%d,用缺省端口號(hào)5001n", i);elseport = i;printf("請輸入套接字類型( 1,TCP; 2, UDP ):");scanf("%d",&i);if(i = 1)socket_type = SOCK_STREAM;/設(shè)定為SOCK_STREAMelse if(i = 2)socket_type = SOCK_DGRAM;/設(shè)定為SOCK_DGRAMe
7、lseprintf("不正確的輸入%d,使用TCP數(shù)據(jù)流n", i);/在windows環(huán)境下,需要先初始化協(xié)議棧if (retval = WSAStartup(0x202, &wsaData) != 0) /WSAStartup函數(shù)調(diào)用,用來初始/socket printf("WSAStartup 失敗,錯(cuò)誤號(hào):%dn",retval); WSACleanup();/當(dāng)調(diào)用了WSAStartup之后,就需要調(diào)用WSACleanup函數(shù)釋放內(nèi)存 return -1; /取得主機(jī)IP地址 if (isalpha(Buffer0) /是域名或命名地址
8、,用首字母的是否在A-Z,或者a-z來推斷是域名還是IP地址 hp = gethostbyname(Buffer);/從一個(gè)主機(jī)數(shù)據(jù)庫中提取出主機(jī)信息 else addr = inet_addr(Buffer);/是點(diǎn)分地址 hp = gethostbyaddr(char *)&addr,4,AF_INET);/依據(jù)網(wǎng)絡(luò)地址,獲得主機(jī)信息,執(zhí)行成功,就返回一個(gè)指向主機(jī)信息的結(jié)構(gòu) if (hp = NULL ) printf("不能解析地址%s: 錯(cuò)誤號(hào)%dn", Buffer, WSAGetLastError();/用于獵取錯(cuò)誤信息 WSACleanup(); ex
9、it(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);/端口號(hào)初始化/建立套接字 conn_socket = socket(AF_INET,socket_type,0); if (conn
10、_socket <0 ) printf("socket()失敗,錯(cuò)誤號(hào):%dn", WSAGetLastError(); WSACleanup(); return -1; /對(duì)于流式套接字,需要先建立連接/其實(shí)也可以使用connect(),send(),recv()等函數(shù)在windows里面一樣實(shí)現(xiàn)數(shù)據(jù)報(bào)套接字功能if(socket_type != SOCK_DGRAM)printf("正在連接到: %sn",hp->h_name);if (connect(conn_socket,(struct sockaddr*)&server,s
11、izeof(server) = SOCKET_ERROR) printf("connect()失敗,錯(cuò)誤號(hào):%dn",WSAGetLastError(); closesocket(conn_socket);/假如創(chuàng)建失敗,就關(guān)閉連接套接字WSACleanup();return -1; while(1) /得到要發(fā)送的信息字符串 puts("n輸入送到服務(wù)器的信息:");gets(Buffer);if(!strlen(Buffer) /假如沒有輸入信息,連續(xù)循環(huán)continue;/發(fā)送網(wǎng)絡(luò)信息if(socket_type != SOCK_DGRAM) re
12、tval = send(conn_socket, Buffer, strlen(Buffer)+1, 0);/面對(duì)tcp,類似BSD write()else retval = sendto(conn_socket, Buffer, strlen(Buffer)+1, 0,/發(fā)送字符串的時(shí)候,須將字符串的結(jié)束符0發(fā)送(struct sockaddr*)&server, sizeof(server);/面對(duì)UDP if (retval = SOCKET_ERROR) printf("發(fā)送失敗,錯(cuò)誤號(hào): %dn", WSAGetLastError(); break; el
13、seprintf("發(fā)送信息:%sn", Buffer);/接收網(wǎng)絡(luò)信息i = sizeof(from);if(socket_type != SOCK_DGRAM) retval = recv(conn_socket, Buffer, sizeof(Buffer), 0 );/面對(duì)tcp,類似BSD read()elseretval = recvfrom(conn_socket, Buffer, sizeof(Buffer), 0,(struct sockaddr*)&from, &i);/面對(duì)UDP if (retval = SOCKET_ERROR) p
14、rintf("接收信息失敗,錯(cuò)誤號(hào):%dn",WSAGetLastError(); break; else if (retval = 0) / 對(duì)于面對(duì)連接的套接字,需要推斷對(duì)方是否關(guān)閉連接 printf("服務(wù)器關(guān)閉連接n"); break; else /正確接收到網(wǎng)絡(luò)信息printf("收到 %d 字節(jié)信息:%s n", retval, Buffer);/程序的一個(gè)退出條件if(!stricmp(Buffer, "quit") break; /關(guān)閉套接字 closesocket(conn_socket); WS
15、ACleanup();return 0;/* server.c - 簡潔 TCP/UDP 套接字服務(wù)器程序 windows環(huán)境 */#include <winsock2.h>/套接字頭文件#include <stdlib.h>#include <stdio.h>#include <string.h>#include <iostream.h>#pragma comment(lib,"ws2_32")/添加庫int main(void) unsigned short port= 5001;/端口號(hào) int socket
16、_type = SOCK_DGRAM;/缺省使用TCP連接 char Buffer1024;/收發(fā)緩沖區(qū) int retval, fromlen, i, isconnected = 0;/臨時(shí)變量 struct sockaddr_in local, from;/套接字地址結(jié)構(gòu)變量 SOCKET listen_socket, msgsock;/套接字變量 WSADATA wsaData;/windows套接字信息/先輸入服務(wù)器程序所需要的基本信息:端口號(hào),套接字類型printf("請輸入端口號(hào)( >5000 ):");scanf("%d", &
17、;i);if(i < 5000 | i > 65535)printf("不正確的端口號(hào)%d,用缺省端口號(hào)5001n",i);elseport = i;printf("請輸入套接字類型( 1,TCP; 2, UDP ):");scanf("%d", &i);if(i = 1)socket_type = SOCK_STREAM;else if(i = 2)socket_type = SOCK_DGRAM;elseprintf("不正確的輸入%d,使用TCP數(shù)據(jù)流n",i);/在windows環(huán)境下,
18、需要先初始化協(xié)議棧 if (retval = WSAStartup(0x202, &wsaData) != 0) /初始化套接字版本等信息 printf("WSAStartup 失敗,錯(cuò)誤號(hào):%dn", retval); WSACleanup();/在創(chuàng)建失敗,或者程序結(jié)束,都要調(diào)用 return -1; /建立套接字 listen_socket = socket(AF_INET, socket_type, 0); if (listen_socket = INVALID_SOCKET) printf("socket()失敗,錯(cuò)誤號(hào):%dn", W
19、SAGetLastError(); 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) ) = SOCKET_ERROR) /綁定網(wǎng)絡(luò)地址 printf("bind()失敗,錯(cuò)誤號(hào):%dn&quo
20、t;, WSAGetLastError(); WSACleanup(); return -1; /對(duì)于流式套接字,讓套接字處于監(jiān)聽狀態(tài),等待連接到來 if (socket_type != SOCK_DGRAM) if (listen(listen_socket,5) = SOCKET_ERROR) /監(jiān)聽網(wǎng)絡(luò) printf("listen()失敗,錯(cuò)誤號(hào):%dn", WSAGetLastError(); WSACleanup(); return -1; printf("監(jiān)聽端口:%d, 使用協(xié)議:%sn", port,(socket_type = SOC
21、K_STREAM)? "TCP": "UDP"); while(1) fromlen =sizeof(from); if (socket_type = SOCK_DGRAM ) msgsock = listen_socket;else if( isconnected = 0)/對(duì)于TCP連接,假如沒有連接,等待一個(gè)連接的到來 msgsock = accept(listen_socket,(struct sockaddr*)&from, &fromlen); if (msgsock = INVALID_SOCKET) printf(&quo
22、t;accept()失敗,錯(cuò)誤號(hào):%dn",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 ); /面對(duì)tcp,類似BSD read() else retval =
23、 recvfrom(msgsock, Buffer, sizeof (Buffer), 0, (struct sockaddr *)&from, &fromlen);/面對(duì)UDP printf("從%s收到數(shù)據(jù)報(bào),端口是:%dn", inet_ntoa(from.sin_addr), htons(from.sin_port); /結(jié)果推斷 if (retval = SOCKET_ERROR) printf("recv()失敗,錯(cuò)誤號(hào):%dn", WSAGetLastError(); closesocket(msgsock); contin
24、ue; else if (retval = 0) printf("客戶端關(guān)閉連接n"); closesocket(msgsock); continue; else /正常接收printf("收到 %d 字節(jié)的數(shù)據(jù):%s n", retval, Buffer);if (socket_type != SOCK_DGRAM)/對(duì)于TCP連接,我們收到"exit"有一個(gè)關(guān)閉連接的操作if(!stricmp(Buffer, "exit") printf("關(guān)閉TCP 連接,等待下一次連接.n");clos
25、esocket(msgsock);isconnected = 0;continue;/信息回送 printf("將同樣的信息回送給客戶端.nn");printf("please input the message:n");scanf("%s",Buffer); if (socket_type != SOCK_DGRAM) retval = send(msgsock, Buffer, strlen(Buffer)+1, 0);/面對(duì)tcp,類似BSD write() else retval = sendto(msgsock, Buffe
26、r, strlen(Buffer)+1, 0, (struct sockaddr *)&from, fromlen);/面對(duì)UDP if (retval = SOCKET_ERROR) printf("send()失敗,錯(cuò)誤號(hào):%dn", WSAGetLastError(); /程序的一個(gè)退出條件if(!stricmp(Buffer, "quit")break; WSACleanup();return 0;3.連接數(shù)據(jù)庫3.1使用說明書第一步:在開頭菜單中找到SQL SERVER并打開 其次步:建立一個(gè)新的數(shù)據(jù)庫。在SQL SERVER中建立一個(gè)
27、名為student的數(shù)據(jù)庫第三步:在student庫下創(chuàng)建一個(gè)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原理說明通過ADO訪問數(shù)據(jù)庫的技術(shù)進(jìn)行數(shù)據(jù)庫編程。我們需要在計(jì)算機(jī)上配置數(shù)據(jù)源。配置數(shù)據(jù)源的過程,就是和讓數(shù)據(jù)庫的驅(qū)動(dòng)程序來對(duì)數(shù)據(jù)庫進(jìn)行操作,以便使我們再程序中,可以調(diào)用驅(qū)動(dòng)程序來完成我們需要完成的工作。處理ADO訪問技術(shù)
28、之外,還有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)入動(dòng)態(tài)鏈接庫,使我們可以使用ADO編程no_namespace rename("EOF", "EndOfFile") /為了防止命名沖突,不使用命名空間#include <iostream>
29、; /標(biāo)準(zhǔn)輸入輸出流#include <iomanip> /for setw() using namespace std; class STU /定義同學(xué)類 public: char snum10; /學(xué)號(hào) char sname10; /姓名 char ssex2; /姓別 long sage; /年齡 char smajor20; /專業(yè) public: STU() STU() ; int main() STU student; /定義同學(xué)對(duì)象 :CoInitialize(NULL); / 初始化OLE/COM庫環(huán)境 ,為訪問ADO接口做預(yù)備 _RecordsetPtr m_pR
30、ecordset("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對(duì)象 m_pConnection.CreateIns
31、tance("ADODB.Connection"); / 設(shè)置連接字符串,必需是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只是針對(duì)我的庫 m_pConnection->Open(strConnect,"","",adModeUnknown);
32、if(m_pConnection=NULL) cerr<<"Lind data ERROR!n" / 創(chuàng)建記錄集對(duì)象 m_pRecordset.CreateInstance(_uuidof(Recordset); / 取得表中的記錄 m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(), adOpenDynamic,adLockOptimistic,adCmdText); _variant_t vsnum,vsname,vsage,vssex,vsmajor; /對(duì)應(yīng)庫中的snum,sname
33、,sage,ssex,smajor cout << "學(xué)號(hào) 姓名 年齡 姓別 專業(yè)" cout << "n-n" while (!m_pRecordset->EndOfFile) /假如記錄集沒有到記錄的尾端 vsnum = m_pRecordset->GetCollect(_variant_t(long)0);/這兒給字段編號(hào)和字段名都可以 vsname = m_pRecordset->GetCollect("sname"); vsage = m_pRecordset->GetColl
34、ect("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
35、:left); /設(shè)置左對(duì)齊cout << setw(14) << (char*)(_bstr_t)vsnum; /輸出學(xué)號(hào)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); /取消左對(duì)齊cout << endl; m_pRecordset->MoveNext(); /移到下一條記錄 cout << "n-n" /輸入將要插入的信息cout << "n請輸入你要添加的同學(xué)信息n" cout << "學(xué)號(hào):" cin >> student.snum; cout << "n姓名:" cin >> student.sna
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 直線的投影課件
- 2023-2024學(xué)年湖南省部分學(xué)校高二下學(xué)期7月期末聯(lián)考數(shù)學(xué)試題(解析版)
- 2023-2024學(xué)年福建省南平市高二下學(xué)期7月期末質(zhì)量檢測數(shù)學(xué)試題(解析版)
- 作業(yè)場地安全管理制度
- 供暖企業(yè)設(shè)備管理制度
- 供氧中心設(shè)備管理制度
- 供水公司庫房管理制度
- 供水單位薪酬管理制度
- 供熱公司安全信息及檔案管理制度
- 供熱外網(wǎng)施工管理制度
- 旅游景區(qū)規(guī)劃設(shè)計(jì)案例
- 鋼琴課件教學(xué)課件
- 國家開放大學(xué)《四史通講》形考作業(yè)1-3+大作業(yè)試卷ABC答案
- 電氣施工管理
- 【MOOC】天文探秘-南京大學(xué) 中國大學(xué)慕課MOOC答案
- FES手冊完整版本
- 云南省保山市(2024年-2025年小學(xué)六年級(jí)語文)部編版小升初模擬((上下)學(xué)期)試卷及答案
- 2024年西藏初中學(xué)業(yè)水平考試地理卷試題真題(含答案解析)
- 2024年廣西職業(yè)院校技能大賽高職組《供應(yīng)鏈管理》賽項(xiàng)規(guī)程
- 一年級(jí)口算題卡大全(80套口算練習(xí)題直接打印版)
- 手術(shù)室儀器設(shè)備管理制度
評(píng)論
0/150
提交評(píng)論