收藏 分享(赏)

《管理系统中计算机应用》实践报告.doc

上传人:tangtianxu1 文档编号:3066552 上传时间:2018-10-02 格式:DOC 页数:26 大小:409.62KB
下载 相关 举报
《管理系统中计算机应用》实践报告.doc_第1页
第1页 / 共26页
《管理系统中计算机应用》实践报告.doc_第2页
第2页 / 共26页
《管理系统中计算机应用》实践报告.doc_第3页
第3页 / 共26页
《管理系统中计算机应用》实践报告.doc_第4页
第4页 / 共26页
《管理系统中计算机应用》实践报告.doc_第5页
第5页 / 共26页
点击查看更多>>
资源描述

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

2、 PING.EXE 十0000000000 管理节点 1000000003F000000003F C 盘 (48.8GB)00061AB82700061AB827 管理节点 200061AB86600061AB866D 盘(73.4GB)000F48CDDA000F48CDDA 分区间隙000F48CE18000F48CE18 管理节点 3000F48CE19000F48CE19 E 盘(73.4GB)001876E38D001876E38D 分区间隙001876E3CB001876E3CB 管理节点 4001876E3CC001876E3CCF 盘(102.4GB)0025422D6C1剩余

3、扇区4六进制源码分析在文件存储空间中,ping.exe 十六进制源码分析如下:52. 套接字编程2.1.使用说明书:第一步:先打开服务器端(server.exe ).根据提示输入端口号,需要输入大于 5001 小于 65535 的值,否则就是用默认的 5001 作为端口值第二步:创建套接字并选择协议。第三步:打开客户端(client.exe),根据提示,将客户端(server.exe)所在的服务器的 IP 地址输入进去。第四步:输入在服务器端(server.exe )中建立的端口号值。第五步:选择和服务器端(server.exe )中一样的协议第六步:收发数据第七步:关闭连接。2.2 原理说明

4、书62.3 程序注释/* client.c - 简单的 TCP/UDP 套接字客户程序 windows 环境 */#include /关于套接字的头文件#include #include #include #include #pragma comment (lib,“ws2_32“)/添加ws2_32库int main(void)unsigned short port = 5001; /端口号int socket_type = SOCK_STREAM; /缺省使用 TCP 连接7char Buffer1280; /收发缓冲区unsigned int addr; /IP 地址变量int retv

