《管理系统中计算机应用》实践报告_第1页
《管理系统中计算机应用》实践报告_第2页
《管理系统中计算机应用》实践报告_第3页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、管理系统中计算机应用实践报告设计题目:管理系统中计算机应用助学院校:河南理工大学自考助学专业:机电设备管理与维修姓名:贺珂珂自考助学学号:040213200112成绩:指导教师签名:河南理工大学成人高等教育2O年 月曰1.软件编译理论及实践教程实习内容2.套接字编程62.1 使用说明书62.2 原理说明书72.3 程序注释73. 连接数据库193.1 使用说明书193.2 原理说明书203.3 程序注释204. 实习总结、体会与收获 26.1.软件编译理论及实践教程实习内容一:我的电脑磁盘分析:0000000000管理节点1000000003F000000003FC 盘(48.8GB)0006

2、1AB82700061AB827管理节点200061AB86600061AB866D 盘(73.4GB)000F48CDDA000F48CDDA分区间隙000F48CE18000F48CE18管理节点3000F48CE19000F48CE19E 盘(73.4GB)001876E38D001876E38D分区间隙001876E3CB001876E3CB管理节点4001876E3CC001876E3CCF 盘(102.4GB)0025422D6C1剩余扇区二.PING.EXE十六进制源码分析在文件存储空间中,pin g.exe十六进制源码分析如下:VOODOO 土翟D 30C00010 : BC;

3、 OQ:l 口C000 30 i UU :0000040 ;0£ jocooaso t 甜 30C00060 t 7叫 7 口g口曲口 ; g n口caao&o l S5 :0000090 :诞 JOCOOOMl r DZ DOOOOOBO $ DE 3DOOOOCD : 53 ccoodo : uti DoconaEO : i.占 occooro rtDE JDC00100 ; Cfi 3D000110 i 口( Juoaoiao L 04 30COG13O r 23 :DC00140 r OCsi goCO 00oo oc00 00IF BA73 iO20 626f冋FS

4、 9750nmnm snt DC s U(J :DU :OC:70 :oc f oo上t DC1 OO :SB2 OA 程E;DO :OOI. anre cs F& c? 讯朝 a on £9 02 01 07 oc10 00 00 00 70 00 00 10 00 OD0DO11 001110UD0000000000 05DOS71& 00 00 00an nraDODmt)Da!;?oB B B 3 3 fi- DDomoo u 8Do?030000OU oa 帖 20lb1C10 OD to 訂口 OQ a 00 oa noD3DO oa 5S nu 丄c D

5、O40THOU7吨CO20 g 缶 DO 4 FlOC 0000B4 右F 12 OP F7 )7 r? F? oa a 10 07 oa oa io oo Ltt oa 00 oa oo a OO oa 0 4 oa 知oa3300 nrt9即75M3B2.套接字编程2.1使用说明书:ao -0400oo -电。OCTw -WgDO -anOtJCD - Z1B372 - 61G&41 -2d旳口北-沁85B -15 *?3B -1JJF73B -D13B -DEP9F -0D口口 D - 0C000D -0C32qr,马吕00 - CC 弓0:I>-TTC$ DD-OC BO

6、阳-OC0D-oa兀QD-2G&D-ocDaDO-OCOUao-COoaao-00uDD-4602沛-QCOO-OCoaao-iczaao-OQoaE内1_警£忍DD-0DOKfid-0C8ao-se1000-00T犯-拆mnnrh匸£oMooMao囂0000ooooozlotlooOQaoL- DO 四 u J DI id &E 53 9©C2 nn u J an era i u J g ao oo nr u J aa aa z u J QQ £1 u J OQ 00 nnODODgoaoHfi3aaaoclno o _o a aFFo

