Автор работы: Пользователь скрыл имя, 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
QTableWidgetItem *item
= new QTableWidgetItem(QIcon(
item->setFlags(Qt::
static_cast<MainWindow
*>(mainWindow)->explorerView_
item = new QTableWidgetItem(fileList[i]->
item->setFlags(Qt::
static_cast<MainWindow
*>(mainWindow)->explorerView_
}
static_cast<MainWindow *>(mainWindow)->pathEdit1->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->backButton1->
else
static_cast<MainWindow *>(mainWindow)->backButton1->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->
else
static_cast<MainWindow *>(mainWindow)->
*/ }
}
}
QString ModelClient::correctIp(QString ip)
{
bool found=false;
for(int i=0;i<ip.size();i++)
{
if(ip[i]=='-')
{
found=true;
break;
}
}
if(!found)
return ip;
if(ip.compare("localhost")==0|
{
return ip;
}
else
{
QString newStr;
found=false;
for(int i=0;i<ip.size();i++)
{
if(ip[i]=='-')
{
found=true;
i+=2;
}
if(found)
newStr.append(ip[i]);
}
return newStr;
}
}
void ModelClient::connected()
{}
void ModelClient::
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << quint8(11);
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
void ModelClient::
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("localhost")==0)
{
if(requestModel==1)
{
static_cast<MainWindow *>(mainWindow)->driveBox_1->
static_cast<MainWindow *>(mainWindow)->driveBox_1->
}
else
{
static_cast<MainWindow *>(mainWindow)->driveBox_2->
static_cast<MainWindow *>(mainWindow)->driveBox_2->
}
}
else
{
QByteArray block=0;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << quint8(12);
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
qDebug()<<"initiateDrivesList"
}
void ModelClient::
{
ip = correctIp(ip);
requestModel=rm;
if(drive.compare("")!=0&&ip.
{
if(ip.compare("localhost")==0)
{
modelFileSystem->changeDrive(
initiateFileItemsList(ip, rm);
}
else
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << quint8(13);
out << ip;
out << drive;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug()<<"
}
}
}
void ModelClient::
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("")!=0)
{
if(ip.compare("localhost")==0)
{
if(requestModel==1)
{
static_cast<MainWindow *>(mainWindow)->explorerView_
QVector<ModelFileSystemItem*> fileList = modelFileSystem->
int rowCount = modelFileSystem->
for(int i=0;i<rowCount;i++)
{
static_cast<MainWindow *>(mainWindow)->explorerView_
QTableWidgetItem *item = new QTableWidgetItem(QIcon(
item->setFlags(Qt::
static_cast<MainWindow *>(mainWindow)->explorerView_
item = new QTableWidgetItem(fileList[i]->
item->setFlags(Qt::
static_cast<MainWindow *>(mainWindow)->explorerView_
}
static_cast<MainWindow *>(mainWindow)->pathEdit1->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->backButton1->
else
static_cast<MainWindow *>(mainWindow)->backButton1->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->
else
static_cast<MainWindow *>(mainWindow)->
}
else
{
static_cast<MainWindow *>(mainWindow)->explorerView_
QVector<ModelFileSystemItem*> fileList = modelFileSystem->
int rowCount = modelFileSystem->
for(int i=0;i<rowCount;i++)
{
static_cast<MainWindow *>(mainWindow)->explorerView_
QTableWidgetItem *item = new QTableWidgetItem(QIcon(
item->setFlags(Qt::
static_cast<MainWindow *>(mainWindow)->explorerView_
item = new QTableWidgetItem(fileList[i]->
item->setFlags(Qt::
static_cast<MainWindow *>(mainWindow)->explorerView_
}
static_cast<MainWindow *>(mainWindow)->pathEdit2->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->backButton2->
else
static_cast<MainWindow *>(mainWindow)->backButton2->
if(modelFileSystem->
static_cast<MainWindow *>(mainWindow)->
else
static_cast<MainWindow *>(mainWindow)->
}
}
else
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)14;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug()<<"
}
}
}
void ModelClient::initiateGoTo(
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("")!=0)
{
if(ip.compare("localhost")==0)
{
modelFileSystem->goTo(path);
initiateFileItemsList(ip, rm);
qDebug()<<"
}
else {
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)16;
out << ip;
out << path;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
qDebug()<<"initiateGoTo"<<ip<<
}
}
}
void ModelClient::initiateGoBack(
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("")!=0)
{
if(ip.compare("localhost")==0)
{
modelFileSystem->goBack();
initiateFileItemsList(ip, rm);
}
else
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)17;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
}
}
void ModelClient::
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("")!=0)
{
if(ip.compare("localhost")==0)
{
modelFileSystem->goForward();
initiateFileItemsList(ip, rm);
}
else
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)18;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
}
}
void ModelClient::initiateGoHome(
{
ip = correctIp(ip);
requestModel=rm;
if(ip.compare("")!=0)
{
if(ip.compare("localhost")==0)
{
modelFileSystem->goHome();
initiateFileItemsList(ip, rm);
}
else
{
QByteArray block;
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::
out << quint64(0);
out << (quint8)19;
out << ip;
out.device()->seek(0);
out << quint64(block.size() - sizeof(quint64));
socket->write(block);
}
}
}
void ModelClient::initiateCopy(
{
if(sourceIp.compare("
modelFileSystem->copy(source,
}
Лістинг ModelServerHandler
#include "ModelServerHandler.h"
#include <QMessageBox>
ModelServerHandler::
{
}
void ModelServerHandler::init(
{
client=cl;
mainWindow=mw;
qDebug() << "New client from:"
<< client->peerAddress().
connect(client, SIGNAL(readyRead()), this, SLOT(readyRead()));
connect(client, SIGNAL(disconnected()), this, SLOT(disconnected()));
}
void ModelServerHandler::readyRead(
{
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;
//qint64 bytes = buffer->write(client->readAll(
//in >> buffer; // go back as many bytes as we just wrote so that it can be read
QImage image;
// Construct a new QImage
//image.loadFromData(buffer->
in >> image;
if (image.isNull())
// Check if the image was indeed received
qDebug("The image is null. Something failed.");
mainWindow->label->setPixmap(
QListWidgetItem *item1=new QListWidgetItem(QPixmap::
mainWindow->listWidget->
}
}
void ModelServerHandler::
{
// QTcpSocket *client = (QTcpSocket*)sender();
// qDebug() << "Client disconnected:"
<< client->peerAddress().
// clients.remove(client);
// QString user = users[client];
// users.remove(client);
// sendUserList();
// foreach(QTcpSocket *client, clients)
// client->write(QString("Server:
}
Лістинг 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::
Информация о работе Розробка системи автоматизованого мережевого розподілення навчального матеріалу