WHPingTester.m 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. //
  2. // WHPingTester.m
  3. // BigVPN
  4. //
  5. // Created by wanghe on 2017/5/11.
  6. // Copyright © 2017年 wanghe. All rights reserved.
  7. //
  8. #import "WHPingTester.h"
  9. @interface WHPingTester()<SimplePingDelegate>
  10. {
  11. NSTimer* _timer;
  12. }
  13. @property(nonatomic, strong) SimplePing* simplePing;
  14. @property(nonatomic, strong) NSMutableArray<WHPingItem*>* pingItems;
  15. @end
  16. @implementation WHPingTester
  17. - (instancetype) initWithHostName:(NSString*)hostName
  18. {
  19. if(self = [super init])
  20. {
  21. self.simplePing = [[SimplePing alloc] initWithHostName:hostName];
  22. self.simplePing.delegate = self;
  23. self.simplePing.addressStyle = SimplePingAddressStyleAny;
  24. self.pingItems = [NSMutableArray new];
  25. }
  26. return self;
  27. }
  28. - (void) startPing
  29. {
  30. [self.simplePing start];
  31. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  32. if([self.pingItems count] > 0)
  33. {
  34. if(self.delegate!=nil && [self.delegate respondsToSelector:@selector(didPingSucccessWithTime:withError:)])
  35. {
  36. [self.delegate didPingSucccessWithTime:0 withError:[NSError errorWithDomain:NSURLErrorDomain code:111 userInfo:nil]];
  37. }
  38. }
  39. });
  40. }
  41. - (void) stopPing
  42. {
  43. [_timer invalidate];
  44. _timer = nil;
  45. [self.simplePing stop];
  46. }
  47. - (void) actionTimer
  48. {
  49. if (self.countdownTime > 0) {
  50. _timer = [NSTimer scheduledTimerWithTimeInterval:self.countdownTime target:self selector:@selector(sendPingData) userInfo:nil repeats:YES];
  51. }
  52. else
  53. {
  54. _timer = [NSTimer scheduledTimerWithTimeInterval:0.2 target:self selector:@selector(sendPingData) userInfo:nil repeats:YES];
  55. }
  56. }
  57. - (void) sendPingData
  58. {
  59. [self.simplePing sendPingWithData:nil];
  60. }
  61. #pragma mark Ping Delegate
  62. - (void)simplePing:(SimplePing *)pinger didStartWithAddress:(NSData *)address
  63. {
  64. [self actionTimer];
  65. }
  66. - (void)simplePing:(SimplePing *)pinger didFailWithError:(NSError *)error
  67. {
  68. HLog(@"ping失败--->%@", error);
  69. if(self.delegate!=nil && [self.delegate respondsToSelector:@selector(didPingfialewithError:)])
  70. {
  71. [self.delegate didPingfialewithError:error];
  72. }
  73. }
  74. - (void)simplePing:(SimplePing *)pinger didSendPacket:(NSData *)packet sequenceNumber:(uint16_t)sequenceNumber
  75. {
  76. WHPingItem* item = [WHPingItem new];
  77. item.sequence = sequenceNumber;
  78. [self.pingItems addObject:item];
  79. item.beginDate = [NSDate date];
  80. }
  81. - (void)simplePing:(SimplePing *)pinger didFailToSendPacket:(NSData *)packet sequenceNumber:(uint16_t)sequenceNumber error:(NSError *)error
  82. {
  83. HLog(@"发包失败--->%@", error);
  84. if(self.delegate!=nil && [self.delegate respondsToSelector:@selector(didPingSucccessWithTime:withError:)])
  85. {
  86. [self.delegate didPingSucccessWithTime:0 withError:error];
  87. }
  88. }
  89. - (void)simplePing:(SimplePing *)pinger didReceivePingResponsePacket:(NSData *)packet sequenceNumber:(uint16_t)sequenceNumber
  90. {
  91. [self.pingItems enumerateObjectsUsingBlock:^(WHPingItem * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
  92. if(obj.sequence == sequenceNumber)
  93. {
  94. if(self.delegate!=nil && [self.delegate respondsToSelector:@selector(didPingSucccessWithTime:withError:)])
  95. {
  96. float delayTime = [[NSDate date] timeIntervalSinceDate:obj.beginDate] * 1000;
  97. [self.delegate didPingSucccessWithTime:delayTime withError:nil];
  98. }
  99. [self.pingItems removeObject:obj];
  100. }
  101. }];
  102. }
  103. - (void)simplePing:(SimplePing *)pinger didReceiveUnexpectedPacket:(NSData *)packet
  104. {
  105. }
  106. @end
  107. @implementation WHPingItem
  108. @synthesize beginDate;
  109. @end