7、ogDSCD“-14 口ao oa ao oo oo oo 加sido on uC 40 ao oo an oo46 40fl Bl E-S00a3546S.SE4Fsj00oa-?03*703F?93F79900DOCLD3:CODF00l_ J00co01D4a10oa(30OQ口 iCOoaDLtIXIaaco00aDOoa00alaaoaaDamEEa6dCM6000aDODOnnrifl1E271C1C004CE 幕00loecooaoooooIT.5头文件oc-riKiSicu0 003 E 3B J日 3BFF 00 0000010Q£ OC 0000oc0000 呼

8、ac ao ocXr ,9, rBi. ” flrfTlWT/MV rare,啊JF' 1 J6 t "第一步:先打开服务器端(server.exe 根据提示输入端口号,需要输入大于5001小于65535的值,否则就是用默认的5001作为端口值第二步:创建套接字并选择协议。第三步:打开客户端(client.exe,根据提示,将客户端(server.ex©所在的服务器的IP地址输入进去。第四步:输入在服务器端(server.exe中建立的端口号值。第五步:选择和服务器端(server.exe中一样的协议第六步:收发数据第七步:关闭连接。2.2原理说明书TCP服為器杆窖

9、户机模餾2.3程序注释* client.c - 简单的 TCP/UDP 套接字客户程序 windows 环境 * */ #include <winsock2.h>/ 关于套接字的头文件 #include <stdlib.h>#include <stdio.h>#include <string.h>#include <conio.h>#pragma comment (Iib,"ws2_32")添加 ws2_32 库int main(void)unsigned short port = 5001;/ 端口号int so

10、cket_type = SOCK_STREAM; / 缺省使用 TCP连接char Buffer1280; / 收发缓冲区 unsigned int addr; /IP 地址变量int retvaI,i;/ 临时变量struct sockaddr_in server, from; /套接字地址结构变量struct hostent *hp;/ 主机信息结构变量指针WSADATA wsaData;/windows 套接字信息SOCKET conn_socket;/ 套接字变量/ 先输入客户程序所需要的基本信息:服务器地址,端口号, 套接字类型printf(" 请输入服务器地址: &quo

11、t;);scanf("%s", Buffer);printf("请输入端口号(>5000 ):");scanf("%d", &i);if(i < 5000 | i > 65535)printf("不正确的端口号d,用缺省端口号5001n", i);elseport = i;printf("请输入套接字类型(1, TCP; 2, UDP ):"); scanf("%d",&i);if(i = 1)socket_type = SOCK_STREA

12、M; 设定为 SOCK_STREAM else if(i = 2)socket_type = SOCK_DGRAM;/ 设定为 SOCK_DGRAMelseprintf("不正确的输入d,使用TCP数据流n", i);/在windows环境下,需要先初始化协议栈if (retval = WSAStartup(0x202, &wsaData) != 0) /WSAStartup 函数调 用,用来初始 /socketprin tf("WSAStartup 失败,错误号:dn",retval);WSACleanup();当 调用了 WSAStartup

13、之后,就需要调用WSAClea nup函数释放内存return -1;/ 取得主机 IP 地址if (isalpha(Buffer0) / 是域名或命名地址,用首字母的是否在 AZ, 或者 a-z 来判断是域名还是 IP 地址hp = gethostby name(Buffer);/从一个主机数据库中提取出主机 信息elseaddr = inet_addr(Buffer);/ 是点分地址hp = gethostbyaddr(char *)&addr,4,AF_INET);/ 根据网络地址, 获得主机信息,执行成功,就返回一个指向主机信息的结构if (hp = NULL )printf(

14、" 不 能 解 析 地 址 %s: 错 误 号 %dn", Buffer,WSAGetLastError();/ 用于获取错误信息WSACleanup();exit(1);/拷贝解析的信息到sockaddr_in结构中memset(&server,0,sizeof(server);分配内存空间,由 server返回memcpy(&(server.sin_addr),hp->h_addr,hp->h_length);信息的 copyserver.sin_family = hp->h_addrtype;/组协议初始化server.sin_por

15、t = hton s(port);/ 端口号初始化/ 建立套接字conn_socket = socket(AF_INET,socket_type,0);if (conn_socket <0 )printf("socket()失败,错误号:dn", WSAGetLastError();WSACleanup();return -1;/ 对于流式套接字,需要先建立连接/其实也可以使用connect(),send(),recv等函数在windows里面一样实现数据报套接字功能if(socket_type != SOCK_DGRAM)printf("正在连接到:%sn

16、",hp->h_name);if(connect(conn_socket,(structsockaddr*)&server,sizeof(server) = SOCKET_ERROR)printf("connect() 失 败 , 错 误号: %dn",WSAGetLastError();closesocket(co nn_socket);如果创建失败,就关闭连接套接字WSACleanup(); return -1;while(1)/ 得到要发送的信息字符串puts("n 输入送到服务器的信息 :");gets(Buffer);i

17、f(!strlen(Buffer) / 如果没有输入信息,继续循环 continue;/ 发送网络信息if(socket_type != SOCK_DGRAM)retval = send(conn_socket, Buffer, strlen(Buffer)+1, 0); /面向 tcp,类似 BSD write()elseretval = sendto(conn_socket, Buffer, strlen(Buffer)+1, 0,/ 发送字符串的时候,须将字符串的结束符 0 发送(struct sockaddr*)&server, sizeof(server);/ 面向 UDPi

18、f (retval = SOCKET_ERROR)printf(" 发送失败,错误号: %dn", WSAGetLastError();break;elseprintf(" 发送信息: %sn", Buffer);/ 接收网络信息i = sizeof(from);if(socket_type != SOCK_DGRAM)retval = recv(conn_socket,Buffer, sizeof(Buffer), 0 );/ 面向tcp,类似 BSD read()elseretval = recvfrom(conn_socket, Buffer, s

19、izeof(Buffer), 0, (struct sockaddr*)&from, &i);/ 面向 UDPif (retval = SOCKET_ERROR)printf(" 接收信息失败,错误号: %dn",WSAGetLastError(); break;else if (retval = 0) / 对于面向连接的套接字,需要判断对方是 否关闭连接printf(" 服务器关闭连接 n"); break;else / 正确接收到网络信息prin tf("收到 d 字节信息:s n", retval, Buffer

20、);/ 程序的一个退出条件if(!stricmp(Buffer, "quit") break;/ 关闭套接字closesocket(conn_socket);WSACleanup();return 0;* server.c -简单 TCP/UDP 套接字服务器程序 windows 环境 */#include <winsock2.h>/ 套接字头文件#include <stdlib.h>#include <stdio.h>#include <string.h>#include <iostream.h>#pragma

21、comme nt(lib,"ws2_32") 添加库int main(void)unsigned short port= 5001;/ 端口号int socket_type = SOCK_DGRAM; / 缺省使用 TCP连接char Buffer1024;/ 收发缓冲区int retval, fromlen, i, isconnected = 0;/ 临时变量struct sockaddr_in local, from; / 套接字地址结构变量SOCKET listen_socket, msgsock;/ 套接字变量WSADATA wsaData; /windows 套接

22、字信息/ 先输入服务器程序所需要的基本信息:端口号,套接字类型printf("请输入端口号(>5000 ):");scanf("%d", &i);if(i < 5000 | i > 65535)printf("不正确的端口号d,用缺省端口号5001n",i);elseport = i;printf("请输入套接字类型(1, TCP; 2, UDP ):");scanf("%d", &i);if(i = 1)socket_type = SOCK_STREAM;el

23、se if(i = 2)socket_type = SOCK_DGRAM;elseprintf("不正确的输入d,使用TCP数据流n",i);/在windows环境下,需要先初始化协议栈if (retval = WSAStartup(0x202, &wsaData) != 0) / 初始化套接字版 本等信息printf("WSAStartup 失败,错误号: %dn", retval);WSACIea nup();在创建失败,或者程序结束,都要调用 return -1;/ 建立套接字Iisten_socket = socket(AF_INET,

24、socket_type, 0);if (Iisten_socket = INVALID_SOCKET)prin tf("socket(失败,错误号:dn", WSAGetLastError();WSACIeanup();return -1;/拷贝解析的信息到sockaddr_in结构中 IocaI.sin_famiIy = AF_INET;IocaI.sin_addr.s_addr = INADDR_ANY;local.sin_port = htons(port);/ 邦定网络地址到套接字if (bind(listen_socket,(struct sockaddr*)&a

25、mp;local, sizeof(local) ) =SOCKET_ERROR) / 绑定网络地址printf("bind() 失败,错误号: %dn", WSAGetLastError();WSACleanup();return -1;/ 对于流式套接字,让套接字处于监听状态,等待连接到来if (socket_type != SOCK_DGRAM)if (listen(listen_socket,5) = SOCKET_ERROR) / 监听网络pri ntf("liste n()失败,错误号:dn", WSAGetLastError();WSACle

26、anup();return -1;printf(" 监听端口: %d, 使用协议: %sn", port,(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,(struc

27、t sockaddr*)&from, &fromlen);if (msgsock = INVALID_SOCKET)prin tf("accept(失败,错误号:dn",WSAGetLastError();WSACleanup();return -1; isconnected = 1;printf(" 从 %s 收 到 连 接 , 端 口 是 : %dn", inet_ntoa(from.sin_addr), htons(from.sin_port);/ 等待接收网络信息if (socket_type != SOCK_DGRAM)retv

28、al =recv(msgsock, Buffer, sizeof (Buffer), 0 ); /面/ 向 tcp ,类似 BSD read()elseretval =recvfrom(msgsock, Buffer, sizeof (Buffer), 0,(struct sockaddr *)&from, &fromlen);/ 面向 UDPprintf(" 从 %s 收 到 数 据 报 , 端 口 是 : %dn", inet_ntoa(from.sin_addr), htons(from.sin_port);/ 结果判断if (retval = SOC

29、KET_ERROR)prin tf("recv()失败,错误号:dn", WSAGetLastError();closesocket(msgsock);continue;else if (retval = 0)printf(”客户端关闭连接n");closesocket(msgsock);continue;else / 正常接收prin tf("收到 %d 字节的数据:%s n", retval, Buffer); if (socket_type != SOCK_DGRAM)/对于TCP连接,我们收到"exit"有一个关闭连

30、 接的操作if(!stricmp(Buffer, "exit")printf("关闭TCP连接,等待下一次连接.n");closesocket(msgsock);isconnected = 0;continue;/ 信息回送printf(" 将同样的信息回送给客户端 .nn");printf("please input the message:n");scanf("%s",Buffer);if (socket_type != SOCK_DGRAM)retval = send(msgsock, B

31、uffer, strlen(Buffer)+1, 0); / 面 向tcp,类似 BSD write()elseretval = sendto(msgsock, Buffer, strlen(Buffer)+1, 0,(struct sockaddr *)&from, fromlen);/ 面向 UDPif (retval = SOCKET_ERROR)prin tf("se nd(失败,错误号:dn", WSAGetLastError();/ 程序的一个退出条件if(!stricmp(Buffer, "quit")break;WSACleanu

32、p();return 0;3.连接数据库3.1使用说明书第一步:在开始菜单中找到 SQL SERVER并打开 第二步:建立一个新的数据库。在 SQL SERVER 中建立一个名为 stude nt的数据库第三步:在 student 库下创建一个 Stu_Info 表,并在表中包含以下字段名:snum, sname ssex sage smajor。输入一些数据,进行测 试。第四步:在安全性中设置密码为 123. 第三步:编译生成可执行的文件,点击运行。根据提示框中的信息, 输入我们需要插入的数据。关闭程序。第四步:在次点击运行,查看我们插入的数据是否成功的插入。3.2原理说明通过 ADO 访问

33、数据库的技术进行数据库编程。我们需要在计算机 上配置数据源。配置数据源的过程,就是和让数据库的驱动程序来 对数据库进行操作,以便使我们再程序中,可以调用驱动程序来完 成我们需要完成的工作。处理 ADO 访问技术之外,还有 ODBC (开放式数据库互联)等。3.3程序注释/*利用 ADO 访问 MS SQL2000要求: 【1】输出 Stu_Info 表内的每一条记录【2】添加一条新记录【3】删除名字为 "李立 "的记录*/#import "c:Program FilesCommon FilesSystemADOmsado15.dll" / 导入动态链接库

34、,使我们可以使用 ADO 编程no_namespace rename("EOF", "EndOfFile") / 为了防止命名冲突,不 使用命名空间#include <iostream> / 标准输入输出流#include <iomanip> /for setw()using namespace std;class STU / 定义学生类public:char snum10; / 学号char sname10; /姓名char ssex2; /姓别long sage; /年龄char smajor20; / 专业public:ST

35、U()STU();int main()STU student; / 定义学生对象:CoInitialize(NULL); / 初始化 OLE/COM 库环境 ,为访问 ADO接口做准备_RecordsetPtr m_pRecordset("ADODB.Recordset"); /建/ 立记录集_ConnectionPtr m_pConnection("ADODB.Connection"); / 建立连接_bstr_t bstrSQL("select * from stu_info"); / 查询语句char * query_cmd =

36、 "DELETE FROM stu_info WHERE sname = ' 李 立'"try / 异常处理/ 创建 Connection 对象m_pConnection.CreateInstance("ADODB.Connection");/ 设置连接字符串,必须是 BSTR 型或者 _bstr_t 类型_bstr_t strConnect= "Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123;"/若数据库在网络上则 Serve为形如

37、(192.168.1.5,3340)/用户sa和密码123只是针对我的库m_pConnection->Open(strConnect,"","",adModeUnknown);if(m_pConnection=NULL)cerr<<"Lind data ERROR!n"/ 创建记录集对象m_pRecordset.CreateInstance(_uuidof(Recordset);/ 取得表中的记录 m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(

38、), adOpenDynamic,adLockOptimistic,adCmdText);_variant_t vsnum,vsname,vsage,vssex,vsmajor/;/ 对 应 库 中 的 snum,sname,sage,ssex,smajorcout << " 学号 姓名 年龄 姓别 专业 "cout << "nn"while (!m_pRecordset->EndOfFile) / 如果记录集没有到记录的尾端vsnum 二 m_pRecordset->GetCollect(_varia nt_t(lo

39、 ng)O);/这儿给字 段编号和字段名都可以vsname = m_pRecordset->GetCollect("sname");vsage = m_pRecordset->GetCollect("sage");vssex = m_pRecordset->GetCollect("ssex"); vsmajor = m_pRecordset->GetCollect("smajor");if (vsnum.vt != VT_NULL&&vsname.vt !=VT_NULL&a

40、mp;&vsage.vt != VT_NULL&&vssex.vt != VT_NULL&&vsmajor.vt != VT_NULL)/ 如 果不为空cout.setf(ios:left); / 设置左对齐cout << setw(14) << (char*)(_bstr_t)vsnum; / 输出学号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; / 输出专业 cout.unsetf(ios:left); /取消左对齐 cout << endl;m_pRecordset->MoveNext(); / 移到下一条记录cout << "nn"

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论