IOS之相同URL不同图片识别

场景,一张图片A,上传到了地址url1,现在修改了图片,变为了B,上传到了url1,这时候造成,相同的url前后时间的图片是不同的,平时写的程序,会有缓存,如果本地该图片存在,则不去网络获取,如果不存在则去获取图片,但这时候url是相同的,app会认为图片是没变的,所以不会再重新请求加载。

这种相同url不同图片的情况比较少吧,一般都会出现个新的图片B的url2,来避开这个问题。

但这种情况怎么来处理呢。

查阅试验了些,发现可以使用http响应头信息来进行辨别吧,

http的response,响应头信息中包含last-modified和content-length(IOS中使用NSURLConnection的delegate方法- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response就可在下载图片之前先查看数据信息),最后修改时间以及响应正文数据大小,一是图片变了,基本上最后修改时间肯定变了,二是几乎改变图片都会造成图片大小变化吧,估计这2者就能够判别一个url的图片是不是改变过了,本地app缓存的时候将这些数据也缓存下,然后将app的缓存策略也做少许更改,加载完本地的图片,还要请求url,看头信息的这2个数据是否变了,变了的话就说明图片经过修改了,需要重新下载更新UI。

//    NSHTTPURLResponse *resp = (NSHTTPURLResponse *)response;

//    NSLog(@"%@",resp.allHeaderFields);
//    NSString *timeString = [resp.allHeaderFields objectForKey:@"Last-Modified"];
//    NSLog(@"%@",timeString);

//    response.expectedContentLength

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS中实现图片识别文字功能可以使用苹果提供的Vision框架,以下是基本的实现步骤: 1. 导入Vision框架:在Xcode中,选中项目,选择General -> Linked Frameworks and Libraries,点击+号,搜索Vision并添加。 2. 创建一个VNImageRequestHandler:这个类用于处理图像请求。可以通过UIImage对象或者CMSampleBufferRef对象创建VNImageRequestHandler。 3. 创建一个VNRecognizeTextRequest:这个类用于识别图像中的文字。 4. 将VNRecognizeTextRequest对象添加到VNImageRequestHandler中。 5. 执行VNImageRequestHandler的perform方法开始识别。 6. 处理识别结果:VNRecognizeTextRequest的结果是一个VNRecognizedTextObservation对象数组,每个对象包含了识别出来的一个文本区域。 以下是示例代码: ```swift import Vision func recognizeText(image: UIImage) { guard let cgImage = image.cgImage else { return } let requestHandler = VNImageRequestHandler(cgImage: cgImage, options: [:]) let request = VNRecognizeTextRequest(completionHandler: handleTextRecognition) do { try requestHandler.perform([request]) } catch { print(error.localizedDescription) } } func handleTextRecognition(request: VNRequest, error: Error?) { guard let observations = request.results as? [VNRecognizedTextObservation] else { return } for observation in observations { guard let topCandidate = observation.topCandidates(1).first else { continue } print(topCandidate.string) } } ``` 在这个例子中,我们先将UIImage对象转化为CGImage对象,然后创建了一个VNImageRequestHandler和一个VNRecognizeTextRequest对象。最后执行VNImageRequestHandler的perform方法,开始识别。当识别完成后,会调用handleTextRecognition方法处理结果。在这个例子中,我们只是简单地将识别出来的文本打印出来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值