




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、管理系统中计算机应用实践 报告作者:日期:2管理系统中计算机应用实践报告设计题目:管理系统中计算机应用助学院校:河南理工大学自考助学专业:机电设备管理与维修姓 名:贺珂珂自考助学学号:040213200112成绩:指导教师签名:河南理工大学成人高等教育2O 年 月 日12目录1 .软件编译理论及实践教程实习内容 42 .套接字编程.6.2.1 使用说明书62.2 原理说明书72.3 程序注释73 .连接数据库.193.1 使用说明书193.2 原理说明书203.3 程序注释204 .实习总结、体会与收获 261.软件 论及实 实习内 一:我的电脑编译理 践教程 容磁盘分析:0000000000
2、管理节点1000000003F000000003FC 盘(48.8GB)00061AB82700061AB827管理节点200061AB86600061AB866D 盘(73.4GB)000F48CDDA000F48CDDA 分区间隙000F48CE18000F48CE18管理节点3000F48CE19000F48CE19E 盘(73.4GB)001876E38D001876E38D分区间隙001876E3CB001876E3CB管理节点4001876E3CC001876E3CCF 盘(102.4GB)0025422D6C1剩余扇区二.PING.EXE十六进制源码分析在文件存储空间中,ping
3、.exe十六进制源码分析如下:GDOCOOOO*DODQQOOia:EaDODoaza:DOoaaso:000D000040喧口 EoaosoI 8900000060;74ODOODQ70:6DBD:fgc?:REQgOg&Q:DEODO000BO:HEoDooaaco:520DOCDODOi DOoooDoarQi 16ODOODora00000100i C6!:gI 040D000130i 23ooooai4a;gOO0OD1SOgoODaooieo:doLDITOj oaaoooaiso 00000190 0D0001A0QDaoQica 000001!>Q OO1LOoo
4、oooiro : oo o? : oaooozia : oo0D000220 4V.2E 00000230 ; 00ODOQQZa : 0000 00 n 0O OE 7Q 65 656B3B 3B JB fiB OD4B OA OQ 00 00 o OD口 口 0 D 口口口o 070 o o o0OOOO2OD& 7 0 00070003 DO 叩 00 oa 72 2Q 2E LD IC 10 OD ID 口口 oa JO oo 口口 00 03 00 00 53 IC oa 钠00 74 g 20 叩 00 63 00 *口0 0 0 0 9 70 0 0 0 0 6 o Q
5、o Q 4 Fo o o o B 6oa oo oa od 22 oo la oo oz oo oa oo oo oo io oo oo oo ID OD00 - 04 00 OD -皿 00 - ao qo OD - DO 00 S - 21 Be 73 - 61 6D 6E - 20 69 OA - ZOO 3B - ID *b - id r? 3B - DE F8 30 - DE F3 - 00 00 qr-置30 45 00 - 00 00 00 - 00 32 oa - oo -io 口中 9口5 00 - 00 BO 的 * 00 00 OQ - g DO OD - 28 ZB O
6、D - 00 00OD OD ODoa cdU 口 口 O a o o O ,o o o o a o o o 0 4- D o o oo O O 口口 o O 一一 .o o o O 020 o o o O o O 1 O4 2 6 o E o 十口 一 d 端口 6 口 o o o o c 0口 o 0口HI 口 Q 0 4 co o o D n 口。口口!: o 9 0 n D Q Drb o 1 o B e o 8 o c £ os Q百产00 00 FF FF 00 00 00 00 DO OQ oa oo od oa co ao db oo oa Dl AC CD 54 2
7、0 63 61 6E 6E 6E 20 M 4F S3 00 CD OD 00 oa 98 3B ID F7 90 Q9 27 T7 99 C6 3B IC F7 9Q CZ 3B IC F7 98 00 00 OD DO 00 00 CO 4匚 DL 03 oa oo ed no or 00 00 00 00 00 00 00 00 CO 00 01 OD 05 叩 01 oa oo od 04 oa 04 oo ao io oo 00 00 10 00 OQ oo oo sc oo oa 00 00 OD DO DC a CIO OD OD Da oo od oo oa 00 00 00
8、00 00 do od gq oo 口口 00 口 oa oo od od oa 00 00 00 10 00 00 00 00 DO 00 Si 71 61 DO 00 oa cio od z 5 oa oa oo 40 no oa 00 00 00 & 00 00 00 OD 00 00 02 4g 40 OQ OD2.套接字编程2.1 .使用说明书:第一步:先打开服务器端(server.exe .根据提示输入端口号,需要输入大于5001小于65535的值,否则就是用默认的5001作为端口值第二步:创建套接字并选择协议。第三步:打开客户端(client.exe),根据提示,将客户端
9、(server.exe所在的服务器的IP地址输入进去。第四步:输入在服务器端(server.exe中建立的端口号值。第五步:选择和服务器端(server.exe中一样的协议第六步:收发数据第七步:关闭连接。2.2 原理说明书关闭连接(closcsockcO.眼外器端创建有接宇:收发数据1防ndAeiwi工作.站端(客户端)TCP服务器和客户机模型2.3 程序注释尸* client.c -简单的TCP/UDP套接字客户程序 windows环境*7*1#include <winsock2.h>关于套接字的头文件#include <stdlib.h>#include <
10、stdio.h>#include <string.h>#include <conio.h>#pragma comment (lib,"ws2_32")添力口 ' ws2_32'库int main(void)unsigned short port = 5001; 端 口 号int socket_type = SOCK_STREAM; 缺省使用 TCP 连接char Buffer1280; 收发缓冲区unsigned int addr; /IP 地址变量int retval,i; 临时变量struct sockaddr_in ser
11、ver, from; /度接字地址结构变量struct hostent *hp;主机信息结构变量指针WSADATA wsaData;/windows 套接字信息SOCKET conn_socket;套接字变量先输入客户程序所需要的基本信息: 服务器地址,端口号,套接字类型printf("请输入服务器地址:");scanf("%s", Buffer);printf("请输入端口号(>5000 ):");scanf("%d", &i);if(i < 5000 | i > 65535)print
12、f("不正确的端口号d,用缺省端口号5001n", i);elseport = i;printf(”请输入套接字类型(1, TCP; 2, UDP ):");scanf("%d",&i);if(i = 1)socket_type = SOCK_STREAM;设定为 SOCK_STREAMelse if(i = 2)socket_type = SOCK_DGRAM;设定为 SOCK_DGRAMelseprintf("不正确的输入d,使用TCP数据流n”, i);在windows环境下,需要先初始化协议栈if (retval =
13、WSAStartup(0x202, &wsaData) != 0) /WSAStartup 函数调用,用来初始/socketprintf("WSAStartup 失败,错误号:%dn",retval);WSACleanup();/当调用了 WSAStartup之后,就需要调用WSACleanup函数释放内存return -1;取得主机IP地址if (isalpha(Buffer0) 是域名或命名地址,用首字母的是否在A-Z,或者a-z来判断是域名还是IP地址hp = gethostbyname(Buffer);从一个主机数据库中提取出主机信息elseaddr = i
14、net_addr(Buffer);是点分地址hp = gethostbyaddr(char *)&addr,4,AF_INET);/ 根据网络地址,获得主机信息,执行成功,就返回一个指向主机信息的结构if (hp = NULL )printf("不能解析地址%s:错误号%d'n", Buffer,WSAGetLastError();用于获取错误信息WSACleanup();exit(1);/拷贝 解析的信息到sockaddr_in结构中memset(&server,0,sizeof(server);/HE内存空间,由 server返回memcpy(&
15、amp;(server.sin_addr),hp->h_addr,hp->h_length);信息的copyserver.sin_family = hp->h_addrtype;/组协议初始化server.sin_port = htons(port);/端口号初始化建立套接字conn_socket = socket(AF_INET,socket_type,0);if (conn_socket <0 ).printf("socket()失败,错误号:%d'n", WSAGetLastError();WSACleanup();return -1;
16、对于流式套接字,需要先建立连接其实也可以使用connect(),send(),recv(痔函数在windows里面一样实现数据报套接字功能if(socket_type != SOCK_DGRAM)printf("正在连接到:%sn",hp->h_name);if (connect(conn_socket,(structsockaddr*)&server,sizeof(server) =SOCKET_ERROR)printf("connect()失败,错误号:dn",WSAGetLastError();closesocket(conn_soc
17、ket);/口果创建失败,就关闭连接套接字WSACleanup();return -1;while(1)得到要发送的信息字符串puts("n输入送到服务器的信息:");gets(Buffer);if(!strlen(Buffer)/如果没有输入信息,继续循环 continue;发送网络信息if(socket_type != SOCK_DGRAM)retval = send(conn_socket, Buffer, strlen(Buffer)+1,0); /面向 tcp,类似 BSD write()elseretval = sendto(conn_socket, Buffe
18、r, strlen(Buffer)+1,0, /发送字符串的时候,须将字符串的结束符0发送(struct sockaddr*)&server, sizeof(server); / 面向UDPif (retval = SOCKET_ERROR)printf("发送失败,错误号: %dn",WSAGetLastError();break;elseprintf("发送信息:%sn", Buffer);13接收网络信息i = sizeof(from);if(socket_type != SOCK_DGRAM)retval = recv(conn_sock
19、et, Buffer, sizeof(Buffer), 0 );面向tcp,类似 BSD read()elseretval = recvfrom(conn_socket, Buffer, sizeof(Buffer), 0,(struct sockaddr*)&from, &i);面向 UDPif (retval = SOCKET_ERROR) printf(" 接收信息失败,错误号:dn",WSAGetLastError();break;else if (retval = 0) /对于面向连接的套接字,需要判断对方是否关闭连接printf("服务
20、器关闭连接n");break;else /任确接收到网络信息printf("收到 %d 字节信息:s n", retval, Buffer);程序的一个退出条件if(!stricmp(Buffer, "quit")break;关闭套接字closesocket(conn_socket);WSACleanup();return 0;I* server.c -简单TCP/UDP 套接字服务器程序 windows环境*I#include <winsock2.h>套接字头文件#include <stdlib.h>#include
21、<stdio.h>#include <string.h>#include <iostream.h>#pragma comment(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;傍接字地址结构
22、变量SOCKET listen_socket, msgsock; 套接字变量WSADATA wsaData;/windows套接字信息先输入服务器程序所需要的基本信息:端口号,套接字类型printf("请输入端口号(>5000 ):");scanf("%d", &i);if(i < 5000 | i > 65535)printf("不正确的端口号d,用缺省端口号5001n",i);elseport = i;printf(”请输入套接字类型(1, TCP; 2, UDP ):");scanf(&quo
23、t;%d", &i);if(i = 1)socket_type = SOCK_STREAM;else if(i = 2)socket_type = SOCK_DGRAM;elseprintf("不正确的输入d,使用TCP数据流n”,i);在windows环境下,需要先初始化协议栈if (retval = WSAStartup(0x202, &wsaData) != 0) 初始化套接字版本等信息printf("WSAStartup 失败,错误号:%dn", retval);WSACleanup();/在创建失败,或者程序结束,都要调用ret
24、urn -1;建立套接字listen_socket = socket(AF_INET, socket_type, 0);if (listen_socket = INVALID_SOCKET)printf("socket()失败,错误号:%d'n", WSAGetLastError();WSACleanup();return -1;/拷贝 解析的信息到sockaddr_in结构中local.sin_family = AF_INET;local.sin_addr.s_addr = INADDR_ANY;local.sin_port = htons(port);邦定网络地
25、址到套接字if (bind(listen_socket,(struct sockaddr*)&local, sizeof(local)= SOCKET_ERROR) 绑定网络地址printf("bind()失败,错误号:%dn", WSAGetLastError();WSACleanup();return -1;对于流式套接字,让套接字处于监听状态,等待连接到来if (socket_type != SOCK_DGRAM)if (listen(listen_socket,5) = SOCKET_ERROR) 监听网络printf("listen()失败,错误
26、号:%dn", WSAGetLastError();WSACleanup();return -1;17printf("监听端口: 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连接,如果没有连接,等待一个连接的到来msgsoc
27、k = accept(listen_socket,(struct sockaddr*)&from, &fromlen);if (msgsock = INVALID_SOCKET)printf("accept() 失 败, 错 误号:dn",WSAGetLastError();WSACleanup();return -1;isconnected = 1;printf("从 %s 收到连接,端 口是:d'n",inet_ntoa(from.sin_addr), htons(from.sin_port);一 一一等待接收网络信息if (
28、socket_type != SOCK_DGRAM)retval = recv(msgsock, Buffer, sizeof (Buffer), 0 ); 面向tcp,类似 BSD read()18elseretval = recvfrom(msgsock, Buffer, sizeof (Buffer), 0,(struct sockaddr *)&from, &fromlen);面 向UDPprintf("从s收到数据报,端口是:dn",inet_ntoa(from.sin_addr), htons(from.sin_port);一 一一结果判断if
29、(retval = SOCKET_ERROR) printf("recv()失败,错误号:%d'n", WSAGetLastError();closesocket(msgsock);continue;else if (retval = 0) printf("客户端关闭连接n");closesocket(msgsock);continue;else /任常接收printf("收到 %d 字节的数据:%s n", retval, Buffer);if (socket_type != SOCK_DGRAM)对于TCP连接,我们收到&
30、quot;exit”有一个关闭连接的操作if(!stricmp(Buffer, "exit") printf("关闭TCP连接,等待下一次连接n");closesocket(msgsock);isconnected = 0; continue;信息回送printf("将同样的信息回送给客户端 n'n");printf("please input the message:n");scanf("%s",Buffer);if (socket_type != SOCK_DGRAM)retval
31、= send(msgsock, Buffer, strlen(Buffer)+1, 0); /面向 tcp,类似 BSD write()elseretval = sendto(msgsock, Buffer, strlen(Buffer)+1, 0, (struct sockaddr *)&from, fromlen);面向UDPif (retval = SOCKET_ERROR) printf("send()失败,错误号: %dn", WSAGetLastError();程序的一个退出条件if(!stricmp(Buffer, "quit")b
32、reak;WSACleanup();return 0;203.连接数据库3.1 使用说明书第一步:在开始菜单中找到 SQL SERVER并打开第二步:建立一个新的数据库。在 SQL SERVER中建立一个名为student的数据库第三步:在student库下创建一个Stu_Info表,并在表中包含以下字段名:snum, sname, ssex sage smajor。输入一些数据,进行测试。第四步:在安全性中设置密码为 123.第三步:编译生成可执行的文件,点击运行。根据提示框中的信息, 输入我们需要插入的数据。关闭程序。第四步:在次点击运行,查看我们插入的数据是否成功的插入。3.2 原理说明
33、通过ADO访问数据库的技术进行数据库编程。我们需要在计算机上配置数据源。配置数据源的过程,就是和让数据库的驱动程序来对 数据库进行操作,以便使我们再程序中,可以调用驱动程序来完成我 们需要完成的工作。处理 ADO访问技术之外,还有 ODBC (开放式 数据库互联)等。3.3 程序注释尸*利用ADO访问MS SQL2000要求:【1】输出Stu_Info表内的每一条记录2添加一条新记录【3】删除名字为"李立"的记录*29*#import "c:Program FilesCommon FilesSystemADOmsado15.dll" V/导入动态链接库,
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:STU()STU();in
35、t 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 = "DELETE FROM stu_i
36、nfo WHERE sname ='李立'";try 异常处理/创建Connection对象m_pConnection.CreateInstance("ADODB.Connection");/设置连接字符串,必须是 BSTR型或者_bstr_t类型_bstr_tstrConnect="Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123;”;若数据库在网络上则 Server为形如(192.168.1.5,3340)用户sa和密码123只是针对我的库m_pCon
37、nection->Open(strConnect,"","",adModeUnknown);if(m_pConnection=NULL)cerr<<"Lind data ERROR!n"/创建记录集对象m_pRecordset.CreateInstance(_uuidof(Recordset);/取得表中的记录m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);_
38、variant_t vsnum,vsname,vsage,vssex,vsmajor;/对应库中的snum,sname,sage,ssex,smajorcout << "学号姓名年龄姓别专业";cout << "nn"while (!m_pRecordset->EndOfFile) 如果记录集没有至U记录的尾端vsnum = m_pRecordset->GetCollect(_variant_t(long)0);/归儿给字段编号和字段名都可以vsname = m_pRecordset->GetCollect(&q
39、uot;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&&vsage.vt != VT_NULL&&vssex.vt != VT_NULL&&a
40、mp;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;俑出性另 U cout <<setw(20) << (char*)(_bstr_t)vsmajor; 输出专业cout.unsetf(ios:left); 取消左对齐cout << endl;m_pRecordset->MoveNext(); 夥至 U 下条 t 己录cout << "nn" /输
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 高端私人飞机航线申请与全球旅行定制服务合同
- 房产处分权与抵押权解除及清偿协议
- 外贸企业单证处理外包派遣及培训合同
- 跨国房地产投资运营管理合同
- 肺癌新辅助治疗进展与临床实践
- 灾害救援私人直升机航拍空域申请及影像记录合同
- 建筑幕墙胶缝更换与节能效果评估协议
- 数据库资源运营权授权与市场推广合同
- 妇科手术护理操作规范
- Web前端开发技术项目教程(HTML5 CSS3 JavaScript)(微课版) 课件 5.1.13任务操作视频
- 五年级数学竞赛试题原创
- 教师听课评价记录表
- 十字头夹具设计说明书
- 物理高考最后一课课件
- 04S202 室内消火栓安装
- 电解质紊乱的心电图表现
- 2022年修改后的银行业G32表填报说明
- 巨量-信息流(初级)认证考试(重点)题库(含答案)
- 三年级硬笔书法课课件
- 佳发教育考试网上巡查系统(标准版)
- 投融资部面试题本
评论
0/150
提交评论