《管理系统中计算机应用》实践报告.docx
《《管理系统中计算机应用》实践报告.docx》由会员分享,可在线阅读,更多相关《《管理系统中计算机应用》实践报告.docx(20页珍藏版)》请在冰豆网上搜索。
《管理系统中计算机应用》实践报告
《管理系统中计算机应用》
实践报告
设计题目:
管理系统中计算机应用
助学院校:
河南理工大学
自考助学专业:
机电设备管理与维修
姓名:
贺珂珂
自考助学学号:
112
成绩:
指导教师签名:
河南理工大学成人高等教育
2O年月日
1.软件编译理论及实践教程实习内容4
2.套接字编程6
2.1使用说明书6
2.2原理说明书7
2.3程序注释7
3.连接数据库19
3.1使用说明书19
3.2原理说明书20
3.3程序注释20
4.实习总结、体会与收获26
1.软件编译理论及实践教程实习内容
一:
我的电脑磁盘分析:
0000000000
管理节点1
000000003F
000000003F
C盘(48.8GB)
00061AB827
00061AB827
管理节点2
00061AB866
00061AB866
D盘(73.4GB)
000F48CDDA
000F48CDDA
分区间隙
000F48CE18
000F48CE18
管理节点3
000F48CE19
000F48CE19
E盘(73.4GB)
001876E38D
001876E38D
分区间隙
001876E3CB
001876E3CB
管理节点4
001876E3CC
001876E3CC
F盘(102.4GB)
0025422D6C1
剩余扇区
二.PING.EXE十六进制源码分析
在文件存储空间中,ping.exe十六进制源码分析如下:
2.套接字编程
2.1.使用说明书:
第一步:
先打开服务器端(server.exe).根据提示输入端口号,需要输入大于5001小于65535的值,否则就是用默认的5001作为端口值
第二步:
创建套接字并选择协议。
第三步:
打开客户端(client.exe),根据提示,将客户端(server.exe)所在的服务器的IP地址输入进去。
第四步:
输入在服务器端(server.exe)中建立的端口号值。
第五步:
选择和服务器端(server.exe)中一样的协议
第六步:
收发数据
第七步:
关闭连接。
2.2原理说明书
2.3程序注释
/******************************************************\
*client.c-简单的TCP/UDP套接字客户程序windows环境*
\******************************************************/
#include//关于套接字的头文件
#include
#include
#include
#include
#pragmacomment(lib,"ws2_32")//添加‘ws2_32’库
intmain(void)
{
unsignedshortport=5001;//端口号
intsocket_type=SOCK_STREAM;//缺省使用TCP连接
charBuffer[1280];//收发缓冲区
unsignedintaddr;//IP地址变量
intretval,i;//临时变量
structsockaddr_inserver,from;//套接字地址结构变量
structhostent*hp;//主机信息结构变量指针
WSADATAwsaData;//windows套接字信息
SOCKETconn_socket;//套接字变量
//先输入客户程序所需要的基本信息:
服务器地址,端口号,套接字类型
printf("请输入服务器地址:
");
scanf("%s",Buffer);
printf("请输入端口号(>5000):
");
scanf("%d",&i);
if(i<5000||i>65535)
printf("不正确的端口号%d,用缺省端口号5001\n",i);
else
port=i;
printf("请输入套接字类型(1,TCP;2,UDP):
");
scanf("%d",&i);
if(i==1)
socket_type=SOCK_STREAM;//设定为SOCK_STREAM
elseif(i==2)
socket_type=SOCK_DGRAM;//设定为SOCK_DGRAM
else
printf("不正确的输入%d,使用TCP数据流\n",i);
//在windows环境下,需要先初始化协议栈
if((retval=WSAStartup(0x202,&wsaData))!
=0)//WSAStartup函数调用,用来初始//socket
{
printf("WSAStartup失败,错误号:
%d\n",retval);
WSACleanup();//当调用了WSAStartup之后,就需要调用WSACleanup函数释放内存
return-1;
}
//取得主机IP地址
if(isalpha(Buffer[0]))//是域名或命名地址,用首字母的是否在A-Z,或者a-z来判断是域名还是IP地址
hp=gethostbyname(Buffer);//从一个主机数据库中提取出主机信息
else
{
addr=inet_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));//分配内存空间,由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<0)
{
printf("socket()失败,错误号:
%d\n",WSAGetLastError());
WSACleanup();
return-1;
}
//对于流式套接字,需要先建立连接
//其实也可以使用connect(),send(),recv()等函数在windows里面一样实现数据报套接字功能
if(socket_type!
=SOCK_DGRAM)
{
printf("正在连接到:
%s\n",hp->h_name);
if(connect(conn_socket,(structsockaddr*)&server,sizeof(server))==SOCKET_ERROR)
{
printf("connect()失败,错误号:
%d\n",WSAGetLastError());
closesocket(conn_socket);//如果创建失败,就关闭连接套接字
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,类似BSDwrite()
else
retval=sendto(conn_socket,Buffer,strlen(Buffer)+1,0,//发送字符串的时候,须将字符串的结束符\0发送
(structsockaddr*)&server,sizeof(server));//面向UDP
if(retval==SOCKET_ERROR)
{
printf("发送失败,错误号:
%d\n",WSAGetLastError());
break;
}
else
printf("发送信息:
%s\n",Buffer);
//接收网络信息
i=sizeof(from);
if(socket_type!
=SOCK_DGRAM)
retval=recv(conn_socket,Buffer,sizeof(Buffer),0);//面向tcp,类似BSDread()
else
retval=recvfrom(conn_socket,Buffer,sizeof(Buffer),0,
(structsockaddr*)&from,&i);//面向UDP
if(retval==SOCKET_ERROR)
{
printf("接收信息失败,错误号:
%d\n",WSAGetLastError());
break;
}
elseif(retval==0)//对于面向连接的套接字,需要判断对方是否关闭连接
{
printf("服务器关闭连接\n");
break;
}
else//正确接收到网络信息
printf("收到%d字节信息:
%s\n",retval,Buffer);
//程序的一个退出条件
if(!
stricmp(Buffer,"quit"))
break;
}
//关闭套接字
closesocket(conn_socket);
WSACleanup();
return0;
}
/*******************************************************\
*server.c-简单TCP/UDP套接字服务器程序windows环境*
\*******************************************************/
#include//套接字头文件
#include
#include
#include
#include
#pragmacomment(lib,"ws2_32")//添加库
intmain(void)
{
unsignedshortport=5001;//端口号
intsocket_type=SOCK_DGRAM;//缺省使用TCP连接
charBuffer[1024];//收发缓冲区
intretval,fromlen,i,isconnected=0;//临时变量
structsockaddr_inlocal,from;//套接字地址结构变量
SOCKETlisten_socket,msgsock;//套接字变量
WSADATAwsaData;//windows套接字信息
//先输入服务器程序所需要的基本信息:
端口号,套接字类型
printf("请输入端口号(>5000):
");
scanf("%d",&i);
if(i<5000||i>65535)
printf("不正确的端口号%d,用缺省端口号5001\n",i);
else
port=i;
printf("请输入套接字类型(1,TCP;2,UDP):
");
scanf("%d",&i);
if(i==1)
socket_type=SOCK_STREAM;
elseif(i==2)
socket_type=SOCK_DGRAM;
else
printf("不正确的输入%d,使用TCP数据流\n",i);
//在windows环境下,需要先初始化协议栈
if((retval=WSAStartup(0x202,&wsaData))!
=0)//初始化套接字版本等信息
{
printf("WSAStartup失败,错误号:
%d\n",retval);
WSACleanup();//在创建失败,或者程序结束,都要调用
return-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);
//邦定网络地址到套接字
if(bind(listen_socket,(structsockaddr*)&local,sizeof(local))==SOCKET_ERROR)//绑定网络地址
{
printf("bind()失败,错误号:
%d\n",WSAGetLastError());
WSACleanup();
return-1;
}
//对于流式套接字,让套接字处于监听状态,等待连接到来
if(socket_type!
=SOCK_DGRAM)
{
if(listen(listen_socket,5)==SOCKET_ERROR)//监听网络
{
printf("listen()失败,错误号:
%d\n",WSAGetLastError());
WSACleanup();
return-1;
}
}
printf("监听端口:
%d,使用协议:
%s\n",port,
(socket_type==SOCK_STREAM)?
"TCP":
"UDP");
while
(1)
{
fromlen=sizeof(from);
if(socket_type==SOCK_DGRAM)
msgsock=listen_socket;
elseif(isconnected==0)
{//对于TCP连接,如果没有连接,等待一个连接的到来
msgsock=accept(listen_socket,(structsockaddr*)&from,&fromlen);
if(msgsock==INVALID_SOCKET)
{
printf("accept()失败,错误号:
%d\n",WSAGetLastError());
WSACleanup();
return-1;
}
isconnected=1;
printf("从%s收到连接,端口是:
%d\n",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(msgsock,Buffer,sizeof(Buffer),0,
(structsockaddr*)&from,&fromlen);//面向UDP
printf("从%s收到数据报,端口是:
%d\n",inet_ntoa(from.sin_addr),htons(from.sin_port));
}
//结果判断
if(retval==SOCKET_ERROR)
{
printf("recv()失败,错误号:
%d\n",WSAGetLastError());
closesocket(msgsock);
continue;
}
elseif(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(msgsock);
isconnected=0;
continue;
}
}
}
//信息回送
printf("将同样的信息回送给客户端...\n\n");
printf("pleaseinputthemessage:
\n");
scanf("%s",Buffer);
if(socket_type!
=SOCK_DGRAM)
retval=send(msgsock,Buffer,strlen(Buffer)+1,0);//面向tcp,类似BSDwrite()
else
retval=sendto(msgsock,Buffer,strlen(Buffer)+1,0,
(structsockaddr*)&from,fromlen);//面向UDP
if(retval==SOCKET_ERROR)
{
printf("send()失败,错误号:
%d\n",WSAGetLastError());
}
//程序的一个退出条件
if(!
stricmp(Buffer,"quit"))
break;
}
WSACleanup();
return0;
}
3.连接数据库
3.1使用说明书
第一步:
在开始菜单中找到SQLSERVER并打开
第二步:
建立一个新的数据库。
在SQLSERVER中建立一个名为student的数据库
第三步:
在student库下创建一个Stu_Info表,并在表中包含以下字段名:
snum,sname,ssex,sage,smajor。
输入一些数据,进行测试。
第四步:
在安全性中设置密码为123.
第三步:
编译生成可执行的文件,点击运行。
根据提示框中的信息,输入我们需要插入的数据。
关闭程序。
第四步:
在次点击运行,查看我们插入的数据是否成功的插入。
3.2原理说明
通过ADO访问数据库的技术进行数据库编程。
我们需要在计算机上配置数据源。
配置数据源的过程,就是和让数据库的驱动程序来对数据库进行操作,以便使我们再程序中,可以调用驱动程序来完成我们需要完成的工作。
处理ADO访问技术之外,还有ODBC(开放式数据库互联)等。
3.3程序注释
/*******************************************************************
利用ADO访问MSSQL2000
要求:
【1】输出Stu_Info表内的每一条记录
【2】添加一条新记录
【3】删除名字为"李立"的记录
*****************************************************************/
#import"c:
\ProgramFiles\CommonFiles\System\ADO\msado15.dll"\//导入动态链接库,使我们可以使用ADO编程
no_namespacerename("EOF","EndOfFile")//为了防止命名冲突,不使用命名空间
#include//标准输入输出流
#include//forsetw()
usingnamespacestd;
classSTU//定义学生类
{
public:
charsnum[10];//学号
charsname[10];//姓名
charssex[2];//姓别
longsage;//年龄
charsmajor[20];//专业
public:
STU(){}
~STU(){}
};
intmain()
{
STUstudent;//定义学生对象
:
:
CoInitialize(NULL);//初始化OLE/COM库环境,为访问ADO接口做准备
_RecordsetPtrm_pRecordset("ADODB.Recordset");//建立记录集
_ConnectionPtrm_pConnection("ADODB.Connection");//建立连接
_bstr_tbstrSQL("select*fromstu_info");//查询语句
char*query_cmd="DELETEFROMstu_infoWHEREsname='李立'";
try//异常处理
{
//创建Connection对象
m_pConnection.CreateInstanc