内容表

上一话题

QNetworkDatagram

下一话题

QNetworkInterface

QNetworkDiskCache

QNetworkDiskCache class provides a very basic disk cache. 更多

Inheritance diagram of PySide2.QtNetwork.QNetworkDiskCache

概要

虚函数

详细描述

QNetworkDiskCache stores each url in its own file inside of the cacheDirectory 使用 QDataStream . Files with a text MimeType are compressed using qCompress . Data is written to disk only in insert() and updateMetaData() .

Currently you cannot share the same cache files with more than one disk cache.

QNetworkDiskCache by default limits the amount of space that the cache will use on the system to 50MB.

Note you have to set the cache directory before it will work.

A network disk cache can be enabled by:

manager = QNetworkAccessManager(self)
diskCache = QNetworkDiskCache(self)
diskCache.setCacheDirectory("cacheDir")
manager.setCache(diskCache)
											

When sending requests, to control the preference of when to use the cache and when to use the network, consider the following:

# do a normal request (preferred from network, as this is the default)
request = QNetworkRequest(QUrl("http://qt-project.org"))
manager.get(request)
# do a request preferred from cache
request2 = QNetworkRequest(QUrl("http://qt-project.org"))
request2.setAttribute(QNetworkRequest.CacheLoadControlAttribute, QNetworkRequest.PreferCache)
manager.get(request2)
											

To check whether the response came from the cache or from the network, the following can be applied:

@Slot(QNetworkReply)
def replyFinished(reply):
    fromCache = reply.attribute(QNetworkRequest.SourceIsFromCacheAttribute)
    print("page from cache? %d" % fromCache)
											
class QNetworkDiskCache ( [ parent=None ] )
param parent

QObject

Creates a new disk cache. The parent 自变量会被传递给 QAbstractNetworkCache ‘s constructor.

PySide2.QtNetwork.QNetworkDiskCache. cacheDirectory ( )
返回类型

unicode

Returns the location where cached files will be stored.

PySide2.QtNetwork.QNetworkDiskCache. expire ( )
返回类型

qint64

Cleans the cache so that its size is under the maximum cache size. Returns the current size of the cache.

When the current size of the cache is greater than the maximumCacheSize() older cache files are removed until the total size is less then 90% of maximumCacheSize() starting with the oldest ones first using the file creation date to determine how old a cache file is.

Subclasses can reimplement this function to change the order that cache files are removed taking into account information in the application knows about that QNetworkDiskCache does not, for example the number of times a cache is accessed.

注意

cacheSize() calls expire if the current cache size is unknown.

PySide2.QtNetwork.QNetworkDiskCache. fileMetaData ( fileName )
参数

fileName – unicode

返回类型

QNetworkCacheMetaData

返回 QNetworkCacheMetaData for the cache file fileName .

fileName is not a cache file QNetworkCacheMetaData will be invalid.

PySide2.QtNetwork.QNetworkDiskCache. maximumCacheSize ( )
返回类型

qint64

Returns the current maximum size for the disk cache.

PySide2.QtNetwork.QNetworkDiskCache. setCacheDirectory ( cacheDir )
参数

cacheDir – unicode

Sets the directory where cached files will be stored to cacheDir

QNetworkDiskCache will create this directory if it does not exists.

Prepared cache items will be stored in the new cache directory when they are inserted.

另请参阅

cacheDirectory() CacheLocation

PySide2.QtNetwork.QNetworkDiskCache. setMaximumCacheSize ( size )
参数

size qint64

Sets the maximum size of the disk cache to be size .

If the new size is smaller then the current cache size then the cache will call expire() .