iTools.m 49 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274
  1. //
  2. // iTools.m
  3. // VclustersGemini
  4. //
  5. // Created by 余衡武 on 2020/4/1.
  6. // Copyright © 2020 APPLE. All rights reserved.
  7. //
  8. #import "iTools.h"
  9. #import "CommonCrypto/CommonDigest.h"
  10. #import <CommonCrypto/CommonCrypto.h>
  11. #import "RSA.h"
  12. static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  13. /* 运营商 首先需要引入以下两个系统类:*/
  14. #import <CoreTelephony/CTCarrier.h>
  15. #import <CoreTelephony/CTTelephonyNetworkInfo.h>
  16. @implementation iTools
  17. + (NSString *)getJSONStringFromDictionary:(NSDictionary *)dict {
  18. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dict options:NSJSONWritingPrettyPrinted error:nil];
  19. NSString *jsonStr = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  20. return jsonStr;
  21. }
  22. + (NSString *)getJSONStringFromArray:(NSArray *)array {
  23. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:array options:NSJSONWritingPrettyPrinted error:nil];
  24. NSString *jsonStr = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  25. return jsonStr;
  26. }
  27. + (NSInteger)getNowTimeStamp {
  28. return [[NSDate date] timeIntervalSince1970];
  29. }
  30. + (NSInteger)getNowTimeStampSS {
  31. NSDate *dateValue = [NSDate date];
  32. NSTimeInterval second = [dateValue timeIntervalSince1970];
  33. long long dTime = [[NSNumber numberWithDouble:second*1000] longLongValue];
  34. return dTime;
  35. }
  36. /** 获取当前时间戳-以秒为单位-return yyyyy年MM月dd日 HH:mm:ss */
  37. + (NSString *)getNowTimeString1 {
  38. NSDate *nowDate = [NSDate date];
  39. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  40. [format setDateFormat:@"yyyy年MM月dd日 HH:mm:ss"];
  41. NSString *dateStr = [format stringFromDate:nowDate];
  42. return dateStr;
  43. }
  44. /** 获取当前时间戳-以秒为单位-return yyyyy-MM-dd HH:mm:ss */
  45. + (NSString *)getNowTimeString2 {
  46. NSDate *nowDate = [NSDate date];
  47. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  48. [format setDateFormat:@"yyyy-MM-dd HH:mm:ss"];
  49. NSString *dateStr = [format stringFromDate:nowDate];
  50. return dateStr;
  51. }
  52. + (NSString *)getNowTimeString3 {
  53. NSDate *nowDate = [NSDate date];
  54. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  55. [format setDateFormat:@"yyyy-MM-dd HH:mm:ss.SSS"];
  56. NSString *dateStr = [format stringFromDate:nowDate];
  57. return dateStr;
  58. }
  59. + (NSInteger)getNowTimeStampToInterval:(NSTimeInterval)second {
  60. long long dTime = [[NSNumber numberWithDouble:second*1000] longLongValue];
  61. return dTime;
  62. }
  63. + (NSString *)getNowTimeStampString {
  64. NSString* date;
  65. NSDateFormatter * formatter = [[NSDateFormatter alloc ] init];
  66. [formatter setDateFormat:@"YYYYMMddhhmmssSSS"];
  67. date = [formatter stringFromDate:[NSDate date]];
  68. NSString *timeNow = [NSString stringWithFormat:@"%@", date];
  69. return timeNow;
  70. }
  71. + (NSString *)getNowTimeString {
  72. NSDate *nowDate = [NSDate date];
  73. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  74. [format setDateFormat:@"yyyy/MM/dd HH:mm"];
  75. NSString *dateStr = [format stringFromDate:nowDate];
  76. return dateStr;
  77. }
  78. + (NSString *)getNowDateString {
  79. NSDate *nowDate = [NSDate date];
  80. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  81. [format setDateFormat:@"yyyy-MM-dd"];
  82. NSString *dateStr = [format stringFromDate:nowDate];
  83. return dateStr;
  84. }
  85. + (NSString *)getTimeStringFromTimeInterval:(NSInteger)timeInterval {
  86. NSDate *date = [[NSDate alloc]initWithTimeIntervalSince1970:timeInterval];
  87. NSDateFormatter *formatter = [[NSDateFormatter alloc]init];
  88. [formatter setDateFormat:@"yyyy/MM/dd HH:mm"];
  89. NSString *timeString = [formatter stringFromDate:date];
  90. return timeString;
  91. }
  92. + (NSDate *)getTimeStringToDate:(NSString *)timeStr{
  93. NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
  94. //需要设置为和字符串相同的格式
  95. [dateFormatter setDateFormat:@"YYYYMMddhhmmssSSS"];
  96. NSDate *localDate = [dateFormatter dateFromString:timeStr];
  97. return localDate;
  98. }
  99. + (NSString *)getPlayTimeStringFromTimeInterval:(NSTimeInterval)timeInterval {
  100. NSInteger seconds = timeInterval;
  101. //format of hour
  102. NSString *str_hour = [NSString stringWithFormat:@"%02ld",seconds/3600];
  103. //format of minut
  104. NSString *str_minute = [NSString stringWithFormat:@"%02ld",(seconds%3600)/60];
  105. //format of second
  106. NSString *str_second = [NSString stringWithFormat:@"%02ld",seconds%60];
  107. //format of time
  108. NSString *format_time = [NSString stringWithFormat:@"%@:%@:%@",str_hour,str_minute,str_second];
  109. return format_time;
  110. }
  111. /** 把字符串转时间戳Date YYYYMMddhhmmssSSS 2024-05-24 20:44:57 返回 x天 多少时 多少分*/
  112. + (NSString *)getTimeStringToExpirationDate:(NSString *)timeStr
  113. {
  114. NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
  115. //需要设置为和字符串相同的格式
  116. [dateFormatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"];;
  117. NSDate *localDate = [dateFormatter dateFromString:timeStr];
  118. NSTimeInterval ExpSecond = [localDate timeIntervalSince1970];
  119. NSTimeInterval curSecond = [[NSDate date] timeIntervalSince1970];
  120. NSTimeInterval curSecond2 = ExpSecond - curSecond;
  121. NSInteger validSecond = (NSInteger)curSecond2;
  122. NSInteger daySecond = 60*60*24;
  123. NSInteger hourSecond = 60*60;
  124. NSInteger minSecond = 60;
  125. if(validSecond >= daySecond){
  126. NSInteger day = validSecond/daySecond;
  127. // if(validSecond % daySecond >0){
  128. // day += 1;
  129. // }
  130. return [[NSString alloc] initWithFormat:@"%ld%@",day,NSLocalizedString(@"share_expiration_date_unit_day_tip",nil)];
  131. }
  132. else if(validSecond >= hourSecond){
  133. NSInteger day = validSecond/hourSecond;
  134. // if(validSecond % daySecond >0){
  135. // day += 1;
  136. // }
  137. return [[NSString alloc] initWithFormat:@"%ld%@",day,NSLocalizedString(@"share_expiration_date_unit_hour_tip",nil)];
  138. }
  139. else if(validSecond >= minSecond){
  140. NSInteger day = validSecond/minSecond;
  141. // if(validSecond % daySecond >0){
  142. // day += 1;
  143. // }
  144. return [[NSString alloc] initWithFormat:@"%ld%@",day,NSLocalizedString(@"share_expiration_date_unit_min_tip",nil)];
  145. }
  146. return [[NSString alloc] initWithFormat:@"1%@",NSLocalizedString(@"share_expiration_date_unit_min_tip",nil)];
  147. }
  148. //ypp add 通讯录文件名格式YmdHis+随机数字(1000~9999) 2020 07 07 15 08 25 1000
  149. + (NSString *)getContactsNameStr {
  150. NSString* date;
  151. NSDateFormatter * formatter = [[NSDateFormatter alloc ] init];
  152. [formatter setDateFormat:@"YYYYMMddhhmmss"];
  153. date = [formatter stringFromDate:[NSDate date]];
  154. int randomNumber = (int) arc4random_uniform(9999) + 1000;
  155. NSString *contactsNameStr = [NSString stringWithFormat:@"%@%d",date,randomNumber];
  156. return contactsNameStr;
  157. }
  158. + (UIImage*)createImageWithColor:(UIColor *)color
  159. {
  160. CGRect rect = CGRectMake(0.0f, 0.0f, 1.0f, 1.0f);
  161. UIGraphicsBeginImageContext(rect.size);
  162. CGContextRef context = UIGraphicsGetCurrentContext();
  163. CGContextSetFillColorWithColor(context, [color CGColor]);
  164. CGContextFillRect(context, rect);
  165. UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
  166. UIGraphicsEndImageContext();
  167. return image;
  168. }
  169. + (UIImage *)imageFromColor:(UIColor *)color view:(UIView *)view {
  170. CGRect rect = CGRectMake(0, 0, view.frame.size.width, view.frame.size.height);
  171. UIGraphicsBeginImageContext(rect.size);
  172. CGContextRef context = UIGraphicsGetCurrentContext();
  173. CGContextSetFillColorWithColor(context, [color CGColor]);
  174. CGContextFillRect(context, rect);
  175. UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
  176. UIGraphicsEndImageContext();
  177. return img;
  178. }
  179. + (UIImage *)getImageFromColor:(UIColor *)color rect:(CGRect)rect {
  180. UIGraphicsBeginImageContext(rect.size);
  181. CGContextRef context = UIGraphicsGetCurrentContext();
  182. CGContextSetFillColorWithColor(context, [color CGColor]);
  183. CGContextFillRect(context, rect);
  184. UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
  185. UIGraphicsEndImageContext();
  186. return img;
  187. }
  188. /**将UIColor变换为UIImage,设置尺寸**/
  189. + (UIImage *)createImageWithColor:(UIColor *)color withSize:(CGSize)size {
  190. CGRect rect = CGRectMake(0.0f, 0.0f, size.width, size.height);
  191. UIGraphicsBeginImageContextWithOptions(rect.size,NO,[UIScreen mainScreen].scale);
  192. CGContextRef context = UIGraphicsGetCurrentContext();
  193. CGContextSetFillColorWithColor(context, [color CGColor]);
  194. CGContextFillRect(context, rect);
  195. UIImage *theImage = UIGraphicsGetImageFromCurrentImageContext();
  196. UIGraphicsEndImageContext();
  197. return theImage;
  198. }
  199. /**将文件大小B 自动转成对应的B KB MB GB**/
  200. + (NSString *)getFileSizeStringFormedValue:(NSInteger)value
  201. {
  202. double convertedValue = value*1.0;
  203. int multiplyFactor = 0;
  204. NSArray *tokens = [NSArray arrayWithObjects:@"B",@"KB",@"MB",@"GB",@"TB",nil];
  205. while (convertedValue > 1024 && multiplyFactor < tokens.count) {
  206. convertedValue /= 1024;
  207. multiplyFactor++;
  208. }
  209. NSString *text = [NSString stringWithFormat:@"%4.2f%@",convertedValue, [tokens objectAtIndex:multiplyFactor]];
  210. if ([text isEqualToString:@"0.00B"]) {
  211. text = @"0B";
  212. }
  213. return text;
  214. }
  215. +(BOOL)getBoolWithKey:(NSString*)key{
  216. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  217. return [defaults boolForKey:key];
  218. }
  219. +(void)setBoolWithKey:(NSString*)key value:(BOOL)value{
  220. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  221. [defaults setBool:value forKey:key];
  222. [defaults synchronize];
  223. }
  224. +(NSString*)getStringWithKey:(NSString*)key{
  225. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  226. return [defaults stringForKey:key];
  227. }
  228. +(void)setStringWithKey:(NSString*)key value:(NSString*)value{
  229. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  230. [defaults setObject:value forKey:key];
  231. [defaults synchronize];
  232. }
  233. +(NSInteger)getIntegerWithKey:(NSString*)key{
  234. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  235. return [defaults integerForKey:key];
  236. }
  237. +(void)setIntegerWithKey:(NSString*)key value:(NSInteger)value{
  238. NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
  239. [defaults setInteger:value forKey:key];
  240. [defaults synchronize];
  241. }
  242. + (NSString *)notRounding:(float)price afterPoint:(int)position {
  243. NSDecimalNumberHandler *roundingBehavior = [NSDecimalNumberHandler decimalNumberHandlerWithRoundingMode:NSRoundDown scale:position raiseOnExactness:NO raiseOnOverflow:NO raiseOnUnderflow:NO raiseOnDivideByZero:NO];
  244. NSDecimalNumber *ouncesDecimal = [[NSDecimalNumber alloc] initWithFloat:price];
  245. NSDecimalNumber *roundedOunces = [ouncesDecimal decimalNumberByRoundingAccordingToBehavior:roundingBehavior];
  246. return [NSString stringWithFormat:@"%@%%",roundedOunces];
  247. }
  248. + (CGFloat)notRoundingFloat:(float)price afterPoint:(int)position {
  249. NSDecimalNumberHandler *roundingBehavior = [NSDecimalNumberHandler decimalNumberHandlerWithRoundingMode:NSRoundDown scale:position raiseOnExactness:NO raiseOnOverflow:NO raiseOnUnderflow:NO raiseOnDivideByZero:NO];
  250. NSDecimalNumber *ouncesDecimal = [[NSDecimalNumber alloc] initWithFloat:price];
  251. NSDecimalNumber *roundedOunces = [ouncesDecimal decimalNumberByRoundingAccordingToBehavior:roundingBehavior];
  252. return [roundedOunces floatValue];
  253. }
  254. + (NSString *)formatFloat:(float)f
  255. {
  256. if (fmodf(f, 1)==0) {//如果有一位小数点
  257. return [NSString stringWithFormat:@"%.0f",f];
  258. } else if (fmodf(f*10, 1)==0) {//如果有两位小数点
  259. return [NSString stringWithFormat:@"%.1f",f];
  260. } else {
  261. return [NSString stringWithFormat:@"%.2f",f];
  262. }
  263. }
  264. /**
  265. 获取运营商名称
  266. */
  267. + (NSString *)getCarrierInfo
  268. {
  269. CTTelephonyNetworkInfo *telephonyInfo = [[CTTelephonyNetworkInfo alloc] init];
  270. CTCarrier *carrier = nil;
  271. if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 12.1) {
  272. if ([telephonyInfo respondsToSelector:@selector(serviceSubscriberCellularProviders)]) {
  273. #pragma clang diagnostic push
  274. #pragma clang diagnostic ignored "-Wunguarded-availability-new"
  275. NSDictionary *dic = [telephonyInfo serviceSubscriberCellularProviders];
  276. if (dic.allKeys.count) {
  277. carrier = [dic objectForKey:dic.allKeys[0]];
  278. }
  279. #pragma clang diagnostic pop
  280. }
  281. }
  282. if(!carrier) {
  283. //遇到的 warning 又明知干不掉的时候就用这种方法隐藏即可,-Wdeprecated-declarations
  284. #pragma clang diagnostic push
  285. #pragma clang diagnostic ignored "-Wdeprecated-declarations"
  286. carrier = telephonyInfo.subscriberCellularProvider;
  287. #pragma clang diagnostic pop
  288. }
  289. //countryCode,移动国家码,MCC的资源由国际电联(ITU)统一分配和管理,唯一识别移动用户所属的国家,共3位,中国为460;
  290. NSString *countryCode = [carrier mobileCountryCode];
  291. //code,移动网络码,共2位,中国移动TD系统使用00,中国联通GSM系统使用01,中国移动GSM系统使用02,中国电信CDMA系统使用03,一个典型的IMSI号码为460030912121001
  292. NSString *code = [carrier mobileNetworkCode];
  293. //网络运营商的名字
  294. NSString *carrier_name = @"";
  295. //用户运营商网络 (中国电信:CHINANET,中国联通:UNICOM,中国移动:CMNET,中国铁通:CRTC,中国广电:GCABLENET)
  296. if ([countryCode isEqualToString:@"460"] && countryCode && code) {
  297. if ([code isEqualToString:@"00"] || [code isEqualToString:@"02"] || [code isEqualToString:@"04"] || [code isEqualToString:@"07"] || [code isEqualToString:@"08"]|| [code isEqualToString:@"13"]) {
  298. carrier_name = @"CMNET";
  299. }
  300. else if ([code isEqualToString:@"03"] || [code isEqualToString:@"05"] || [code isEqualToString:@"11"] || [code isEqualToString:@"12"])
  301. {
  302. carrier_name = @"CHINANET";
  303. }
  304. else if ([code isEqualToString:@"01"] || [code isEqualToString:@"06"] || [code isEqualToString:@"09"] || [code isEqualToString:@"10"])
  305. {
  306. carrier_name = @"UNICOM";
  307. }
  308. else if ([code isEqualToString:@"20"])
  309. {
  310. carrier_name = @"CRTC";
  311. }
  312. else if ([code isEqualToString:@"15"])
  313. {
  314. carrier_name = @"GCABLENET";
  315. }
  316. }
  317. return carrier_name;
  318. }
  319. // 去除字符串中所有的空格和换行符(包括中间和首尾)
  320. + (NSString *)removeSpaceAndNewline:(NSString *)str
  321. {
  322. NSString *temp = [str stringByReplacingOccurrencesOfString:@" " withString:@""];
  323. temp = [temp stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]; //去除掉首尾的空白字符和换行字符
  324. temp = [temp stringByReplacingOccurrencesOfString:@"\r" withString:@""];
  325. temp = [temp stringByReplacingOccurrencesOfString:@"\n" withString:@""];
  326. return temp;
  327. }
  328. #pragma mark 加密/解密(AES RSA base64 md5)
  329. // AES加密
  330. + (NSString *)AES128Encrypt:(NSString *)plainText key:(NSString *)key
  331. {
  332. char keyPtr[kCCKeySizeAES128+1];
  333. memset(keyPtr, 0, sizeof(keyPtr));
  334. [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
  335. NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];
  336. NSUInteger dataLength = [data length];
  337. size_t bufferSize = dataLength + kCCBlockSizeAES128;
  338. void *buffer = malloc(bufferSize);
  339. size_t numBytesEncrypted = 0;
  340. CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,
  341. kCCAlgorithmAES128,
  342. kCCOptionPKCS7Padding|kCCOptionECBMode,
  343. keyPtr,
  344. kCCBlockSizeAES128,
  345. NULL,
  346. [data bytes],
  347. dataLength,
  348. buffer,
  349. bufferSize,
  350. &numBytesEncrypted);
  351. if (cryptStatus == kCCSuccess) {
  352. NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
  353. return [resultData base64EncodedStringWithOptions:(NSDataBase64Encoding64CharacterLineLength)];
  354. }
  355. free(buffer);
  356. return nil;
  357. }
  358. //AES解密
  359. + (NSString *)AES128Decrypt:(NSString *)encryptText key:(NSString *)key
  360. {
  361. char keyPtr[kCCKeySizeAES128 + 1];
  362. memset(keyPtr, 0, sizeof(keyPtr));
  363. [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
  364. NSData *data = [[NSData alloc] initWithBase64EncodedString:encryptText options:NSDataBase64DecodingIgnoreUnknownCharacters];//base64解码
  365. NSUInteger dataLength = [data length];
  366. size_t bufferSize = dataLength + kCCBlockSizeAES128;
  367. void *buffer = malloc(bufferSize);
  368. size_t numBytesCrypted = 0;
  369. CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
  370. kCCAlgorithmAES128,
  371. kCCOptionPKCS7Padding|kCCOptionECBMode,
  372. keyPtr,
  373. kCCBlockSizeAES128,
  374. NULL,
  375. [data bytes],
  376. dataLength,
  377. buffer,
  378. bufferSize,
  379. &numBytesCrypted);
  380. if (cryptStatus == kCCSuccess) {
  381. NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];
  382. return [[NSString alloc] initWithData:resultData encoding:NSUTF8StringEncoding];
  383. }
  384. free(buffer);
  385. return nil;
  386. }
  387. /**RSA加密-publicKey-公钥*/
  388. + (NSString *)RSAEncrypt:(NSString *)plainText key:(NSString *)publicKey {
  389. NSString *encrypted = [RSA encryptString:plainText publicKey:publicKey];
  390. return encrypted;
  391. }
  392. /**RSA解密-privateKey-私钥*/
  393. + (NSString *)RSADecrypt:(NSString *)encryptText key:(NSString *)privateKey {
  394. NSString *decrypted = [RSA decryptString:encryptText privateKey:privateKey];
  395. return decrypted;
  396. }
  397. /**Base64加密*/
  398. + (NSString *)Base64Encrypt:(NSString *)plainText {
  399. NSData *data = [plainText dataUsingEncoding:NSUTF8StringEncoding];
  400. return [data base64EncodedStringWithOptions:0];
  401. }
  402. /**base64解密*/
  403. + (NSString *)Base64Decrypt:(NSString *)encryptText {
  404. NSData *data = [self dataWithBase64EncodedString:encryptText];
  405. return [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  406. }
  407. /**base64格式字符串转换为文本数据*/
  408. + (NSData *)dataWithBase64EncodedString:(NSString *)string
  409. {
  410. if (string == nil)
  411. [NSException raise:NSInvalidArgumentException format:@""];
  412. if ([string length] == 0)
  413. return [NSData data];
  414. static char *decodingTable = NULL;
  415. if (decodingTable == NULL)
  416. {
  417. decodingTable = malloc(256);
  418. if (decodingTable == NULL)
  419. return nil;
  420. memset(decodingTable, CHAR_MAX, 256);
  421. NSUInteger i;
  422. for (i = 0; i < 64; i++)
  423. decodingTable[(short)encodingTable[i]] = i;
  424. }
  425. const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
  426. if (characters == NULL) // Not an ASCII string!
  427. return nil;
  428. char *bytes = malloc((([string length] + 3) / 4) * 3);
  429. if (bytes == NULL)
  430. return nil;
  431. NSUInteger length = 0;
  432. NSUInteger i = 0;
  433. while (YES)
  434. {
  435. char buffer[4];
  436. short bufferLength;
  437. for (bufferLength = 0; bufferLength < 4; i++)
  438. {
  439. if (characters[i] == '\0')
  440. break;
  441. if (isspace(characters[i]) || characters[i] == '=')
  442. continue;
  443. buffer[bufferLength] = decodingTable[(short)characters[i]];
  444. if (buffer[bufferLength++] == CHAR_MAX) // Illegal character!
  445. {
  446. free(bytes);
  447. return nil;
  448. }
  449. }
  450. if (bufferLength == 0)
  451. break;
  452. if (bufferLength == 1) // At least two characters are needed to produce one byte!
  453. {
  454. free(bytes);
  455. return nil;
  456. }
  457. // Decode the characters in the buffer to bytes.
  458. bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
  459. if (bufferLength > 2)
  460. bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
  461. if (bufferLength > 3)
  462. bytes[length++] = (buffer[2] << 6) | buffer[3];
  463. }
  464. bytes = realloc(bytes, length);
  465. return [NSData dataWithBytesNoCopy:bytes length:length];
  466. }
  467. /**md5加密*/
  468. + (NSString *)md5Encrypt:(NSString *)encryptText{
  469. const char *cStr = [encryptText UTF8String];
  470. unsigned char result[CC_MD5_DIGEST_LENGTH];
  471. CC_MD5(cStr, strlen(cStr), result);
  472. return [[NSString stringWithFormat:@"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X",
  473. result[0], result[1], result[2], result[3],
  474. result[4], result[5], result[6], result[7],
  475. result[8], result[9], result[10], result[11],
  476. result[12], result[13], result[14], result[15]
  477. ] lowercaseString];
  478. }
  479. #pragma mark - RSA加密demo
  480. - (void)RSA {
  481. NSString *pubkey = @"-----BEGIN PUBLIC KEY-----\nMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDDI2bvVLVYrb4B0raZgFP60VXY\ncvRmk9q56QiTmEm9HXlSPq1zyhyPQHGti5FokYJMzNcKm0bwL1q6ioJuD4EFI56D\na+70XdRz1CjQPQE3yXrXXVvOsmq9LsdxTFWsVBTehdCmrapKZVVx6PKl7myh0cfX\nQmyveT/eqyZK1gYjvQIDAQAB\n-----END PUBLIC KEY-----";
  482. NSString *privkey = @"-----BEGIN PRIVATE KEY-----\nMIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAMMjZu9UtVitvgHS\ntpmAU/rRVdhy9GaT2rnpCJOYSb0deVI+rXPKHI9Aca2LkWiRgkzM1wqbRvAvWrqK\ngm4PgQUjnoNr7vRd1HPUKNA9ATfJetddW86yar0ux3FMVaxUFN6F0KatqkplVXHo\n8qXubKHRx9dCbK95P96rJkrWBiO9AgMBAAECgYBO1UKEdYg9pxMX0XSLVtiWf3Na\n2jX6Ksk2Sfp5BhDkIcAdhcy09nXLOZGzNqsrv30QYcCOPGTQK5FPwx0mMYVBRAdo\nOLYp7NzxW/File//169O3ZFpkZ7MF0I2oQcNGTpMCUpaY6xMmxqN22INgi8SHp3w\nVU+2bRMLDXEc/MOmAQJBAP+Sv6JdkrY+7WGuQN5O5PjsB15lOGcr4vcfz4vAQ/uy\nEGYZh6IO2Eu0lW6sw2x6uRg0c6hMiFEJcO89qlH/B10CQQDDdtGrzXWVG457vA27\nkpduDpM6BQWTX6wYV9zRlcYYMFHwAQkE0BTvIYde2il6DKGyzokgI6zQyhgtRJ1x\nL6fhAkB9NvvW4/uWeLw7CHHVuVersZBmqjb5LWJU62v3L2rfbT1lmIqAVr+YT9CK\n2fAhPPtkpYYo5d4/vd1sCY1iAQ4tAkEAm2yPrJzjMn2G/ry57rzRzKGqUChOFrGs\nlm7HF6CQtAs4HC+2jC0peDyg97th37rLmPLB9txnPl50ewpkZuwOAQJBAM/eJnFw\nF5QAcL4CYDbfBKocx82VX/pFXng50T7FODiWbbL4UnxICE0UBFInNNiWJxNEb6jL\n5xd0pcy9O2DOeso=\n-----END PRIVATE KEY-----";
  483. NSString *encrypted = [RSA encryptString:@"hello world!" publicKey:pubkey];
  484. HLog(@"encrypted: %@", encrypted);
  485. NSString *decrypted = [RSA decryptString:encrypted privateKey:privkey];
  486. HLog(@"decrypted: %@", decrypted);
  487. }
  488. //防止N秒内,同部同接口频繁调用的处理
  489. + (BOOL)timeOverTosecode:(NSInteger)index bannerOldTime:(NSString *)bannerOldTime;
  490. {
  491. BOOL reFreshDevice_flag = YES;
  492. NSString *nowTime = [iTools getNowTimeStampString];
  493. NSString *oldTime = nil;
  494. if (![bannerOldTime isEqual:@""]) {
  495. oldTime = bannerOldTime;
  496. }
  497. //比较
  498. if ([oldTime length] > 0) {
  499. //时间差
  500. NSDate *dateNow = [iTools getTimeStringToDate:nowTime];
  501. NSDate *dateOld = [iTools getTimeStringToDate:oldTime];
  502. NSTimeInterval distanceBetweenDates = [dateNow timeIntervalSinceDate:dateOld];
  503. long long min = [[NSNumber numberWithDouble:distanceBetweenDates] longLongValue];
  504. if (min < index)
  505. {
  506. reFreshDevice_flag = NO;
  507. }else{
  508. reFreshDevice_flag = YES;
  509. }
  510. }
  511. return reFreshDevice_flag;
  512. }
  513. //获取拼音首字母(传入汉字字符串, 返回大写拼音首字母)
  514. + (NSString *)FirstCharactor:(NSString *)pString
  515. {
  516. //转成了可变字符串
  517. NSMutableString *pStr = [NSMutableString stringWithString:pString];
  518. //先转换为带声调的拼音
  519. CFStringTransform((CFMutableStringRef)pStr,NULL, kCFStringTransformMandarinLatin,NO);
  520. //再转换为不带声调的拼音
  521. CFStringTransform((CFMutableStringRef)pStr,NULL, kCFStringTransformStripDiacritics,NO);
  522. //转化为大写拼音
  523. NSString *pPinYin = [pStr capitalizedString];
  524. //获取并返回首字母
  525. return [pPinYin substringToIndex:1];
  526. }
  527. //根据uiview得到图像
  528. + (UIImage *)getImageFromView:(UIView *)fromView useScreenScale:(BOOL)use useNewMethod:(BOOL)useNewMethod
  529. {
  530. UIImage *viewImage = nil;
  531. if (([[[UIDevice currentDevice] systemVersion] doubleValue] > 7) && useNewMethod) {
  532. UIGraphicsBeginImageContextWithOptions(fromView.bounds.size, NO, [[UIScreen mainScreen] scale]);
  533. [fromView drawViewHierarchyInRect:fromView.bounds afterScreenUpdates:NO];
  534. viewImage = UIGraphicsGetImageFromCurrentImageContext();
  535. UIGraphicsEndImageContext();
  536. } else {
  537. NSInteger scale = use ? [[UIScreen mainScreen] scale] : 1;
  538. UIGraphicsBeginImageContextWithOptions(CGSizeMake(fromView.bounds.size.width, fromView.bounds.size.height), NO, scale);
  539. [fromView.layer renderInContext:UIGraphicsGetCurrentContext()];
  540. viewImage = UIGraphicsGetImageFromCurrentImageContext();
  541. UIGraphicsEndImageContext();
  542. }
  543. return viewImage;
  544. }
  545. //验证身份证
  546. //必须满足以下规则
  547. //1. 长度必须是18位,前17位必须是数字,第十八位可以是数字或X
  548. //2. 前两位必须是以下情形中的一种:11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,82,91
  549. //3. 第7到第14位出生年月日。第7到第10位为出生年份;11到12位表示月份,范围为01-12;13到14位为合法的日期
  550. //4. 第17位表示性别,双数表示女,单数表示男
  551. //5. 第18位为前17位的校验位
  552. //算法如下:
  553. //(1)校验和 = (n1 + n11) * 7 + (n2 + n12) * 9 + (n3 + n13) * 10 + (n4 + n14) * 5 + (n5 + n15) * 8 + (n6 + n16) * 4 + (n7 + n17) * 2 + n8 + n9 * 6 + n10 * 3,其中n数值,表示第几位的数字
  554. //(2)余数 = 校验和 % 11
  555. //(3)如果余数为0,校验位应为1,余数为1到10校验位应为字符串“0X98765432”(不包括分号)的第余数位的值(比如余数等于3,校验位应为9)
  556. //6. 出生年份的前两位必须是19或20
  557. + (BOOL)verifyIDCardNumber:(NSString *)value
  558. {
  559. value = [value stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
  560. if ([value length] != 18) {
  561. return NO;
  562. }
  563. NSString *mmdd = @"(((0[13578]|1[02])(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)(0[1-9]|[12][0-9]|30))|(02(0[1-9]|[1][0-9]|2[0-8])))";
  564. NSString *leapMmdd = @"0229";
  565. NSString *year = @"(19|20)[0-9]{2}";
  566. NSString *leapYear = @"(19|20)(0[48]|[2468][048]|[13579][26])";
  567. NSString *yearMmdd = [NSString stringWithFormat:@"%@%@", year, mmdd];
  568. NSString *leapyearMmdd = [NSString stringWithFormat:@"%@%@", leapYear, leapMmdd];
  569. NSString *yyyyMmdd = [NSString stringWithFormat:@"((%@)|(%@)|(%@))", yearMmdd, leapyearMmdd, @"20000229"];
  570. NSString *area = @"(1[1-5]|2[1-3]|3[1-7]|4[1-6]|5[0-4]|6[1-5]|82|[7-9]1)[0-9]{4}";
  571. NSString *regex = [NSString stringWithFormat:@"%@%@%@", area, yyyyMmdd , @"[0-9]{3}[0-9Xx]"];
  572. NSPredicate *regexTest = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
  573. if (![regexTest evaluateWithObject:value]) {
  574. return NO;
  575. }
  576. int summary = ([value substringWithRange:NSMakeRange(0,1)].intValue + [value substringWithRange:NSMakeRange(10,1)].intValue) *7
  577. + ([value substringWithRange:NSMakeRange(1,1)].intValue + [value substringWithRange:NSMakeRange(11,1)].intValue) *9
  578. + ([value substringWithRange:NSMakeRange(2,1)].intValue + [value substringWithRange:NSMakeRange(12,1)].intValue) *10
  579. + ([value substringWithRange:NSMakeRange(3,1)].intValue + [value substringWithRange:NSMakeRange(13,1)].intValue) *5
  580. + ([value substringWithRange:NSMakeRange(4,1)].intValue + [value substringWithRange:NSMakeRange(14,1)].intValue) *8
  581. + ([value substringWithRange:NSMakeRange(5,1)].intValue + [value substringWithRange:NSMakeRange(15,1)].intValue) *4
  582. + ([value substringWithRange:NSMakeRange(6,1)].intValue + [value substringWithRange:NSMakeRange(16,1)].intValue) *2
  583. + [value substringWithRange:NSMakeRange(7,1)].intValue *1 + [value substringWithRange:NSMakeRange(8,1)].intValue *6
  584. + [value substringWithRange:NSMakeRange(9,1)].intValue *3;
  585. NSInteger remainder = summary % 11;
  586. NSString *checkBit = @"";
  587. NSString *checkString = @"10X98765432";
  588. checkBit = [checkString substringWithRange:NSMakeRange(remainder,1)];// 判断校验位
  589. return [checkBit isEqualToString:[[value substringWithRange:NSMakeRange(17,1)] uppercaseString]];
  590. }
  591. #pragma mark --------------------
  592. #pragma mark - Localizable
  593. /**< 得到当前系统的语言 */
  594. + (NSString *)getCurrentLocalizableLanguage {
  595. NSArray *languages = [NSLocale preferredLanguages];
  596. NSString *currentLanguage = [languages objectAtIndex:0];
  597. return currentLanguage;
  598. }
  599. /**< 得到当前语言是否为中文 */
  600. + (BOOL)isChineseLanguage {
  601. NSString *currentLanguage = [self getCurrentLocalizableLanguage];
  602. if ([currentLanguage rangeOfString:@"^zh-" options:NSRegularExpressionSearch range:NSMakeRange(0, currentLanguage.length)].location != NSNotFound) {
  603. return YES;
  604. }
  605. return NO;
  606. }
  607. #define FileHashDefaultChunkSizeForReadingData 1024*8
  608. + (NSString*)getFileMD5WithPath:(NSString*)path {
  609. NSFileManager *fileManager = [NSFileManager defaultManager];
  610. if([fileManager fileExistsAtPath:path isDirectory:nil])
  611. {
  612. NSData *data = [NSData dataWithContentsOfFile:path];
  613. unsigned char digest[CC_MD5_DIGEST_LENGTH];
  614. CC_MD5( data.bytes, (CC_LONG)data.length, digest );
  615. NSMutableString *output = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
  616. for( int i = 0; i < CC_MD5_DIGEST_LENGTH; i++ )
  617. {
  618. [output appendFormat:@"%02x", digest[i]];
  619. }
  620. return output;
  621. }
  622. else
  623. {
  624. return @"";
  625. }
  626. }
  627. + (CAShapeLayer *)getCornerRoundWithSelfView:(UIView *)originalView byRoundingCorners:(UIRectCorner)corners cornerRect:(CGRect)rect {
  628. UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:rect byRoundingCorners:corners cornerRadii:CGSizeMake(10, 10)];
  629. CAShapeLayer *maskLayer = [[CAShapeLayer alloc] init];
  630. maskLayer.frame = originalView.bounds;
  631. maskLayer.path = maskPath.CGPath;
  632. return maskLayer;
  633. }
  634. // 彩色图变黑白图
  635. + (UIImage*)getGrayImageFromImage:(UIImage*)sourceImage {
  636. int width = sourceImage.size.width-2;
  637. int height = sourceImage.size.height;
  638. CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceGray();
  639. CGContextRef context = CGBitmapContextCreate (nil, width, height,8,0, colorSpace,kCGImageAlphaNone);
  640. CGColorSpaceRelease(colorSpace);
  641. if (context ==NULL) {
  642. return nil;
  643. }
  644. CGContextDrawImage(context,CGRectMake(0,0, width, height), sourceImage.CGImage);
  645. UIImage *grayImage = [UIImage imageWithCGImage:CGBitmapContextCreateImage(context)];
  646. CGContextRelease(context);
  647. return grayImage;
  648. }
  649. // 显示base64二进制图片
  650. + (void)setImageView:(UIImageView *)imageView WithBase64String:(NSString *)avatar {
  651. //参数在这里 + (void) setImageView:(UIImageView *)imageView WithString:(NSString *)avatar
  652. //二进制显示
  653. /*服务器返回:例如
  654. data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAIAAACRXR/mAAAABnRSTlMAAAAAAABupgeRAAAAhElEQVRYhe3Y0QmAIBhF4YwGaZRGaNRGaJRGaYEyTj/RfTjnVYQPBRXbuh9DXuPfgOtkkWSRZJFkkUJZU3H+tsx3Q5VrLXS1ZJFkkWSRZJFkkWSRZJFkkUJZLfPH5vktX3mtv54buomySLJIskihrNBTvvWHP0V37oDQTZRFkkWSRQplnQDfEjVVBe3tAAAAAElFTkSuQmCC
  655. *上面的字符串复制到浏览器是可以显示出来一个图片的,这里说一下,字符串前面的data:image/png;base64是这个图片的格式,
  656. * web上面 解析好像是需要这部分的,但是拿到我们的iOS平台上,是不需要这部分的,有这部分反而解析不出来图片。
  657. * 所以这里可以说这部分属于格式部分,so我们显示的时候不要这部分。
  658. */
  659. NSArray *imageArray = [avatar componentsSeparatedByString:@","];
  660. NSData *imageData = [[NSData alloc] initWithBase64EncodedString:imageArray[1] options:NSDataBase64DecodingIgnoreUnknownCharacters];
  661. UIImage *image = [UIImage imageWithData:imageData];
  662. imageView.image = [iTools cutAlphaZero:image];
  663. }
  664. // iOS裁剪掉图片周围透明度为0的部分
  665. + (UIImage *)cutAlphaZero:(UIImage *)image {
  666. CGImageRef cgimage = [image CGImage];
  667. size_t width = CGImageGetWidth(cgimage); // 图片宽度
  668. size_t height = CGImageGetHeight(cgimage); // 图片高度
  669. unsigned char *data = calloc(width * height * 4, sizeof(unsigned char)); // 取图片首地址
  670. size_t bitsPerComponent = 8; // r g b a 每个component bits数目
  671. size_t bytesPerRow = width * 4; // 一张图片每行字节数目 (每个像素点包含r g b a 四个字节)
  672. CGColorSpaceRef space = CGColorSpaceCreateDeviceRGB(); // 创建rgb颜色空间
  673. CGContextRef context = CGBitmapContextCreate(data, width,height,bitsPerComponent,bytesPerRow,space,kCGImageAlphaPremultipliedLast | kCGBitmapByteOrder32Big);
  674. CGContextDrawImage(context, CGRectMake(0, 0, width, height), cgimage);
  675. int top = 0; // 上边框透明高度
  676. int left = 0; // 左边框透明高度
  677. int right = 0; // 右边框透明高度
  678. int bottom = 0; // 底边框透明高度
  679. for (size_t row = 0; row < height; row++) {
  680. BOOL find = false;
  681. for (size_t col = 0; col < width; col++) {
  682. size_t pixelIndex = (row * width + col) * 4;
  683. // int red = data[pixelIndex];
  684. // int green = data[pixelIndex+1];
  685. // int blue = data[pixelIndex + 2];
  686. int alpha = data[pixelIndex + 3];
  687. if (alpha != 0) {
  688. find = YES;
  689. break;
  690. }
  691. }
  692. if (find) {
  693. break;
  694. }
  695. top ++;
  696. }
  697. for (size_t col = 0; col < width; col++) {
  698. BOOL find = false;
  699. for (size_t row = 0; row < height; row++) {
  700. size_t pixelIndex = (row * width + col) * 4;
  701. int alpha = data[pixelIndex + 3];
  702. if (alpha != 0) {
  703. find = YES;
  704. break;
  705. }
  706. }
  707. if (find) {
  708. break;
  709. }
  710. left ++;
  711. }
  712. for (size_t col = width - 1; col > 0; col--) {
  713. BOOL find = false;
  714. for (size_t row = 0; row < height; row++) {
  715. size_t pixelIndex = (row * width + col) * 4;
  716. int alpha = data[pixelIndex + 3];
  717. if (alpha != 0) {
  718. find = YES;
  719. break;
  720. }
  721. }
  722. if (find) {
  723. break;
  724. }
  725. right ++;
  726. }
  727. for (size_t row = height - 1; row > 0; row--) {
  728. BOOL find = false;
  729. for (size_t col = 0; col < width; col++) {
  730. size_t pixelIndex = (row * width + col) * 4;
  731. int alpha = data[pixelIndex + 3];
  732. if (alpha != 0) {
  733. find = YES;
  734. break;
  735. }
  736. }
  737. if (find) {
  738. break;
  739. }
  740. bottom ++;
  741. }
  742. CGFloat scale = image.scale;
  743. CGImageRef newImageRef = CGImageCreateWithImageInRect(cgimage, CGRectMake(left * scale, top *scale, (image.size.width - left - right)*scale, (image.size.height - top - bottom)*scale));
  744. UIImage *newImage = [UIImage imageWithCGImage:newImageRef];
  745. // 释放
  746. CGImageRelease(cgimage);
  747. CGContextRelease(context);
  748. CGColorSpaceRelease(space);
  749. return newImage;
  750. }
  751. + (UIWindow *)getKeyWindow {
  752. UIWindow* window = nil;
  753. if (@available(iOS 13.0, *))
  754. {
  755. for (UIWindowScene* windowScene in [UIApplication sharedApplication].connectedScenes)
  756. {
  757. if (windowScene.activationState == UISceneActivationStateForegroundActive)
  758. {
  759. window = windowScene.windows.firstObject;
  760. break;
  761. }
  762. }
  763. }else{
  764. window = [UIApplication sharedApplication].keyWindow;
  765. }
  766. return window;
  767. }
  768. //调整相机拍摄的图片方向
  769. + (UIImage *)fixOrientation:(UIImage *)srcImg {
  770. if (srcImg.imageOrientation ==UIImageOrientationUp) return srcImg;
  771. CGAffineTransform transform =CGAffineTransformIdentity;
  772. switch (srcImg.imageOrientation) {
  773. case UIImageOrientationDown:
  774. case UIImageOrientationDownMirrored:
  775. transform = CGAffineTransformTranslate(transform, srcImg.size.width, srcImg.size.height);
  776. transform = CGAffineTransformRotate(transform,M_PI);
  777. break;
  778. case UIImageOrientationLeft:
  779. case UIImageOrientationLeftMirrored:
  780. transform = CGAffineTransformTranslate(transform, srcImg.size.width,0);
  781. transform = CGAffineTransformRotate(transform,M_PI_2);
  782. break;
  783. case UIImageOrientationRight:
  784. case UIImageOrientationRightMirrored:
  785. transform = CGAffineTransformTranslate(transform,0, srcImg.size.height);
  786. transform = CGAffineTransformRotate(transform, -M_PI_2);
  787. break;
  788. case UIImageOrientationUp:
  789. case UIImageOrientationUpMirrored:
  790. break;
  791. }
  792. switch (srcImg.imageOrientation) {
  793. case UIImageOrientationUpMirrored:
  794. case UIImageOrientationDownMirrored:
  795. transform = CGAffineTransformTranslate(transform, srcImg.size.width,0);
  796. transform = CGAffineTransformScale(transform, -1,1);
  797. break;
  798. case UIImageOrientationLeftMirrored:
  799. case UIImageOrientationRightMirrored:
  800. transform = CGAffineTransformTranslate(transform, srcImg.size.height,0);
  801. transform = CGAffineTransformScale(transform, -1,1);
  802. break;
  803. case UIImageOrientationUp:
  804. case UIImageOrientationDown:
  805. case UIImageOrientationLeft:
  806. case UIImageOrientationRight:
  807. break;
  808. }
  809. CGContextRef ctx =CGBitmapContextCreate(NULL, srcImg.size.width, srcImg.size.height,
  810. CGImageGetBitsPerComponent(srcImg.CGImage),0,
  811. CGImageGetColorSpace(srcImg.CGImage),
  812. CGImageGetBitmapInfo(srcImg.CGImage));
  813. CGContextConcatCTM(ctx, transform);
  814. switch (srcImg.imageOrientation) {
  815. case UIImageOrientationLeft:
  816. case UIImageOrientationLeftMirrored:
  817. case UIImageOrientationRight:
  818. case UIImageOrientationRightMirrored:
  819. CGContextDrawImage(ctx,CGRectMake(0,0,srcImg.size.height,srcImg.size.width), srcImg.CGImage);
  820. break;
  821. default:
  822. CGContextDrawImage(ctx,CGRectMake(0,0,srcImg.size.width,srcImg.size.height), srcImg.CGImage);
  823. break;
  824. }
  825. CGImageRef cgimg = CGBitmapContextCreateImage(ctx);
  826. UIImage *img = [UIImage imageWithCGImage:cgimg];
  827. CGContextRelease(ctx);
  828. CGImageRelease(cgimg);
  829. return img;
  830. }
  831. + (NSString *)getTaskUidStr
  832. {
  833. NSInteger num = 6;
  834. NSString *string = [[NSString alloc]init];
  835. for (int i = 0; i < num; i++) {
  836. int number = arc4random() % 36;
  837. if (number < 10) {
  838. int figure = arc4random() % 10;
  839. NSString *tempString = [NSString stringWithFormat:@"%d", figure];
  840. string = [string stringByAppendingString:tempString];
  841. }else {
  842. int figure = (arc4random() % 26) + 97;
  843. char character = figure;
  844. NSString *tempString = [NSString stringWithFormat:@"%c", character];
  845. string = [string stringByAppendingString:tempString];
  846. }
  847. }
  848. return string;
  849. }
  850. + (void)lc_setAlternateIconName:(NSString*)iconName
  851. {
  852. //超级签换不了图片 旧版本升级会有问题 不要了
  853. //anti apple private method call analyse
  854. // if ([[UIApplication sharedApplication] respondsToSelector:@selector(supportsAlternateIcons)] &&
  855. // [[UIApplication sharedApplication] supportsAlternateIcons])
  856. // {
  857. // NSMutableString *selectorString = [[NSMutableString alloc] initWithCapacity:40];
  858. // [selectorString appendString:@"_setAlternate"];
  859. // [selectorString appendString:@"IconName:"];
  860. // [selectorString appendString:@"completionHandler:"];
  861. //
  862. // SEL selector = NSSelectorFromString(selectorString);
  863. // IMP imp = [[UIApplication sharedApplication] methodForSelector:selector];
  864. // void (*func)(id, SEL, id, id) = (void *)imp;
  865. // if (func)
  866. // {
  867. // func([UIApplication sharedApplication], selector, iconName, ^(NSError * _Nullable error) {});
  868. // }
  869. // }
  870. }
  871. + (UIViewController *)appRootViewController {
  872. UIViewController *appRootVC = [iTools getKeyWindow].rootViewController;
  873. UIViewController *topVC = appRootVC;
  874. while (topVC.presentedViewController) {
  875. topVC = topVC.presentedViewController;
  876. }
  877. return topVC;
  878. }
  879. /**
  880. * 压缩图片
  881. * image:将要压缩的图片 size:压缩后的尺寸
  882. */
  883. + (UIImage*)OriginImage:(UIImage *)image scaleToSize:(CGSize)size
  884. {
  885. // 下面方法,第一个参数表示区域大小。第二个参数表示是否是非透明的。如果需要显示半透明效果,需要传NO,否则传YES。第三个参数就是屏幕密度了
  886. //UIGraphicsBeginImageContextWithOptions(size, NO, [UIScreen mainScreen].scale);
  887. UIGraphicsBeginImageContext(CGSizeMake(size.width, size.height));
  888. [image drawInRect:CGRectMake(0, 0, size.width, size.height)];
  889. UIImage* scaledImage = UIGraphicsGetImageFromCurrentImageContext();
  890. UIGraphicsEndImageContext();
  891. return scaledImage; //返回的就是已经改变的图片
  892. }
  893. // 时间戳转时间,时间戳为13位是精确到毫秒的,10位精确到秒
  894. + (NSString *)getDateStringWithTimeStr:(NSString* )str{
  895. NSTimeInterval time= [str doubleValue];//传入的时间戳str如果是精确到毫秒的记得要/1000
  896. if(str.length == 13){//传入的时间戳str如果是精确到毫秒的记得要/1000
  897. time = time/1000;
  898. }
  899. NSDate *detailDate=[NSDate dateWithTimeIntervalSince1970:time];
  900. NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init]; //实例化一个NSDateFormatter对象
  901. //设定时间格式,这里可以设置成自己需要的格式
  902. //[dateFormatter setDateFormat:@"yyyy-MM-dd HH:mm:ss SS"];
  903. [dateFormatter setDateFormat:@"yyyy-MM-dd"];
  904. NSString *currentDateStr = [dateFormatter stringFromDate: detailDate];
  905. return currentDateStr;
  906. }
  907. // 文件夹大小(字节)
  908. + (unsigned long long)folderSizeAtPath:(NSString *)folderPath{
  909. NSFileManager *manager = [NSFileManager defaultManager];
  910. if (![manager fileExistsAtPath:folderPath]) return 0;
  911. NSEnumerator *childFilesEnumerator = [[manager subpathsAtPath:folderPath] objectEnumerator];
  912. NSString *fileName;
  913. long long folderSize = 0;
  914. while ((fileName = [childFilesEnumerator nextObject]) != nil){
  915. NSString *fileAbsolutePath = [folderPath stringByAppendingPathComponent:fileName];
  916. folderSize += [self fileSizeAtPath:fileAbsolutePath];
  917. }
  918. return folderSize;
  919. }
  920. //单个文件的大小(字节)
  921. +(unsigned long long)fileSizeAtPath:(NSString *)filePath {
  922. NSFileManager *manager = [NSFileManager defaultManager];
  923. if ([manager fileExistsAtPath:filePath]){
  924. return [[manager attributesOfItemAtPath:filePath error:nil] fileSize];
  925. }
  926. return 0;
  927. }
  928. + (NSArray *)toArrayWithJsonStr:(NSString *)jsonStr
  929. {
  930. if ([jsonStr isKindOfClass:[NSArray class]]) {
  931. return (NSArray *)jsonStr;
  932. }
  933. if (jsonStr == nil) {
  934. return nil;
  935. }
  936. NSData *jsonData = [jsonStr dataUsingEncoding:NSUTF8StringEncoding];
  937. NSError *err;
  938. NSArray *resultArr = [NSJSONSerialization JSONObjectWithData:jsonData
  939. options:NSJSONReadingMutableContainers
  940. error:&err];
  941. if(err) {
  942. NSLog(@"json解析失败:%@",err);
  943. return nil;
  944. }
  945. return resultArr;
  946. }
  947. + (NSString *)toJsonStrWithArray:(NSArray *)arr {
  948. if ([arr isKindOfClass:[NSString class]]) {
  949. return (NSString *)arr;
  950. }
  951. NSError *parseError = nil;
  952. NSData *data = [NSJSONSerialization dataWithJSONObject:arr options:NSJSONWritingPrettyPrinted error:nil];
  953. NSString *jsonStr = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  954. jsonStr = [jsonStr stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
  955. jsonStr = [jsonStr stringByReplacingOccurrencesOfString:@" " withString:@""];
  956. jsonStr = [jsonStr stringByReplacingOccurrencesOfString:@"\n" withString:@""];
  957. if (parseError) {
  958. jsonStr = @"";
  959. }
  960. return jsonStr;
  961. }
  962. //ios端:
  963. //1、需求说明:解决除MP4 MOV 3GP M4V 总计4种格式外,其他格式下载失败的问题;
  964. //2、交互说明:下载列表勾选文件中含有其他格式,toast提示“IOS系统仅支持MP4、MOV、3GP、M4V 的视频格式,其他格式无法下载”。点击下载按钮,过滤其他格式文件,仅下载MP4、MOV、3GP、M4V 的视频格式文件;
  965. //ios支持图片格式: (SVG 不支持)
  966. //需求说明:解决除JPG PNG GIF TIFF BMP总计5种格式外,其他格式下载失败的问题
  967. //视觉交互:选择文件中含有其他格式,toast提示“IOS系统仅支持JPG 、PNG、GIF、TIFF、BMP的图片格式,其他格式无法下载”。点击下载按钮,过滤其他格式文件,仅下载JPG 、PNG、GIF、TIFF、BMP的图片格式文件;
  968. + (BOOL)canSaveFileToAlbumByPhoto:(BOOL)isPhotoType withName:(NSString*)nameStr{
  969. NSString*name = [nameStr lowercaseString];
  970. NSArray *nameArr = [name componentsSeparatedByString:@"."];
  971. if(nameArr.count >0 && !isPhotoType){
  972. BOOL canSavePhotoType = NO;
  973. NSString *lastName = nameArr.lastObject;
  974. if([lastName isEqualToString:@"mp4"]
  975. ||[lastName isEqualToString:@"mov"]
  976. ||[lastName isEqualToString:@"3gp"]
  977. ||[lastName isEqualToString:@"m4v"]){
  978. canSavePhotoType = YES;
  979. }
  980. return canSavePhotoType;
  981. }
  982. if(nameArr.count >0 && isPhotoType){
  983. BOOL canSavePhotoType = NO;
  984. //JPG 、PNG、GIF、TIFF、BMP
  985. NSString *lastName = nameArr.lastObject;
  986. if([lastName isEqualToString:@"jpg"]
  987. ||[lastName isEqualToString:@"png"]
  988. ||[lastName isEqualToString:@"gif"]
  989. ||[lastName isEqualToString:@"tiff"]
  990. ||[lastName isEqualToString:@"bmp"]
  991. ||[lastName isEqualToString:@"heic"]
  992. ||[lastName isEqualToString:@"jpeg"]
  993. ||[lastName isEqualToString:@"heif"]){
  994. canSavePhotoType = YES;
  995. }
  996. return canSavePhotoType;
  997. }
  998. return NO;
  999. }
  1000. //判断是否为音频文件
  1001. + (BOOL)isAudioFilewithName:(NSString*)nameStr
  1002. {
  1003. NSString*name = [nameStr lowercaseString];
  1004. NSArray *nameArr = [name componentsSeparatedByString:@"."];
  1005. if(nameArr.count >0 ){
  1006. //JPG 、PNG、GIF、TIFF、BMP
  1007. NSString *lastName = nameArr.lastObject;
  1008. if([lastName isEqualToString:@"mp3"]
  1009. ||[lastName isEqualToString:@"wav"]
  1010. ||[lastName isEqualToString:@"flac"]
  1011. ||[lastName isEqualToString:@"ogg"]
  1012. ||[lastName isEqualToString:@"wma"]
  1013. ||[lastName isEqualToString:@"m4a"]
  1014. ||[lastName isEqualToString:@"acc"]
  1015. ||[lastName isEqualToString:@"ac3"]){
  1016. return YES;
  1017. }
  1018. }
  1019. return NO;
  1020. }
  1021. //判断是否为视频文件
  1022. + (BOOL)isVideoFilewithName:(NSString*)nameStr
  1023. {
  1024. NSString*name = [nameStr lowercaseString];
  1025. NSArray *nameArr = [name componentsSeparatedByString:@"."];
  1026. if(nameArr.count >0 ){
  1027. //JPG 、PNG、GIF、TIFF、BMP
  1028. NSString *lastName = nameArr.lastObject;
  1029. if([lastName isEqualToString:@"mp4"]
  1030. ||[lastName isEqualToString:@"mov"]
  1031. ||[lastName isEqualToString:@"3gp"]
  1032. ||[lastName isEqualToString:@"m4v"]
  1033. ||[lastName isEqualToString:@"avi"]
  1034. ||[lastName isEqualToString:@"flv"]
  1035. ||[lastName isEqualToString:@"wmv"]
  1036. ||[lastName isEqualToString:@"mkv"]
  1037. ||[lastName isEqualToString:@"wkm"]
  1038. ||[lastName isEqualToString:@"ts"]
  1039. ||[lastName isEqualToString:@"rmvb"]){
  1040. return YES;
  1041. }
  1042. }
  1043. return NO;
  1044. }
  1045. //判断是否为相片文件
  1046. + (BOOL)isPhotoFilewithName:(NSString*)nameStr
  1047. {
  1048. NSString*name = [nameStr lowercaseString];
  1049. NSArray *nameArr = [name componentsSeparatedByString:@"."];
  1050. if(nameArr.count >0 ){
  1051. //JPG 、PNG、GIF、TIFF、BMP
  1052. NSString *lastName = nameArr.lastObject;
  1053. if([lastName isEqualToString:@"jpg"]
  1054. ||[lastName isEqualToString:@"png"]
  1055. ||[lastName isEqualToString:@"gif"]
  1056. ||[lastName isEqualToString:@"tiff"]
  1057. ||[lastName isEqualToString:@"bmp"]
  1058. ||[lastName isEqualToString:@"heic"]
  1059. ||[lastName isEqualToString:@"jpeg"]
  1060. ||[lastName isEqualToString:@"heif"]){
  1061. return YES;
  1062. }
  1063. }
  1064. return NO;
  1065. }
  1066. @end