SDWebImage и настройка пользовательских заголовков HTTP?
Я только что изменил свой код для кэширования изображений с EGOImageCache на SDWebView. К сожалению, я не знаю, как установить пользовательские заголовки HTTP, так как я должен отправить аутентификацию, чтобы иметь возможность получать изображения. Это было легко сделать с EGOImageCache, так как я расширил NSURLRequest в соответствующем месте. Но я не знаю, как это сделать с SDWebView.framework. Я вижу заголовки, и я нашел методы в SDWebImageDownloader.h, содержащий
/**
* Set a value for a HTTP header to be appended to each download HTTP request.
*
* @param value The value for the header field. Use `nil` value to remove the header.
* @param field The name of the header field to set.
*/
- (void)setValue:(NSString *)value forHTTPHeaderField:(NSString *)field;
/**
* Returns the value of the specified HTTP header field.
*
* @return The value associated with the header field field, or `nil` if there is no corresponding header field.
*/
- (NSString *)valueForHTTPHeaderField:(NSString *)field;
Кажется, что библиотека поддерживает заголовки HTTP. Но поскольку я использую UIImageView+WebCache.h i, я не вижу там опции для установки заголовков. В моем коде я звоню
[self.imageView setImageWithURL:[NSURL URLWithString:themeImageURL] placeholderImage:[UIImage imageNamed:@"placeholder.png"]];
Кто-нибудь может сказать мне, как установить заголовки HTTP?
6 ответов
У меня была такая же проблема, и я попытался сделать:
SDWebImageDownloader *manager = [SDWebImageDownloader sharedDownloader];
[manager setValue:username forHTTPHeaderField:@"X-Oauth-Username"];
Но заголовок не был отправлен. После нескольких попыток я столкнулся с проблемой: SDWebImageDownloader в sharedDownloader создает новый экземпляр SDWebImageDownloader, поэтому, когда вы помещаете заголовок в этот экземпляр, экземпляр, который действительно загружает изображение, не имеет заголовка.
Я решил сделать это:
SDWebImageDownloader *manager = [SDWebImageManager sharedManager].imageDownloader;
[manager setValue:username forHTTPHeaderField:@"X-Oauth-Username"];
Swift Version
let imageDownloader = SDWebImageDownloader.shared()
imageDownloader.setValue("Username", forHTTPHeaderField: "X-Oauth-Username")
Я знаю, что он довольно старый, но не мог не рассказать, что сработало для меня. Мне нужно было установить значение токена для заголовка logintoken
, Итак, этот кусок кода сделал то, что я хотел -
NSString *loginToken = // Some method to fetch login token
[SDWebImageDownloader.sharedDownloader setValue:loginToken forHTTPHeaderField:@"logintoken"];
Я использую обычную аутентификацию и настраиваю username
а также password
на sharedDownloader
помогло:
SDWebImageDownloader *downloader = [SDWebImageDownloader sharedDownloader];
downloader.username = @"username";
downloader.password = @"password";
Swift 4.1
let manager = SDWebImageManager.shared().imageDownloader
manager?.setValue("oAuthToken",forHTTPHeaderField: "AuthHeaderName")
manager?.downloadImage(with: imageURL, options: SDWebImageDownloaderOptions.useNSURLCache, progress:
{ (receivedSize, expectedSize , url) in
// progression tracking code
}, completed: { (image,data , error,finished) in
if error == nil && image != nil {
// here the downloaded image is cached, now you need to set it to the imageView
DispatchQueue.main.async {
imageView.image = image
self.maskCircle(anyImage: image!)
}
} else {
// handle the failure
DispatchQueue.main.async {
let defImage = UIImage(named: SearchKitConstants.ImageNameConstants.NoUserImage, in: ZohoSearchKit.frameworkBundle, compatibleWith: nil)!
imageView.image = defImage
self.maskCircle(anyImage: defImage)
}
}
})
SDWebImage 5 и более поздних версий необходимо использовать следующий вырезанный код.
func configureSDWebImageHeader(){
let requestModifier = SDWebImageDownloaderRequestModifier { (request) -> URLRequest? in
var mutableRequest = request
// Used Your Header Keys
mutableRequest.setValue("", forHTTPHeaderField: KeyConstant.USERID)
mutableRequest.setValue("", forHTTPHeaderField: KeyConstant.AUTH_KEY)
return mutableRequest
};
SDWebImageDownloader.shared.requestModifier = requestModifier
}