5、al,i; /临时变量struct sockaddr_in server, from; /套接字地址结构变量struct hostent *hp; /主机信息结构变量指针WSADATA wsaData; /windows 套接字信息SOCKET conn_socket; /套接字变量/先输入客户程序所需要的基本信息:服务器地址,端口号,套接字类型printf(“请输入服务器地址: “);scanf(“%s“, Buffer);printf(“请输入端口号 ( 5000 ):“);scanf(“%d“, if(i 65535)printf(“不正确的端口号 %d,用缺省端口号 5001n“, i

6、);elseport = i;printf(“请输入套接字类型 ( 1,TCP; 2, UDP ):“);scanf(“%d“,8if(i = 1)socket_type = SOCK_STREAM;/设定为 SOCK_STREAMelse if(i = 2)socket_type = SOCK_DGRAM;/设定为 SOCK_DGRAMelseprintf(“不正确的输入 %d,使用 TCP 数据流n“, i);/在 windows 环境下,需要先初始化协议栈if (retval = WSAStartup(0x202, WSACleanup();/当调用了 WSAStartup 之后,就需要

7、调用WSACleanup 函数释放内存return -1;/取得主机 IP 地址if (isalpha(Buffer0) /是域名或命名地址,用首字母的是否在 A-Z,或者 a-z 来判断是域名还是 IP 地址hp = gethostbyname(Buffer);/从一个主机数据库中提取出主机信息else 9addr = inet_addr(Buffer);/是点分地址hp = gethostbyaddr(char *)/根据网络地址,获得主机信息,执行成功,就返回一个指向主机信息的结构if (hp = NULL ) printf(“不能解析地址 %s: 错误号%dn“, Buffer, WS

8、AGetLastError();/用于获取错误信息WSACleanup();exit(1);/ 拷贝 解析的信息到 sockaddr_in 结构中memset(/分配内存空间,由 server 返回memcpy(/信息的copyserver.sin_family = hp-h_addrtype;/组协议初始化server.sin_port = htons(port);/端口号初始化/建立套接字conn_socket = socket(AF_INET,socket_type,0);if (conn_socket h_name);if (connect(conn_socket,(struct so

9、ckaddr*)closesocket(conn_socket);/如果创建失败,就关闭连接套接字WSACleanup();return -1;while(1) /得到要发送的信息字符串puts(“n 输入送到服务器的信息:“);gets(Buffer);if(!strlen(Buffer) /如果没有输入信息,继续循环continue;/发送网络信息11if(socket_type != SOCK_DGRAM)retval = send(conn_socket, Buffer, strlen(Buffer)+1, 0); /面向 tcp,类似 BSD write()else retval =

10、 sendto(conn_socket, Buffer, strlen(Buffer)+1, 0, /发送字符串的时候,须将字符串的结束符0 发送(struct sockaddr*)/面向 UDPif (retval = SOCKET_ERROR) printf(“发送失败,错误号: %dn“, WSAGetLastError();break;elseprintf(“发送信息:%sn“, Buffer);/接收网络信息i = sizeof(from);if(socket_type != SOCK_DGRAM)retval = recv(conn_socket, Buffer, sizeof(B

11、uffer), 0 );/面向tcp,类似 BSD read()elseretval = recvfrom(conn_socket, Buffer, sizeof(Buffer), 0,(struct sockaddr*)/面向 UDPif (retval = SOCKET_ERROR) 12printf(“接收信息失败,错误号: %dn“,WSAGetLastError();break;else if (retval = 0) / 对于面向连接的套接字,需要判断对方是否关闭连接printf(“服务器关闭连接 n“);break;else /正确接收到网络信息printf(“收到 %d 字节信

12、息:%s n“, retval, Buffer);/程序的一个退出条件if(!stricmp(Buffer, “quit“) break;/关闭套接字closesocket(conn_socket);WSACleanup();return 0;/* server.c - 简单 TCP/UDP 套接字服务器程序 windows 环境 */#include /套接字头文件#include #include 13#include #include #pragma comment(lib,“ws2_32“)/添加库int main(void)unsigned short port= 5001; /端口

13、号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 套接字信息/先输入服务器程序所需要的基本信息:端口号,套接字类型printf(“请输入端口号 ( 5000 ):“);scanf(“%d“, if(i 65535)p

14、rintf(“不正确的端口号 %d,用缺省端口号 5001n“,i);elseport = i;14printf(“请输入套接字类型 ( 1,TCP; 2, UDP ) :“);scanf(“%d“, 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, WSACleanup();/在创建失败,或者程序结束,都要调用r

15、eturn -1;/建立套接字listen_socket = socket(AF_INET, socket_type, 0); if (listen_socket = INVALID_SOCKET)printf(“socket()失败,错误号:%dn“, WSAGetLastError();WSACleanup();return -1;/ 拷贝 解析的信息到 sockaddr_in 结构中15local.sin_family = AF_INET;local.sin_addr.s_addr = INADDR_ANY; local.sin_port = htons(port);/邦定网络地址到套接

16、字if (bind(listen_socket,(struct sockaddr*)WSACleanup();return -1;/对于流式套接字,让套接字处于监听状态,等待连接到来if (socket_type != SOCK_DGRAM) if (listen(listen_socket,5) = SOCKET_ERROR) /监听网络printf(“listen()失败,错误号:%dn“, WSAGetLastError();WSACleanup();return -1;printf(“监听端口: %d, 使用协议:%sn“, port,(socket_type = SOCK_STREA

17、M)? “TCP“: “UDP“);while(1)fromlen =sizeof(from); if (socket_type = SOCK_DGRAM )msgsock = listen_socket;16else if( isconnected = 0)/对于 TCP 连接,如果没有连接,等待一个连接的到来msgsock = accept(listen_socket,(struct sockaddr*)if (msgsock = INVALID_SOCKET) printf(“accept()失败,错误号:%dn“,WSAGetLastError();WSACleanup();retur

18、n -1;isconnected = 1;printf(“从%s 收到连接, 端口是:%dn“, inet_ntoa(from.sin_addr), htons(from.sin_port);/等待接收网络信息if (socket_type != SOCK_DGRAM)retval = recv(msgsock, Buffer, sizeof (Buffer), 0 ); /面向 tcp,类似 BSD read()elseretval = recvfrom(msgsock, Buffer, sizeof (Buffer), 0, (struct sockaddr *)/面向 UDPprintf

19、(“从%s 收到数据报,端口是:%dn“, inet_ntoa(from.sin_addr), htons(from.sin_port);/结果判断if (retval = SOCKET_ERROR) 17printf(“recv()失败,错误号: %dn“, WSAGetLastError();closesocket(msgsock);continue;else if (retval = 0) printf(“客户端关闭连接 n“);closesocket(msgsock);continue;else /正常接收printf(“收到 %d 字节的数据:%s n“, retval, Buffe

20、r);if (socket_type != SOCK_DGRAM)/对于 TCP 连接,我们收到“exit“有一个关闭连接的操作if(!stricmp(Buffer, “exit“) printf(“关闭 TCP 连接,等待下一次连接.n“);closesocket(msgsock);isconnected = 0;continue;18/信息回送printf(“将同样的信息回送给客户端 .nn“);printf(“please input the message:n“);scanf(“%s“,Buffer);if (socket_type != SOCK_DGRAM)retval = sen

21、d(msgsock, Buffer, strlen(Buffer)+1, 0); /面向tcp,类似 BSD write()elseretval = sendto(msgsock, Buffer, strlen(Buffer)+1, 0, (struct sockaddr *)/面向 UDPif (retval = SOCKET_ERROR) printf(“send()失败,错误号: %dn“, WSAGetLastError();/程序的一个退出条件if(!stricmp(Buffer, “quit“)break;WSACleanup();return 0;193.连接数据库3.1 使用说

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

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

24、e“) /为了防止命名冲突,不使用命名空间#include /标准输入输出流#include /for setw() using namespace std; class STU /定义学生类 public:char snum10; /学号 char sname10; /姓名 char ssex2; /姓别 long sage; /年龄 char smajor20; /专业 public:STU() STU() ; int main() STU student; /定义学生对象:CoInitialize(NULL); / 初始化 OLE/COM 库环境 ,为访问 ADO接口做准备 _Recor

25、dsetPtr m_pRecordset(“ADODB.Recordset“); /建立记录集22_ConnectionPtr m_pConnection(“ADODB.Connection“); /建立连接_bstr_t bstrSQL(“select * from stu_info“); /查询语句 char * query_cmd = “DELETE FROM stu_info WHERE sname = 李立“; try /异常处理 / 创建 Connection 对象 m_pConnection.CreateInstance(“ADODB.Connection“); / 设置连接字符

26、串,必须是 BSTR 型或者_bstr_t 类型 _bstr_t strConnect= “Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123;“; /若数据库在网络上则 Server 为形如(192.168.1.5,3340) /用户 sa 和密码 123 只是针对我的库 m_pConnection-Open(strConnect,“,“,adModeUnknown); if(m_pConnection=NULL) cerrOpen(bstrSQL,m_pConnection.GetInterfacePtr()

27、, adOpenDynamic,adLockOptimistic,adCmdText); _variant_t vsnum,vsname,vsage,vssex,vsmajor; /对应库中的snum,sname,sage,ssex,smajor 23cout EndOfFile) /如果记录集没有到记录的尾端 vsnum = m_pRecordset-GetCollect(_variant_t(long)0);/这儿给字段编号和字段名都可以 vsname = m_pRecordset-GetCollect(“sname“); vsage = m_pRecordset-GetCollect(“

28、sage“); vssex = m_pRecordset-GetCollect(“ssex“); vsmajor = m_pRecordset-GetCollect(“smajor“); if (vsnum.vt != VT_NULL /设置左对齐cout MoveNext(); /移到下一条记录 cout student.snum; cout student.sname; cout student.sage; cout student.ssex; cout student.smajor; m_pRecordset-MoveFirst(); /移动到第一条记录 m_pRecordset-Add

29、New(); /添加新记录 m_pRecordset-PutCollect(“snum“,_variant_t(student.snum); /将数据添加进去输入库m_pRecordset-PutCollect(“sname“,_variant_t(student.sname); m_pRecordset-PutCollect(“sage“,_variant_t(student.sage); m_pRecordset-PutCollect(“ssex“,_variant_t(student.ssex); m_pRecordset-PutCollect(“smajor“,_variant_t(s

30、tudent.smajor); m_pRecordset-Update();/更新操作,如果不更新,对数据库的25操作将没有得到相应的操作 m_pConnection-Execute(query_cmd,NULL,1); /用 Execute 执行 sql 语句来删除 m_pRecordset-Close(); / 关闭记录集 / 捕捉异常 catch(_com_error e) / 显示错误信息 cerr State) m_pConnection-Close(); :CoUninitialize(); return 0; 264.实习总结、体会与收获通过这些天老师给我们讲授实习课,我知道的我们专业的实用性,以及在软件工程上我们应该怎么学,学些什么,光靠课堂上我们学习的东西十分有限,要充分利用课余时间,利用图书馆和互联网。学习这个专业,要求我们要深入进去,不能只学会些皮毛,要不断跟进时代的步伐,不断学习新的知识,开拓视野,才能在这个专业上有更好的作为,使我们走得更远,这门课程的学习使我受益匪浅,为以后的学习打下了基础,激发了我的学习兴趣,使我明确了自己的专业方向。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 高等教育 > 专业基础教材

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报