Автор работы: Пользователь скрыл имя, 14 Февраля 2013 в 21:48, дипломная работа
Метою дослідження є перевірка навичок програмування на QT, отримання розробленої системи автоматичного мережевого розподілення навчального матеріалу у комп’ютерному класі з урахуванням IP-адрес комп’ютерів й інструкції з її використання та закріплення знань, отриманих в процесі теоретичної діяльності.
Задачі дослідження наступні:
Робота над програмним продуктом та реалізацією програмного забезпечення;
Застосування знань про мережну роботу засобами QT;
Застосування знань про маніпулювання файловою системою й роботою з нею засобами QT;
Отримання нового досвіду з проектування на платформі QT;
ВСТУП 6
РОЗДІЛ 1. АНАЛІЗ ДЖЕРЕЛ СТОСОВНО МЕТОДІВ РОЗРОБКИ 9
Вибір середи програмування 9
Технологія клієнт – сервер: взаємодія клієнта з сервером 11
Робота з мережею засобами QT 13
Використання TCP за допомогою класів QTcpSocket та QTcpServer 14
Робота з файловою системою засобами QT 16
Клас QFileSystemModel 17
Клас QDir. Перегляд вмісту директорії за допомогою QDir 17
Клас QFile 19
Клас QFileInfo 20
Робота з потоками засобами QT 21
Клас QThread 22
Класи QRunnable та QThreadPool 24
Клас QtConcurrent 24
РОЗДІЛ 2. ОСНОВНІ ПРОБЛЕМИ РОЗРОБКИ ТА ЇХ РІШЕННЯ 26
Мета розробки 26
Основні задачі та проблеми 26
Крос-платформність 27
Робота з мережею: захист від збоїв 28
Власний протокол взаємодії клієнта з сервером 29
Маніпулювання файловою системою 30
Алгоритм роботи програми 32
Алгоритм роботи сервера 32
Алгоритм роботи клієнта 34
Алгоритм роботи графічного клієнта 35
РОЗДІЛ 3.РЕАЛІЗАЦІЯ СИСТЕМИ АВТОМАТИЧНОГО МЕРЕЖЕВОГО РОЗПОДІЛЕННЯ НАВЧАЛЬНОГО МАТЕРІАЛУ У КОМПЬЮТЕРНОМУ КЛАСІ 36
Програмна реалізація сервера 38
Програмна реалізація клієнта 40
Програмна реалізація графічного клієнта 42
Інструкція з використання програми 44
РОЗДІЛ 4. ОХОРОНА ПРАЦІ 48
Основні поняття охорони праці 48
Загальні положення 50
Вимоги до виробничого персоналу 51
Вимоги безпеки під час роботи 53
Вимоги безпеки в аварійних ситуаціях 54
Інструкція із заходів пожежної безпеки є службових кабінетах і лабораторіях 55
Загальні положення 55
Співробітники зобов'язані 55
Забороняється 55
Дії при пожежі 55
Обов'язки особи, відповідального за протипожежний стан приміщення 56
Відповідальність особи, відповідального за протипожежний стан приміщенні 56
ВИСНОВКИ 57
СПИСОК ВИКОРИСТАНИХ ДЖЕРЕЛ 59
items.push_back( new ModelFileSystemItem(filemodel-
}
return items;
}
QStringList ModelFileSystem::
{ QStringList drives;
foreach(QFileInfo drive, QDir::drives())
{ drives.push_back(drive.
}
return drives;
}
QString ModelFileSystem::
{ return path;
}
void ModelFileSystem::
{path=p;
}
bool ModelFileSystem::goTo(QString p)
{ bool res=true;
QModelIndex ItemIndex = filemodel->index(QDir(path+p+"
if(filemodel->fileInfo(
{for(int i=pathHistory.size()-1;i>0;i--
if(pathHistory[i].compare(
break;
else
pathHistory.remove(i);
path+=p+"/";
pathHistory.push_back(path);
pathHistoryIndex=pathHistory.
}
else
res=false;
updateAvalibility();
return res;
}
void ModelFileSystem::
{ if(pathHistory.size()>1 && pathHistoryIndex>0)
isAvalibleBack=true;
else
isAvalibleBack=false;
if(pathHistoryIndex<
isAvalibleForward=true;
else
isAvalibleForward=false;
}
void ModelFileSystem::goBack()
{ pathHistoryIndex--;
if(pathHistoryIndex<=0)
pathHistoryIndex=0;
path=pathHistory[
updateAvalibility();
}
void ModelFileSystem::goForward()
{ pathHistoryIndex++;
if(pathHistoryIndex>=
pathHistoryIndex=pathHistory.
path=pathHistory[
updateAvalibility();
}
void ModelFileSystem::goHome()
{ path=root;
pathHistory.clear();
pathHistory.push_back(path);
pathHistoryIndex=0;
updateAvalibility();
}
bool ModelFileSystem::
bool ModelFileSystem::
void ModelFileSystem::changeDrive(
{ path = d;
root = d;
filemodel->setRootPath(d);
pathHistory.clear();
pathHistory.push_back(path);
pathHistoryIndex=0;
updateAvalibility();
}
Додаток Б
Лістинг ModelClient
#include "ModelClient.h"
ModelClient::ModelClient(
{ socket = new QTcpSocket(this);
modelFileSystem = new ModelFileSystem(parent,"/");
connect(socket, SIGNAL(readyRead()), this, SLOT(readyRead()));
connect(socket, SIGNAL(connected()), this, SLOT(connected()));
socket->connectToHost("127.0.
}
void ModelClient::readyRead()
{ QDataStream in(socket);
in.setVersion(QDataStream::Qt_
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
QString ip;
QString path;
QString drive;
quint8 count;
quint8 rowCount;
quint8 command;
for (;;)
{ m_nNextBlockSize=0;
{ if (socket->bytesAvailable() < sizeof(quint64)) {
break;
}
in >> m_nNextBlockSize;
}
if (socket->bytesAvailable() < m_nNextBlockSize) {
break;
}
in >> command;
qDebug() << "Received command " << command;
switch(command)
{ case 12:
in >>ip;
out << quint64(0);
out << quint8(22);
out << quint8(modelFileSystem->
for(int i=0;i<modelFileSystem->
{ out << modelFileSystem->
}
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Sending drive list ";
break;
case 13:
in >>ip;
in >> drive;
block.clear();
modelFileSystem->changeDrive(
out << quint64(0);
out << (quint8)23;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Changed drive to "<<drive;
break;
case 14:
in >>ip;
fileList = modelFileSystem->
block.clear();
out << quint64(0);
out << (quint8)24;
out << ip;
rowCount = modelFileSystem->
out << (quint8)rowCount;
out << modelFileSystem->
if(modelFileSystem->
out << (quint8)1;
else
out << (quint8)0;
if(modelFileSystem->
out << (quint8)1;
else
out << (quint8)0;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Initiate all files";
break;
case 15:
in >> ip;
in >> rowCount;
in >> count;
if(count<rowCount)
{block.clear();
out << quint64(0);
out << (quint8)25;
out << ip;
out << quint8(rowCount);
out << quint8(count);
out << fileList[count]->getIcon();
out << fileList[count]->getCaption();
out << fileList[count]->getSize();
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
qDebug() << "Sending file";
break;
case 16:
in >>ip;
in >> path;
block.clear();
modelFileSystem->goTo(path);
out << quint64(0);
out << (quint8)23;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Go To "<<path;
break;
case 17:
in >>ip;
block.clear();
modelFileSystem->goBack();;
out << quint64(0);
out << (quint8)23;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Go Back";
break;
case 18:
in >>ip;
block.clear();
modelFileSystem->goForward();
out << quint64(0);
out << (quint8)23;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Go Forward";
break;
case 19:
in >>ip;
block.clear();
modelFileSystem->goHome();
out << quint64(0);
out << (quint8)23;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug() << "Go Home";
break;
default: block.clear();
in.setDevice(socket);
break;
}
}
}
void ModelClient::connected()
{ QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)7;
out << QString("default");
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
Лістинг ModelFileSystem
#include "ModelFileSystem.h"
ModelFileSystem::
{ filemodel = new QFileSystemModel(obj);
changeDrive(rp);
}
QVector<ModelFileSystemItem*> ModelFileSystem::
{ QVector<ModelFileSystemItem*> items;
QDir di(path);
QStringList qsl = di.entryList(QDir::
for(int i=0;i<qsl.size();i++)
{ QModelIndex ItemIndex = filemodel->index(QDir(path+
QString size;
if(filemodel->fileInfo(
size="folder";
else
size= QString::number(filemodel->
items.push_back( new ModelFileSystemItem(filemodel-
}
return items;
}
QStringList ModelFileSystem::
{ QStringList drives;
foreach(QFileInfo drive, QDir::drives())
{ drives.push_back(drive.
}
return drives;
}
QString ModelFileSystem::
{ return path;
}
void ModelFileSystem::
{path=p;
}
bool ModelFileSystem::goTo(QString p)
{ bool res=true;
QModelIndex ItemIndex = filemodel->index(QDir(path+p+"
if(filemodel->fileInfo(
{for(int i=pathHistory.size()-1;i>0;i--
if(pathHistory[i].compare(
break;
else
pathHistory.remove(i);
path+=p+"/";
pathHistory.push_back(path);
pathHistoryIndex=pathHistory.
}
else
res=false;
updateAvalibility();
return res;
}
void ModelFileSystem::
{ if(pathHistory.size()>1 && pathHistoryIndex>0)
isAvalibleBack=true;
else
isAvalibleBack=false;
if(pathHistoryIndex<
isAvalibleForward=true;
else
isAvalibleForward=false;
}
void ModelFileSystem::goBack()
{ pathHistoryIndex--;
if(pathHistoryIndex<=0)
pathHistoryIndex=0;
path=pathHistory[
updateAvalibility();
}
void ModelFileSystem::goForward()
{ pathHistoryIndex++;
if(pathHistoryIndex>=
pathHistoryIndex=pathHistory.
path=pathHistory[
updateAvalibility();
}
void ModelFileSystem::goHome()
{ path=root;
pathHistory.clear();
pathHistory.push_back(path);
pathHistoryIndex=0;
updateAvalibility();
}
bool ModelFileSystem::
bool ModelFileSystem::
void ModelFileSystem::changeDrive(
{ path = d;
root = d;
filemodel->setRootPath(d);
pathHistory.clear();
pathHistory.push_back(path);
pathHistoryIndex=0;
updateAvalibility();
Лістинг ModelFileSystemItem
#include "ModelFileSystemItem.h"
ModelFileSystemItem::
{icon=i;
caption=c;
size=s;
}
QImage ModelFileSystemItem::getIcon()
{ return icon;
}
QString ModelFileSystemItem::
{ return caption;
}
QString ModelFileSystemItem::getSize()
{ return size;
}
Додаток В
Лістинг ModelServer
#include "ModelServer.h"
ModelServer::ModelServer(
{ mainWindow = new MainWindow();
mainWindow->show();
QString sPath = "/";
QDir dir("F:/L2");
dir.setPath(QString("F:/L2"));
filemodel = new QFileSystemModel(this);
filemodel->setRootPath(dir.
QModelIndex parentIndex = filemodel->index(QDir("F:/L2/
int numRows = filemodel->rowCount(
qDebug() << filemodel->fileInfo(
QDir di("C:/");
QStringList qsl = di.entryList(QDir::
for(int i=0;i<qsl.size();i++)
qDebug() << "Count:" << qsl[i];
foreach( QFileInfo drive, QDir::drives() )
{ qDebug() << "Drive: " << drive.absolutePath();
}
}
void ModelServer::
{ QTcpSocket *client = new QTcpSocket(this);
client->setSocketDescriptor(
clients.push_back(client);
//QListWidgetItem *item1=new QListWidgetItem(client->
//mainWindow->clientList->
qDebug() << "New client from:"
<< client->peerAddress().
connect(client, SIGNAL(readyRead()), this, SLOT(readyRead()));
connect(client, SIGNAL(disconnected()), this, SLOT(disconnected()));
}
void ModelServer::readyRead()
{
QTcpSocket *client = (QTcpSocket*)sender();
QDataStream in(client);
quint8 command;
in >> command;
qDebug() << "Received command " << command;
if(command==7)
{
QString name;
QByteArray block;
in >> block;
name = QString::fromUtf8( block.data(), block.size() );
qDebug() << "Message " << name;
Информация о работе Розробка системи автоматизованого мережевого розподілення навчального матеріалу