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

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

ID:64004223

大小:227.18 KB

页数:38页

时间:2024-01-24

上传者:无敌小子
《管理系统中计算机应用》实践报告材料_第1页
《管理系统中计算机应用》实践报告材料_第2页
《管理系统中计算机应用》实践报告材料_第3页
《管理系统中计算机应用》实践报告材料_第4页
《管理系统中计算机应用》实践报告材料_第5页
《管理系统中计算机应用》实践报告材料_第6页
《管理系统中计算机应用》实践报告材料_第7页
《管理系统中计算机应用》实践报告材料_第8页
《管理系统中计算机应用》实践报告材料_第9页
《管理系统中计算机应用》实践报告材料_第10页
资源描述:

《《管理系统中计算机应用》实践报告材料》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

中南林业科技大学管理系统中计算机应用》实践报告姓名XXX专.业人力资源管理衿(系)中南林业科技大学成教学I兀.实习时间:2013年4月18日实习地点:XXXXXXXXXX成绩:指导教师评语: 签名:年月日撰写及批改注意事项、填写信息1、学生填写信息齐全、字迹清晰、日期真实;2、教师批改后的签名和日期应完整;3、报告中封面、图、程序要求打印(封面与此页要求正反双面打印,教师评语要求手写)。、实习报告的撰写1、实习报告撰写认真细致,数据计算正确、误差分析准确、实验结论分析符合科学规律。2、实习报告有绘制的图形、图表时,要求(1)用电脑绘制;(2)应在报告中注明图号、表号。三、批改实验报告1、一律采用百分制;2、批改时应对错分明,错误之处应有文字说明或指出错误的标记;3、指导教师评语的内容: (1)对本次认识实习完成情况的评语;(2)对本次认识实习报告的评语;目录1.软件编译理论及实践教程实习内容42.套接字编程62.1使用说明书62.2原理说明书72.3程序注释73.连接数据库193.1使用说明书193.2原理说明书203.3程序注释204.实习总结、体会与收获26 正文部分)1.软件编译理论及实践教程实习内容一:我的电脑磁盘分析:001876E38D001876E38D分区间隙001876E3CB001876E3CB管理节点4001876E3CC001876E3CC (102.4GB)(?b25422D6cl剩余扇区PING.EXE+六进制源码分析在文件存储空间中,Ping.exe十六进制源码分析如下:-1力F7-1D»'7-DEF8-DEP9-00□□^3045-0000-0032-OO1001»与0500-00白妗•0000-0000-ZG0D-0072732.套接字编程2.1.使用说明书:第一步:先打开服务器端(server.exe).根据提示输入端口号,需要输入大于5001小于65535的值,否则就是用默认的5001作为端口值 第二步:创建套接字并选择协议。第三步:打开客户端(client.exe),根据提示,将客户端(server.exe)所在的服务器的IP地址输入进去。第四输入在服务器端(server.exe)中建立的端口号值。r1•第五步:选择和服务器端(server.exe)中一样的协议置六收发数据少第七关闭连接。 2.2原理说明书2.3程序注释 ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★if★*client©-简单的TCP/UDP套接字客户程序windows环境include//关于套接字的头文件includeincludeincludeinclude#pragmacomment(lib,Hws2_32n)//添力口'ws2_321库//端口号intmain(void)unsignedshortport=5001;intsocket_type=SOCK_STREAM;//缺省使用TCP连接charBuffer[1280];//收发缓冲区unsignedintaddr;〃IP地址变量intretvalj;〃临时变量 套接字地址结构变量//主机信息结构变量//windows套接字信structsockaddrjnserver,from;//structhostent*hp;指针WSADATAwsaData;//套接字变量SOCKETconnsocket;〃先输入客户程序所需要的基本信息:服务器地址,端口号,套接字类型print"请输入服务器地址:”);scanf(n%sn,Buffer);printf(”请输入端口号(>5000):");scanf(H%dH,&i);if(i<5000||i>65535)printf("不正确的端口号%d,用缺省端口号5001 ;i);else port=i;printf(“请输入套接字类型(1,TCP;2,UDPscanf(n%dn5&i);if(i==1)socketjype=SOCK_STREAM;//设定为SOCK_STREAMelseif(i==2)socketjype=SOCK_DGRAM;〃设定为SOCK_DGRAMelseprintf("不正确的输入%d使用TCP数据流 ",i);//在windows环境下,需要先初始化协议栈if((retval=WSAStartup(0x202,&wsaData))!=0)//WSAStartup函数调用,用来初始//socket{printf(”WSAStartup失贝攵,错误号:%d n,retval);WSACIeanup();//当调用了WSAStartup之后,就需要调用WSACIeanup函数释放内存return-1; 〃取得主机IP地址if(isalpha(Buffeg]))〃是域名或命名地址,用首字母的是否在A-Z,或者a-z来判断是域名还是IP地址hp=gethostbyname(Buffer);//从一个主机数据库中提取出主机信息elseaddr=inet_addr(Buffer);//是点分地址hp=gethostbyaddr((char*)&addr,4,AF_INET);//根据网络地址,获得主机信息,执行成功,就返回一个指向主机信息的结构)if(hp==NULL)printf("不能解析地址[%s]:错误号%d ",Buffer,WSAGetLastError());//用于获取错误信息 WSACIeanupQ;〃拷贝解析的信息到sockaddjin结构中memset(&server,0,sizeof(server));//配内存空间'由server返回memcpy(&(server.sin_addr)3hp->h_addr,hp->hjength);//信息的copyserver.sin_family=hp->h_addrtype;//组t办议初始彳匕server.sin_port=htons(port);//端口号初始彳匕//建立套接字conn_socket=socket(AF_lNET,socket_type,0);if(conn_socket<0){printf("socket()失败,错误号:%d ",WSAGetLastError());WSACIeanupQ;return-1; //对于流式套接字,需要先建立连接〃其实也可以使用connect。,send。,recv()等函数在windows里面一样实现数据报套接字功能if(socket_type!=SOCK_DGRAM){printf(n正在连接到:%s H,hp->h_name);if(connect(conn_socket,(structsockaddr*)&server,sizeof(server))==SOCKET_ERROR)printf("connect()失败,错误号:%d H,WSAGetLastError());closesocket(conn_socket);〃如果创建失败,就关闭连接套接字WSACIeanupQ;return-1;})while(1) 〃得到要发送的信息字符串puts”n输入送到服务器的信息:”);gets(Buffer);if(!strlen(Buffeij)〃如果没有输入信息,继续循环continue;//发送网络信息if(socket_type!=SOCK_DGRAM)retval=send(conn_socket,Buffer,strlen(Buffer)+1,0);〃面向tcp,类似BSDwrite()elseretval=sendto(conn_socket,Buffer,strlen(Buffer)+1,0,〃发送字符串的时候,须将字符串的结束符发送(structsockaddr*)&server,sizeof(server));〃面向UDPif(retval==SOCKET_ERROR) printf("发送失败,错误号:WSAGetLastError());%d H,break;elseprint"'发送信息:%s ”,Buffer);//接收网络信息i=sizeof(from);if(socket_type!=SOCK_DGRAM)retval=recv(conn_socket,Buffer,Buffer,sizeof(Buffer),0);〃面向tcp,类似BSDread()elseretval=recvfrom(conn_socketjsizeof(Buffer),0,(structsockaddr*)&from,&i);〃面向UDPif(retval==SOCKET_ERROR) printf("接收信息失败,错号:%d H,WSAGetLastError());break;)elseif(retval==0)//对于面向连接的套接字,要判断对方是否关闭连接(printf("服务器关闭连接 ");break;)else//正确接收到网络信息printf(n收到%d字节信息:%s n,retval,Buffer);〃程序的一个退出条件if(!stricmp(Buffer,nquitn))break;//关闭套接字closesocket(conn_socket);WSACIeanupQ; return0; ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★if***server©-简单TCP/UDP套接字服务器程序windows环境★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★I#include//套接字头文件#include#include#include#include#pragmacomment(lib,Hws2_32n)//添加库intmain(void)unsignedshortport=5001;//端口号intsocket_type=SOCK_DGRAM;charBuffer[1024];〃缺省使用TCP连接//收发缓冲区intretval,fromlen,i,isconnected=0;〃临时变量 structsockaddrjnlocal,from;//套接字地址结构变SOCKETlisten_socket,msgsock;//套接字变量WSADATAwsaData;//windows套接字信//先输入服务器程序所需要的基本信息:端口号,套接字类型printf("请输入端口号(>5000):");scanf(H%dH,&i);if(i<5000||i>65535)printf("不正确的端口号%d,用缺省端口号5001 "J)elseport=i;printf("请输入套接字类型(1,TCP;2,UDP):H);scanf(n%dM5&i);if(i==1)socket_type=SOCK_STREAM;elseif(i==2)socket_type=SOCK_DGRAM;else printf("不正确的输入%d,使用TCP数据流 ;i);〃在windows环境下,需要先初始化协议栈if((retval=WSAStartup(0x202,&wsaData))!=0)//始化套接字版本等信息(printf(nWSAStartup失败,错误号:%d n5retval);WSACIeanup();〃在创建失败,或者程序结束,都要调用return-1;//建立套接字listen_socket=socket(AF_INET,socket_type,0);if(listen_socket==INVALID_SOCKET)(printf("socket()失败,错误号:%d ",WSAGetLastError());WSACIeanup();return-1;) 〃拷贝解析的信息到sockaddrjn结构中local.sin_family=AFJNET;local.sinaddr.saddr=INADDRANY;local.sin_port=htons(port);//邦定网络地址到套接字if(bind(listen_socket,(structsockaddr*)&local,sizeof(local))==SOCKET_ERROR)//绑定网络地址{printf("bind()失败,错误号:%d ",WSAGetLastError());WSACIeanup();return-1;)//对于流式套接字,让套接字处于监听状态,等待连接到来if(socket_type!=SOCK_DGRAM)if(listen(listen_socket,5)==SOCKET_ERROR//)监听网络( printf("listen()失败,错误号:%d ",WSAGetLastError());WSACIeanupQ;return-1;printf(“监听端口:%d,使用协议:%s ;port,(socketjype==SOCK_STREAM)?叮CP":”UDP“);while(1)(fromlen=sizeof(from);if(socketjype==SOCK_DGRAM)msgsock=listen_socket;elseif(isconnected==0){//对于TCP连接,如果没有连接,等待一个连接的到来msgsock=accept(listen_socket,(structsockaddr*)&from,&fromlen);if(msgsock==INVALID_SOCKET)(printf(naccept()失败,错 号:%d H,WSAGetLastError());WSACIeanupQ;return-1;isconnected=1;printf("从%s收到连接,端口是:%d ",inet_ntoa(from.sin_addr),htons(from.sin_port));)//等待接收网络信息if(socket_type!=SOCK_DGRAM)retval=recv(msgsock,Buffer,sizeof(Buffer),0);〃面向tcp,类似BSDread()else(retval=recvfrom(msgsockjBuffer,sizeof(Buffer),0, (structsockaddr*)&from,&fromlen);〃面向UDPprintf(H从%s收到数据报,端口是:%d ”,inet_ntoa(from.sin_addr),htons(from.sin_port));)//结果判断if(retval==SOCKET_ERROR)(printf("recv()失败,错误号:%d ",WSAGetLastError());closesocket(msgsock);continue;)elseif(retval==0)(printf(H客户端关闭连接 ");closesocket(msgsock);continue; )else//正常接收printf(n收到%d字节的数据:%s H,retval,Buffer);if(socket_type!=SOCK_DGRAM){〃对于TCP连接,我们收到“exit”有一个关闭连接的操作if(!stricmp(Buffer,nexitH))(printf("关闭TCP连接,等待下一次连接…俏;closesocket(msgsock);isconnected=0;continue; 〃信息回送printf("将同样的信息回送给客户端... ");printf(Hpleaseinputthemessage: n);scanf(H%sH,Buffer);if(socket_type!=SOCK_DGRAM)retval=send(msgsock,Buffer,strlen(Buffer)+1,0);//面向tcp,类似BSDwrite()elseretval=sendto(msgsock,Buffer,strlen(Buffer)+1,0,(structsockaddr*)&from,fromlen);〃面向UDPif(retval==SOCKET_ERROR)printf("send()失败'错误号:%drT,WSAGetLastError());)〃程序的一个退出条件if(!stricmp(Buffer,"quit"))break;) WSACIeanupQ;return0;)3.连接数据库3.1使用说明书第一步:在开始菜单中找到SQLSERVE并R打开第二步:建立一个新的数据库。在SQLSERVER中建立一个名为student的数据库第三步:在student库下创建一个Stu_lnfo表,并在表中包含以下字段名:snum,sname,ssex'sage,smajor°输入一些数据'进行测试。第四步:在安全性中设置密码为123.第三步:编译生成可执行的文件,点击运行。根据提示框中的信息,输入我们需要插入的数据。关闭程序。第四步:在次点击运行,查看我们插入的数据是否成功的插入。3.2原理说明 通过ADO访问数据库的技术进行数据库编程。我们需要在计算机上配置数据源。配置数据源的过程,就是和让数据库的驱动程序来对数据库进行操作,以便使我们再程序中,可以调用驱动程序来完成我们需要完成的工作。处理ADO访问技术之外,还有ODB(C开放式数据库互联)等。33不早^率/***★★***★**★★*****★★***★**★★*****★****★***★★★★★★*★★**★★★*利用ADO访问MSSQL2000要求:【1】输出Stu」nfo表内的每一条记录[2]添加一条新记录[3]删除名字为“李立“的记录#importnc:ProgramFilesCommonFilesSystemADOmsado15.dll"V/导入动态链接库,使我们可以 使用ADO编程no_namespacerename(HEOFn,HEndOfFileH)//为了防止命名冲突,不使用命名空间#include//标准输入输出流#include//forsetw()usingnamespacestd;classSTU//定义学生类public:学号charsnum[10];//姓名charsname[10];//charssex[2];//姓别longsage;//年龄专业charsmajor[20];//public:STU(){}~STU(){}};intmain()( STUstudent;//定义学生又寸象::Colnitialize(NULL);//初始化OLE/COM库环境,为访问ADO接口做准备_RecordsetPtrm_pRecordset(nADODB.RecordsetH);//立t己录_ConnectionPtrm_pConnection("ADODB.Connection");//建立连接_bstr_tbstrSQL("select*fromstujnfo");//查询语句char*query_cmd="DELETEFROMstujnfoWHEREsname=,李立”二try//异常处理〃仓!!建Connection又寸象m_pConnection.Createlnstance("ADODB.Connection");〃设置连接字符串,必须是BSTR型或者_bstr_t类型__bstrjstrConnect=Trovider=SQLOLEDB;Server=(local);Database=student;uid=sa pwd=123;H;〃若数据库在网络上则Server为形如(192.168.1.5,3340)〃用户sa和密码123只是针对我的库m_pConnection->Open(strConnect,"",""JadModeUnknown);if(m__pConnection==NULL)cerr«HLinddataERROR! H;//创建记录集对象m_pRecordset.Createlnstance(_uuidof(Recordset));〃取得表中的记录m_pRecordset->Open(bstrSQL,m_pConnection.GetlnterfacePtr()3adOpenDynamic,adLockOptimistic,adCmdText);_variant_tvsnum,vsname,vsage,vssex,vsmajor;//又寸应库中的snum5sname,sage,ssex5smajor cout«"学号姓名年龄姓别专业cout«” ";while(!m_pRecordset->EndOfFile)//如果记录集没有到记录的尾端{vsnum=m_pRecordset->GetCollect(_variant_t((long)0));//这儿给字段编号和字段名都可以vsname=m_pRecordset->GetCollect(Hsnamen);vsage=m_pRecordset->GetCollect(nsagen);vssex=m_pRecordset->GetCollect(nssexn);vsmajor=m_pRecordset->GetCollect(nsmajorn);if(vsnum.vt!=VT_NULL&&vsname.vt!=VT_NULL&&vsage.vt!=VTNULL&&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();III移到下一条记录)cout«H ";〃输入将要插入的信息cout«" 请输入你要添加的学生信息 ";cout«"学号:";cin»student.snum;cout«n 姓名:”; cin»student.sname;cout«” 年龄:";cin»student.sage;cout«” 姓别:”;cin»student.ssex;cout«” 专业:”;cin»student.smajor;m_pRecordset->MoveFirst();//移动到第一条记录m_pRecordset->AddNew();III添加新记录m_pRecordset->RutCollect(nsnumn3_variant_t(student.snum));//将数据添加进去输入库m_pRecordset->PutCollect(nsnamen,_variant_t(student.sname));m_pRecordset->PutCollect(nsagen3_variant_t(student.sage));m_pRecordset->PutCollect(nssexH,_variant_t(student.ssex));m_pRecordset->PutCollect(nsmajorn,_variant_t(student.smajor)); m_pRecordset->Update();〃更新操作,如果不更新,对数据 库的操作将没有得到相应的操作用Executem_pConnection->Execute(query_cmd5NULL51);//执行sql语句来删除m_pRecordset->Close();//关闭记录集//捕捉异常catch(_com_errore)//显示错误信息cerr«H ERROR:H«(char*)e.Description。;//if(m_pConnection->State)m_pConnection->Close();抛出异::CoUninitialize();return0;3.实习总结、体会与收获通过这些天老师给我们讲授实习课,我知道的我们专业的实用性,以及在软件工程上我们应该怎么学,学些什么,光靠课堂上 我们学习的东西十分有限,要充分利用课余时间,利用图书馆和互联网。学习这个专业,要求我们要深入进去,不能只学会些皮毛,要不断跟进时代的步伐,不断学习新的知识,开拓视野,才能在这个专业上有更好的作为,使我们走得更远,这门课程的学习使我受益匪浅,为以后的学习打下了基础,激发了我的学习兴趣,使我明确了自己的专业方向。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
关闭