![管理系统中计算机应用实践报告参考模板_第1页](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/092be28f-660b-4278-a829-d68965d65827/092be28f-660b-4278-a829-d68965d658271.gif)
![管理系统中计算机应用实践报告参考模板_第2页](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/092be28f-660b-4278-a829-d68965d65827/092be28f-660b-4278-a829-d68965d658272.gif)
![管理系统中计算机应用实践报告参考模板_第3页](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/092be28f-660b-4278-a829-d68965d65827/092be28f-660b-4278-a829-d68965d658273.gif)
![管理系统中计算机应用实践报告参考模板_第4页](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/092be28f-660b-4278-a829-d68965d65827/092be28f-660b-4278-a829-d68965d658274.gif)
![管理系统中计算机应用实践报告参考模板_第5页](http://file3.renrendoc.com/fileroot_temp3/2022-3/2/092be28f-660b-4278-a829-d68965d65827/092be28f-660b-4278-a829-d68965d658275.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、中南林业科技大学管理系统中计算机应用实践报告姓 名:XXX 专 业: 人力资源管理 院 (系): 中南林业科技大学成教学院 实习时间: 2013年4月18日 实习地点: XXXXXXXXXX 1 / 42指导教师评语: 成绩:签名: 年 月 日撰写及批改注意事项一、填写信息1、学生填写信息齐全、字迹清晰、日期真实;2、教师批改后的签名和日期应完整;3、报告中封面、图、程序要求打印(封面与此页要求正反双面打印,教师评语要求手写)。二、实习报告的撰写 1、实习报告撰写认真细致,数据计算正确、误差分析准确、实验结论分析符合科学规律。2、实习报告有绘制的图形、图表时,要求 (1)用电脑绘制; (2)应
2、在报告中注明图号、表号。三、批改实验报告 1、一律采用百分制; 2、批改时应对错分明,错误之处应有文字说明或指出错误的标记;3、指导教师评语的内容: (1)对本次认识实习完成情况的评语; (2)对本次认识实习报告的评语;目 录1.软件编译理论及实践教程实习内容42.套接字编程62.1使用说明书62.2原理说明书72.3程序注释73.连接数据库193.1使用说明书193.2原理说明书203.3程序注释204.实习总结、体会与收获26 (正 文 部 分)1.软件编译理论及实践教程实习内容一:我的电脑磁盘分析:0000000000 管理节点1000000003F000000003F C盘(48.8G
3、B)00061AB82700061AB827 管理节点200061AB86600061AB866 D盘(73.4GB)000F48CDDA000F48CDDA 分区间隙000F48CE18000F48CE18 管理节点3000F48CE19000F48CE19 E盘(73.4GB)001876E38D001876E38D 分区间隙001876E3CB001876E3CB 管理节点4001876E3CC001876E3CC F盘(102.4GB)0025422D6C1 剩余扇区二. PING.EXE十六进制源码分析在文件存储空间中,ping.exe十六进制源码分析如下:2. 套接字编程2.1.使
4、用说明书:第一步:先打开服务器端(server.exe).根据提示输入端口号,需要输入大于5001小于65535的值,否则就是用默认的5001作为端口值第二步:创建套接字并选择协议。第三步:打开客户端(client.exe),根据提示,将客户端(server.exe)所在的服务器的IP地址输入进去。第四步:输入在服务器端(server.exe)中建立的端口号值。第五步:选择和服务器端(server.exe)中一样的协议第六步:收发数据第七步:关闭连接。2.2原理说明书2.3程序注释/* client.c - 简单的 TCP/UDP 套接字客户程序 windows环境 */#include &l
5、t;winsock2.h>/关于套接字的头文件#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;/端口号 int socket_type = SOCK_STREAM;/缺省使用TCP连接 char Buffer1280;/收发缓冲区 unsigned int ad
6、dr;/IP地址变量 int retval,i;/临时变量 struct sockaddr_in server, from; /套接字地址结构变量 struct hostent *hp;/主机信息结构变量指针 WSADATA wsaData;/windows套接字信息 SOCKET conn_socket;/套接字变量/先输入客户程序所需要的基本信息:服务器地址,端口号,套接字类型printf("请输入服务器地址:");scanf("%s", Buffer);printf("请输入端口号( >5000 ):");scanf(&q
7、uot;%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;/设定为SOCK_STREAMelse if(i = 2)socket_type = SOCK_DGRAM;/设定为SOCK_DGRAMelseprintf(
8、"不正确的输入%d,使用TCP数据流n", i);/在windows环境下,需要先初始化协议栈if (retval = WSAStartup(0x202, &wsaData) != 0) /WSAStartup函数调用,用来初始/socket printf("WSAStartup 失败,错误号:%dn",retval); WSACleanup();/当调用了WSAStartup之后,就需要调用WSACleanup函数释放内存 return -1; /取得主机IP地址 if (isalpha(Buffer0) /是域名或命名地址,用首字母的是否在A
9、-Z,或者a-z来判断是域名还是IP地址 hp = gethostbyname(Buffer);/从一个主机数据库中提取出主机信息 else addr = inet_addr(Buffer);/是点分地址 hp = gethostbyaddr(char *)&addr,4,AF_INET);/根据网络地址,获得主机信息,执行成功,就返回一个指向主机信息的结构 if (hp = NULL ) printf("不能解析地址%s: 错误号%dn", Buffer, WSAGetLastError();/用于获取错误信息 WSACleanup(); exit(1); / 拷
10、贝 解析的信息到sockaddr_in结构中 memset(&server,0,sizeof(server);/分配内存空间,由server返回 memcpy(&(server.sin_addr),hp->h_addr,hp->h_length);/信息的copy server.sin_family = hp->h_addrtype;/组协议初始化 server.sin_port = htons(port);/端口号初始化/建立套接字 conn_socket = socket(AF_INET,socket_type,0); if (conn_socket &l
11、t;0 ) printf("socket()失败,错误号:%dn", WSAGetLastError(); WSACleanup(); return -1; /对于流式套接字,需要先建立连接/其实也可以使用connect(),send(),recv()等函数在windows里面一样实现数据报套接字功能if(socket_type != SOCK_DGRAM)printf("正在连接到: %sn",hp->h_name);if (connect(conn_socket,(struct sockaddr*)&server,sizeof(serv
12、er) = SOCKET_ERROR) printf("connect()失败,错误号:%dn",WSAGetLastError(); closesocket(conn_socket);/如果创建失败,就关闭连接套接字WSACleanup();return -1; while(1) /得到要发送的信息字符串 puts("n输入送到服务器的信息:");gets(Buffer);if(!strlen(Buffer) /如果没有输入信息,继续循环continue;/发送网络信息if(socket_type != SOCK_DGRAM) retval = sen
13、d(conn_socket, Buffer, strlen(Buffer)+1, 0);/面向tcp,类似BSD write()else retval = sendto(conn_socket, Buffer, strlen(Buffer)+1, 0,/发送字符串的时候,须将字符串的结束符0发送(struct sockaddr*)&server, sizeof(server);/面向UDP if (retval = SOCKET_ERROR) printf("发送失败,错误号: %dn", WSAGetLastError(); break; elseprintf(&
14、quot;发送信息:%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, sizeof(Buffer), 0,(struct sockaddr*)&from, &i);/面向UDP if (retval = SOCKET_ERROR) printf(&quo
15、t;接收信息失败,错误号:%dn",WSAGetLastError(); break; else if (retval = 0) / 对于面向连接的套接字,需要判断对方是否关闭连接 printf("服务器关闭连接n"); break; else /正确接收到网络信息printf("收到 %d 字节信息:%s n", retval, Buffer);/程序的一个退出条件if(!stricmp(Buffer, "quit") break; /关闭套接字 closesocket(conn_socket); WSACleanup()
16、;return 0;/* server.c - 简单 TCP/UDP 套接字服务器程序 windows环境 */#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;/端口号 int socket_type = SO
17、CK_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", &i);if(i &
18、lt; 5000 | i > 65535)printf("不正确的端口号%d,用缺省端口号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数据流n",i);/在windows环境下,需要先初始化协议栈
19、if (retval = WSAStartup(0x202, &wsaData) != 0) /初始化套接字版本等信息 printf("WSAStartup 失败,错误号:%dn", retval); WSACleanup();/在创建失败,或者程序结束,都要调用 return -1; /建立套接字 listen_socket = socket(AF_INET, socket_type, 0); if (listen_socket = INVALID_SOCKET) printf("socket()失败,错误号:%dn", WSAGetLastE
20、rror(); WSACleanup(); return -1; / 拷贝 解析的信息到sockaddr_in结构中 local.sin_family = AF_INET; local.sin_addr.s_addr = INADDR_ANY; local.sin_port = htons(port);/邦定网络地址到套接字 if (bind(listen_socket,(struct sockaddr*)&local, sizeof(local) ) = SOCKET_ERROR) /绑定网络地址 printf("bind()失败,错误号:%dn", WSAGet
21、LastError(); 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_STREAM)?
22、 "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()
23、失败,错误号:%dn",WSAGetLastError(); WSACleanup(); return -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() else retval = recvfrom(
24、msgsock, Buffer, sizeof (Buffer), 0, (struct sockaddr *)&from, &fromlen);/面向UDP printf("从%s收到数据报,端口是:%dn", inet_ntoa(from.sin_addr), htons(from.sin_port); /结果判断 if (retval = SOCKET_ERROR) printf("recv()失败,错误号:%dn", WSAGetLastError(); closesocket(msgsock); continue; else i
25、f (retval = 0) printf("客户端关闭连接n"); closesocket(msgsock); continue; else /正常接收printf("收到 %d 字节的数据:%s n", retval, Buffer);if (socket_type != SOCK_DGRAM)/对于TCP连接,我们收到"exit"有一个关闭连接的操作if(!stricmp(Buffer, "exit") printf("关闭TCP 连接,等待下一次连接.n");closesocket(ms
26、gsock);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);/面向tcp,类似BSD write() else retval = sendto(msgsock, Buffer, strlen(
27、Buffer)+1, 0, (struct sockaddr *)&from, fromlen);/面向UDP if (retval = SOCKET_ERROR) printf("send()失败,错误号:%dn", WSAGetLastError(); /程序的一个退出条件if(!stricmp(Buffer, "quit")break; WSACleanup();return 0;3.连接数据库3.1使用说明书第一步:在开始菜单中找到SQL SERVER并打开 第二步:建立一个新的数据库。在SQL SERVER中建立一个名为student的
28、数据库第三步:在student库下创建一个Stu_Info表,并在表中包含以下字段名:snum,sname,ssex,sage,smajor。输入一些数据,进行测试。第四步:在安全性中设置密码为123.第三步:编译生成可执行的文件,点击运行。根据提示框中的信息,输入我们需要插入的数据。关闭程序。第四步:在次点击运行,查看我们插入的数据是否成功的插入。3.2原理说明通过ADO访问数据库的技术进行数据库编程。我们需要在计算机上配置数据源。配置数据源的过程,就是和让数据库的驱动程序来对数据库进行操作,以便使我们再程序中,可以调用驱动程序来完成我们需要完成的工作。处理ADO访问技术之外,还有ODBC(
29、开放式数据库互联)等。3.3程序注释/*利用ADO访问MS SQL2000要求: 【1】输出Stu_Info表内的每一条记录【2】添加一条新记录【3】删除名字为"李立"的记录 */#import "c:Program FilesCommon FilesSystemADOmsado15.dll" /导入动态链接库,使我们可以使用ADO编程no_namespace rename("EOF", "EndOfFile") /为了防止命名冲突,不使用命名空间#include <iostream> /标准输入输出流
30、#include <iomanip> /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接口做准备 _RecordsetPtr m_pRecordset(&
31、quot;ADODB.Recordset"); /建立记录集 _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(&quo
32、t;ADODB.Connection"); / 设置连接字符串,必须是BSTR型或者_bstr_t类型 _bstr_t strConnect= "Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123;" /若数据库在网络上则Server为形如 /用户sa和密码123只是针对我的库 m_pConnection->Open(strConnect,"","",adModeUnknown); if(m_pConnection=NULL) cerr&
33、lt;<"Lind data ERROR!n" / 创建记录集对象 m_pRecordset.CreateInstance(_uuidof(Recordset); / 取得表中的记录 m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(), adOpenDynamic,adLockOptimistic,adCmdText); _variant_t vsnum,vsname,vsage,vssex,vsmajor; /对应库中的snum,sname,sage,ssex,smajor cout <&
34、lt; "学号 姓名 年龄 姓别 专业" cout << "n-n" while (!m_pRecordset->EndOfFile) /如果记录集没有到记录的尾端 vsnum = m_pRecordset->GetCollect(_variant_t(long)0);/这儿给字段编号和字段名都可以 vsname = m_pRecordset->GetCollect("sname"); vsage = m_pRecordset->GetCollect("sage"); vssex
35、 = 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); /设置左对齐cout <<
36、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 << "n-n" /输入将要插入的信息cout << "n请输入你要添加的学生信息n" cout << "学号:" cin >> student.snum; cout << "n姓名:&q
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年公司消防应急预案演练评估报告总结
- 二零二五版国际教育文化交流合作协议
- 单位用人申请书
- 2025年度土地储备项目征地补偿合同范本
- 2025年度工程建设项目投标担保合同范本
- 酒店转正申请书范文
- 婴儿改名申请书
- 工勤岗转管理岗申请书
- 求职面试中的职场礼仪技巧分析
- 2025年午托班学生课后兴趣小组活动合同
- 快消品公司销售部薪酬绩效方案(快消品公司销售KPI绩效考核指标)
- 2025年初中地理八年级上册全册重点知识点复习课件
- 化学第五单元化学反应的定量关系大单元备课-2024-2025学年九年级化学人教版(2024)上册
- PIR 灌注保温装饰板外墙保温系统应用技术规程规程征求意见稿
- 2024年中国网球游戏机市场调查研究报告
- 2024年日历表电子版(带农历-含周数-周一开始-打印版)
- 三年级上册科学全册知识点2024年新青岛版六三制
- DLT5155-2016 220kV~1000kV变电站站用电设计技术规程
- 2024年全国期货从业资格之期货投资分析考试历年考试题(详细参考解析)
- 产品生产及供货方案(2篇)
- 期末情境卷考核-2023-2024学年语文二年级下册统编版
评论
0/150
提交评论