mirror of
https://github.com/YACReader/yacreader
synced 2025-06-04 01:28:55 -04:00
Eliminada escritura en la response de PageController y a?adido Transfer-Encoding chunked
Cada vez que se reciben los datos de los c?mics disponibles en el dispositivo se resetea el conjunto de deviceComics
This commit is contained in:
parent
154d82a84b
commit
1dc6f05946
@ -14,11 +14,17 @@ void PageController::service(HttpRequest& request, HttpResponse& response)
|
|||||||
HttpSession session=Static::sessionStore->getSession(request,response,false);
|
HttpSession session=Static::sessionStore->getSession(request,response,false);
|
||||||
|
|
||||||
QString path = QUrl::fromPercentEncoding(request.getPath()).toLatin1();
|
QString path = QUrl::fromPercentEncoding(request.getPath()).toLatin1();
|
||||||
|
|
||||||
|
//QByteArray path2=request.getPath();
|
||||||
|
//qDebug("PageController: request to -> %s ",path2.data());
|
||||||
|
|
||||||
QStringList pathElements = path.split('/');
|
QStringList pathElements = path.split('/');
|
||||||
QString libraryName = pathElements.at(2);
|
QString libraryName = pathElements.at(2);
|
||||||
qulonglong comicId = pathElements.at(4).toULongLong();
|
qulonglong comicId = pathElements.at(4).toULongLong();
|
||||||
unsigned int page = pathElements.at(6).toUInt();
|
unsigned int page = pathElements.at(6).toUInt();
|
||||||
|
|
||||||
|
//qDebug("lib name : %s",pathElements.at(2).data());
|
||||||
|
|
||||||
Comic * comicFile = session.getCurrentComic();
|
Comic * comicFile = session.getCurrentComic();
|
||||||
if(session.getCurrentComicId() != 0 && !QPointer<Comic>(comicFile).isNull())
|
if(session.getCurrentComicId() != 0 && !QPointer<Comic>(comicFile).isNull())
|
||||||
{
|
{
|
||||||
@ -26,7 +32,9 @@ void PageController::service(HttpRequest& request, HttpResponse& response)
|
|||||||
{
|
{
|
||||||
if(comicFile->pageIsLoaded(page))
|
if(comicFile->pageIsLoaded(page))
|
||||||
{
|
{
|
||||||
|
//qDebug("PageController: La página estaba cargada -> %s ",path.data());
|
||||||
response.setHeader("Content-Type", "image/jpeg");
|
response.setHeader("Content-Type", "image/jpeg");
|
||||||
|
response.setHeader("Transfer-Encoding","chunked");
|
||||||
QByteArray pageData = comicFile->getRawPage(page);
|
QByteArray pageData = comicFile->getRawPage(page);
|
||||||
QDataStream data(pageData);
|
QDataStream data(pageData);
|
||||||
char buffer[4096];
|
char buffer[4096];
|
||||||
@ -34,10 +42,12 @@ void PageController::service(HttpRequest& request, HttpResponse& response)
|
|||||||
int len = data.readRawData(buffer,4096);
|
int len = data.readRawData(buffer,4096);
|
||||||
response.write(QByteArray(buffer,len));
|
response.write(QByteArray(buffer,len));
|
||||||
}
|
}
|
||||||
response.write(pageData);
|
//response.write(pageData,true);
|
||||||
|
response.write(QByteArray(),true);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
//qDebug("PageController: La página NO estaba cargada 404 -> %s ",path.data());
|
||||||
response.setStatus(404,"not found"); //TODO qué mensaje enviar
|
response.setStatus(404,"not found"); //TODO qué mensaje enviar
|
||||||
response.write("404 not found",true);
|
response.write("404 not found",true);
|
||||||
}
|
}
|
||||||
|
@ -269,6 +269,7 @@ void HttpSession::setDeviceType(const QString & device)
|
|||||||
{
|
{
|
||||||
if(dataPtr)
|
if(dataPtr)
|
||||||
{
|
{
|
||||||
|
dataPtr->yacreaderSessionData.comicsOnDevice.clear(); //TODO crear un método clear que limpie la sesión completamente
|
||||||
dataPtr->yacreaderSessionData.device = device;
|
dataPtr->yacreaderSessionData.device = device;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user