管理系统中计算机应用实践报告Word文档格式.docx
- 文档编号:18557150
- 上传时间:2022-12-27
- 格式:DOCX
- 页数:18
- 大小:403.98KB
管理系统中计算机应用实践报告Word文档格式.docx
《管理系统中计算机应用实践报告Word文档格式.docx》由会员分享,可在线阅读,更多相关《管理系统中计算机应用实践报告Word文档格式.docx(18页珍藏版)》请在冰豆网上搜索。
001876E3CB
管理节点4
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<
winsock2.h>
//关于套接字的头文件
stdlib.h>
stdio.h>
string.h>
conio.h>
#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);
请输入端口号(>
5000):
%d"
&
i);
if(i<
5000||i>
65535)
printf("
不正确的端口号%d,用缺省端口号5001\n"
i);
else
port=i;
请输入套接字类型(1,TCP;
2,UDP):
&
if(i==1)
socket_type=SOCK_STREAM;
//设定为SOCK_STREAM
elseif(i==2)
socket_type=SOCK_DGRAM;
//设定为SOCK_DGRAM
不正确的输入%d,使用TCP数据流\n"
//在windows环境下,需要先初始化协议栈
if((retval=WSAStartup(0x202,&
wsaData))!
=0)//WSAStartup函数调用,用来初始//socket
{
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)
不能解析地址[%s]:
错误号%d\n"
Buffer,WSAGetLastError());
//用于获取错误信息
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)
socket()失败,错误号:
WSAGetLastError());
//对于流式套接字,需要先建立连接
//其实也能够使用connect(),send(),recv()等函数在windows里面一样实现数据报套接字功能
if(socket_type!
=SOCK_DGRAM)
正在连接到:
%s\n"
hp->
h_name);
if(connect(conn_socket,(structsockaddr*)&
server,sizeof(server))==SOCKET_ERROR)
{
printf("
connect()失败,错误号:
WSAGetLastError());
closesocket(conn_socket);
//如果创立失败,就关闭连接套接字
WSACleanup();
return-1;
}
while
(1)
//得到要发送的信息字符串
puts("
\n输入送到服务器的信息:
gets(Buffer);
if(!
strlen(Buffer))//如果没有输入信息,继续循环
continue;
//发送网络信息
if(socket_type!
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)
发送失败,错误号:
%d\n"
break;
else
发送信息:
%s\n"
//接收网络信息
i=sizeof(from);
retval=recv(conn_socket,Buffer,sizeof(Buffer),0);
//面向tcp,类似BSDread()
retval=recvfrom(conn_socket,Buffer,sizeof(Buffer),0,
from,&
接收信息失败,错误号:
elseif(retval==0)//对于面向连接的套接字,需要判断对方是否关闭连接
服务器关闭连接\n"
else//正确接收到网络信息
收到%d字节信息:
%s\n"
retval,Buffer);
//程序的一个退出条件
stricmp(Buffer,"
quit"
))
break;
//关闭套接字
return0;
}
/*******************************************************\
*server.c-简单TCP/UDP套接字服务器程序windows环境*
\*******************************************************/
//套接字头文件
iostream.h>
#pragmacomment(lib,"
)//添加库
unsignedshortport=5001;
intsocket_type=SOCK_DGRAM;
charBuffer[1024];
//收发缓冲区
intretval,fromlen,i,isconnected=0;
structsockaddr_inlocal,from;
SOCKETlisten_socket,msgsock;
//套接字变量
//先输入服务器程序所需要的基本信息:
端口号,套接字类型
i);
2,UDP):
if((retval=WSAStartup(0x202,&
=0)//初始化套接字版本等信息
retval);
//在创立失败,或者程序结束,都要调用
listen_socket=socket(AF_INET,socket_type,0);
if(listen_socket==INVALID_SOCKET)
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)//绑定网络地址
bind()失败,错误号:
//对于流式套接字,让套接字处于监听状态,等待连接到来
if(socket_type!
=SOCK_DGRAM)
if(listen(listen_socket,5)==SOCKET_ERROR)//监听网络
listen()失败,错误号:
监听端口:
%d,使用协议:
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*)&
fromlen);
if(msgsock==INVALID_SOCKET)
{
accept()失败,错误号:
isconnected=1;
从%s收到连接,端口是:
inet_ntoa(from.sin_addr),htons(from.sin_port));
//等待接收网络信息
retval=recv(msgsock,Buffer,sizeof(Buffer),0);
//面向tcp,类似BSDread()
retval=recvfrom(msgsock,Buffer,sizeof(Buffer),0,
(structsockaddr*)&
从%s收到数据报,端口是:
//结果判断
recv()失败,错误号:
closesocket(msgsock);
continue;
elseif(retval==0)
客户端关闭连接\n"
else//正常接收
收到%d字节的数据:
if(socket_type!
{//对于TCP连接,我们收到"
exit"
有一个关闭连接的操作
if(!
{
printf("
关闭TCP连接,等待下一次连接...\n"
closesocket(msgsock);
isconnected=0;
continue;
}
}
//信息回送
将同样的信息回送给客户端...\n\n"
pleaseinputthemessage:
\n"
scanf("
Buffer);
retval=send(msgsock,Buffer,strlen(Buffer)+1,0);
retval=sendto(msgsock,Buffer,strlen(Buffer)+1,0,
(structsockaddr*)&
from,fromlen);
//面向UDP
send()失败,错误号:
))
3.连接数据库
3.1使用说明书
在开始菜单中找到SQLSERVER并打开
建立一个新的数据库。
在SQLSERVER中建立一个名为student的数据库
在student库下创立一个Stu_Info表,并在表中包含以下字段名:
snum,sname,ssex,sage,smajor。
输入一些数据,进行测试。
在安全性中设置密码为123.
编译生成可执行的文件,点击运行。
根据提示框中的信息,输入我们需要插入的数据。
关闭程序。
在次点击运行,查看我们插入的数据是否成功的插入。
3.2原理说明
经过ADO访问数据库的技术进行数据库编程。
我们需要在计算机上配置数据源。
配置数据源的过程,就是和让数据库的驱动程序来对数据库进行操作,以便使我们再程序中,能够调用驱动程序来完成我们需要完成的工作。
处理ADO访问技术之外,还有ODBC(开放式数据库互联)等。
3.3程序注释
/*******************************************************************
利用ADO访问MSSQL
要求:
【1】输出Stu_Info表内的每一条记录
【2】添加一条新记录
【3】删除名字为"
李立"
的记录
*****************************************************************/
#import"
c:
\ProgramFiles\CommonFiles\System\ADO\msado15.dll"
\//导入动态链接库,使我们能够使用ADO编程
no_namespacerename("
EOF"
"
EndOfFile"
)//为了防止命名冲突,不使用命名空间
iostream>
//标准输入输出流
iomanip>
//forsetw()
usingnamespacestd;
classSTU//定义学生类
{
public:
charsnum[10];
//学号
charsname[10];
//姓名
charssex[2];
//姓别
longsage;
//年龄
charsmajor[20];
//专业
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.CreateInstance("
//设置连接字符串,必须是BSTR型或者_bstr_t类型
_bstr_tstrConnect="
Provider=SQLOLEDB;
Se
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 管理 系统 计算机 应用 实践 报告