iOS开发检测是否开启定位、是否允许消息推送等权限
1.iOS开发检测是否开启定位:
需要导入:
#import <CoreLocation/CoreLocation.h>
代码如下:
+ (void)openLocationServiceWithBlock:(ReturnBlock)returnBlock
{
BOOL isOPen = NO;
if ([CLLocationManager locationServicesEnabled] && [CLLocationManager authorizationStatus] != kCLAuthorizationStatusDenied) {
isOPen = YES;
}
if (returnBlock) {
returnBlock(isOpen);
}
}
2.iOS开发检测是否允许消息推送:
需要导入:
#import <UserNotifications/UserNotifications.h>
代码如下:
+ (void)openMessageNotificationServiceWithBlock:(ReturnBlock)returnBlock
{
BOOL isOpen = NO;
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
UIUserNotificationSettings *setting = [[UIApplication sharedApplication] currentUserNotificationSettings];
if (setting.types != UIUserNotificationTypeNone) {
isOpen = YES;
}
#else
UIRemoteNotificationType type = [[UIApplication sharedApplication] enabledRemoteNotificationTypes];
if (type != UIRemoteNotificationTypeNone) {
isOpen = YES;
}
#endif
if (returnBlock) {
returnBlock(isOpen);
}
}
+ (void)openMessageNotificationServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
[[UNUserNotificationCenter currentNotificationCenter] getNotificationSettingsWithCompletionHandler:^(UNNotificationSettings *settings) {
if (returnBlock) {
returnBlock(settings.authorizationStatus == UNAuthorizationStatusAuthorized);
}
}];
#elif __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
returnBlock([[UIApplication sharedApplication] isRegisteredForRemoteNotifications]);
#else
UIRemoteNotificationType type = [[UIApplication sharedApplication] enabledRemoteNotificationTypes];
if (returnBlock) {
returnBlock(type != UIRemoteNotificationTypeNone);
}
#endif
}
3.iOS开发检测是否开启摄像头:
需要导入:
#import <AVFoundation/AVFoundation.h>
代码如下:
+ (void)openCaptureDeviceServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_7_0
AVAuthorizationStatus authStatus = [AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeVideo];
if (authStatus == AVAuthorizationStatusNotDetermined) {
[AVCaptureDevice requestAccessForMediaType:AVMediaTypeVideo completionHandler:^(BOOL granted) {
if (returnBlock) {
returnBlock(granted);
}
}];
return NO;
} else if (authStatus == AVAuthorizationStatusRestricted || authStatus == AVAuthorizationStatusDenied) {
returnBlock(NO);
} else {
returnBlock(YES);
}
#endif
}
4.iOS开发检测是否开启相册:
需要导入:
#import <Photos/Photos.h>#import <AssetsLibrary/AssetsLibrary.h>
代码如下:
+ (void)openAlbumServiceWithBlock:(ReturnBlock)returnBlock
{
BOOL isOpen;
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
PHAuthorizationStatus authStatus = [PHPhotoLibrary authorizationStatus];
isOpen = YES;
if (authStatus == PHAuthorizationStatusRestricted || authStatus == PHAuthorizationStatusDenied) {
isOpen = NO;
}
#else
ALAuthorizationStatus author = [ALAssetsLibrary authorizationStatus];
isOpen = YES;
if (author == ALAuthorizationStatusRestricted || author == ALAuthorizationStatusDenied) {
isOpen = NO;
}
#endif
if (returnBlock) {
returnBlock(isOpen);
}
}
5.iOS开发检测是否开启麦克风:
需要导入:
#import <AVFoundation/AVFoundation.h>
代码如下:
+ (void)openRecordServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
AVAudioSessionRecordPermission permissionStatus = [[AVAudioSession sharedInstance] recordPermission];
if (permissionStatus == AVAudioSessionRecordPermissionUndetermined) {
[[AVAudioSession sharedInstance] requestRecordPermission:^(BOOL granted) {
if (returnBlock) {
returnBlock(granted);
}
}];
} else if (permissionStatus == AVAudioSessionRecordPermissionDenied) {
returnBlock(NO);
} else {
returnBlock(YES);
}
#endif
}
6.iOS开发检测是否开启通讯录:
需要导入:
#import <AddressBook/AddressBook.h>#import <Contacts/Contacts.h>
代码如下:
+ (void)openContactsServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0
CNAuthorizationStatus cnAuthStatus = [CNContactStore authorizationStatusForEntityType:CNEntityTypeContacts];
if (cnAuthStatus == CNAuthorizationStatusNotDetermined) {
CNContactStore *store = [[CNContactStore alloc] init];
[store requestAccessForEntityType:CNEntityTypeContacts completionHandler:^(BOOL granted, NSError *error) {
if (returnBolck) {
returnBolck(granted);
}
}];
} else if (cnAuthStatus == CNAuthorizationStatusRestricted || cnAuthStatus == CNAuthorizationStatusDenied) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
#else
//ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULL, NULL);
ABAddressBookRef addressBook = ABAddressBookCreate();
ABAuthorizationStatus authStatus = ABAddressBookGetAuthorizationStatus();
if (authStatus != kABAuthorizationStatusAuthorized) {
ABAddressBookRequestAccessWithCompletion(addressBook, ^(bool granted, CFErrorRef error) {
dispatch_async(dispatch_get_main_queue(), ^{
if (error) {
NSLog(@"Error: %@", (__bridge NSError *)error);
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
});
});
} else {
if (returnBolck) {
returnBolck(YES);
}
}
#endif
}
7.iOS开发检测是否开启蓝牙:
需要导入:
#import <CoreBluetooth/CoreBluetooth.h>
代码如下:
+ (void)openPeripheralServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_7_0
CBPeripheralManagerAuthorizationStatus cbAuthStatus = [CBPeripheralManager authorizationStatus];
if (cbAuthStatus == CBPeripheralManagerAuthorizationStatusNotDetermined) {
if (returnBolck) {
returnBolck(NO);
}
} else if (cbAuthStatus == CBPeripheralManagerAuthorizationStatusRestricted || cbAuthStatus == CBPeripheralManagerAuthorizationStatusDenied) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
#endif
}
8.iOS开发检测是否开启日历/备忘录:
需要导入:
#import <EventKit/EventKit.h>
代码如下:
+ (void)openEventServiceWithBolck:(ReturnBlock)returnBolck withType:(EKEntityType)entityType
{
// EKEntityTypeEvent 代表日历
// EKEntityTypeReminder 代表备忘
EKAuthorizationStatus ekAuthStatus = [EKEventStore authorizationStatusForEntityType:entityType];
if (ekAuthStatus == EKAuthorizationStatusNotDetermined) {
EKEventStore *store = [[EKEventStore alloc] init];
[store requestAccessToEntityType:entityType completion:^(BOOL granted, NSError *error) {
if (returnBolck) {
returnBolck(granted);
}
}];
} else if (ekAuthStatus == EKAuthorizationStatusRestricted || ekAuthStatus == EKAuthorizationStatusDenied) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
}
9.iOS开发检测是否开启联网:
需要导入:
#import <CoreTelephony/CTCellularData.h>
代码如下:
+ (void)openEventServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0
CTCellularData *cellularData = [[CTCellularData alloc] init];
cellularData.cellularDataRestrictionDidUpdateNotifier = ^(CTCellularDataRestrictedState state){
if (state == kCTCellularDataRestrictedStateUnknown || state == kCTCellularDataNotRestricted) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
};
CTCellularDataRestrictedState state = cellularData.restrictedState;
if (state == kCTCellularDataRestrictedStateUnknown || state == kCTCellularDataNotRestricted) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
#endif
}
10.iOS开发检测是否开启健康:
需要导入:
#import <HealthKit/HealthKit.h>
代码如下:
+ (void)openHealthServiceWithBolck:(ReturnBlock)returnBolck
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
if (![HKHealthStore isHealthDataAvailable]) {
if (returnBolck) {
returnBolck(NO);
}
} else {
HKHealthStore *healthStore = [[HKHealthStore alloc] init];
HKObjectType *hkObjectType = [HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierHeight];
HKAuthorizationStatus hkAuthStatus = [healthStore authorizationStatusForType:hkObjectType];
if (hkAuthStatus == HKAuthorizationStatusNotDetermined) {
// 1. 你创建了一个NSSet对象,里面存有本篇教程中你将需要用到的从Health Stroe中读取的所有的类型:个人特征(血液类型、性别、出生日期)、数据采样信息(身体质量、身高)以及锻炼与健身的信息。
NSSet <HKObjectType *> * healthKitTypesToRead = [[NSSet alloc] initWithArray:@[[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierDateOfBirth],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBloodType],[HKObjectType characteristicTypeForIdentifier:HKCharacteristicTypeIdentifierBiologicalSex],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierBodyMass],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierHeight],[HKObjectType workoutType]]];
// 2. 你创建了另一个NSSet对象,里面有你需要向Store写入的信息的所有类型(锻炼与健身的信息、BMI、能量消耗、运动距离)
NSSet <HKSampleType *> * healthKitTypesToWrite = [[NSSet alloc] initWithArray:@[[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierBodyMassIndex],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierActiveEnergyBurned],[HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierDistanceWalkingRunning],[HKObjectType workoutType]]];
[healthStore requestAuthorizationToShareTypes:healthKitTypesToWrite readTypes:healthKitTypesToRead completion:^(BOOL success, NSError *error) {
if (returnBolck) {
returnBolck(success);
}
}];
} else if (hkAuthStatus == HKAuthorizationStatusSharingDenied) {
if (returnBolck) {
returnBolck(NO);
}
} else {
if (returnBolck) {
returnBolck(YES);
}
}
}
#endif
}
11.iOS开发检测是否开启Touch ID:
需要导入:
#import <LocalAuthentication/LocalAuthentication.h>
代码如下:
#pragma mark - 开启Touch ID服务
+ (void)openTouchIDServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0
LAContext *laContext = [[LAContext alloc] init];
laContext.localizedFallbackTitle = @"输入密码";
NSError *error;
if ([laContext canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) {
NSLog(@"恭喜,Touch ID可以使用!");
[laContext evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"需要验证您的指纹来确认您的身份信息" reply:^(BOOL success, NSError *error) {
if (success) {
// 识别成功
if (returnBlock) {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
returnBlock(YES);
}];
}
} else if (error) {
if (returnBlock) {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
returnBlock(NO);
}];
}
if (error.code == LAErrorAuthenticationFailed) {
// 验证失败
}
if (error.code == LAErrorUserCancel) {
// 用户取消
}
if (error.code == LAErrorUserFallback) {
// 用户选择输入密码
}
if (error.code == LAErrorSystemCancel) {
// 系统取消
}
if (error.code == LAErrorPasscodeNotSet) {
// 密码没有设置
}
}
}];
} else {
NSLog(@"设备不支持Touch ID功能,原因:%@",error);
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
需要导入:
#import <PassKit/PassKit.h>
代码如下:
#pragma mark - 开启Apple Pay服务
+ (void)openApplePayServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0
NSArray<PKPaymentNetwork> *supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa, PKPaymentNetworkDiscover];
if ([PKPaymentAuthorizationViewController canMakePayments] && [PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:supportedNetworks]) {
if (returnBlock) {
returnBlock(YES);
}
} else {
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
13.iOS开发检测是否开启语音识别:
需要导入:
#import <Speech/Speech.h>
代码如下:
#pragma mark - 开启语音识别服务
+ (void)openSpeechServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
SFSpeechRecognizerAuthorizationStatus speechAuthStatus = [SFSpeechRecognizer authorizationStatus];
if (speechAuthStatus == SFSpeechRecognizerAuthorizationStatusNotDetermined) {
[SFSpeechRecognizer requestAuthorization:^(SFSpeechRecognizerAuthorizationStatus status) {
if (status == SFSpeechRecognizerAuthorizationStatusAuthorized) {
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(YES);
}
});
} else {
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(YES);
}
});
}
}];
} else if (speechAuthStatus == SFSpeechRecognizerAuthorizationStatusAuthorized) {
if (returnBlock) {
returnBlock(YES);
}
} else{
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
14.iOS开发检测是否开启媒体资料库/Apple Music:
需要导入:
#import <MediaPlayer/MediaPlayer.h>
代码如下:
#pragma mark - 开启媒体资料库/Apple Music 服务
+ (void)openMediaPlayerServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_3
MPMediaLibraryAuthorizationStatus authStatus = [MPMediaLibrary authorizationStatus];
if (authStatus == MPMediaLibraryAuthorizationStatusNotDetermined) {
[MPMediaLibrary requestAuthorization:^(MPMediaLibraryAuthorizationStatus status) {
if (status == MPMediaLibraryAuthorizationStatusAuthorized) {
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(YES);
}
});
}else{
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(NO);
}
});
}
}];
}else if (authStatus == MPMediaLibraryAuthorizationStatusAuthorized){
if (returnBlock) {
returnBlock(YES);
}
}else{
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
15.iOS开发检测是否开启Siri:
需要导入:
#import <Intents/Intents.h>
代码如下:
#pragma mark - 开启Siri服务
+ (void)openSiriServiceWithBlock:(ReturnBlock)returnBlock
{
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
INSiriAuthorizationStatus siriAutoStatus = [INPreferences siriAuthorizationStatus];
if (siriAutoStatus == INSiriAuthorizationStatusNotDetermined) {
[INPreferences requestSiriAuthorization:^(INSiriAuthorizationStatus status) {
if (status == INSiriAuthorizationStatusAuthorized) {
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(YES);
}
});
} else {
dispatch_async(dispatch_get_main_queue(), ^{
if (returnBlock) {
returnBlock(YES);
}
});
}
}];
} else if (siriAutoStatus == INSiriAuthorizationStatusAuthorized) {
if (returnBlock) {
returnBlock(YES);
}
} else{
if (returnBlock) {
returnBlock(NO);
}
}
#endif
}
在.h文件中申明block
#if NS_BLOCKS_AVAILABLE
typedef void(^ReturnBlock)(BOOL isOpen);
#endif
由于iOS10的权限原因,需要在工程的info.plist(右击选择Open as - Source Code)中添加
<!-- 相册 -->
<key>NSPhotoLibraryUsageDescription</key>
<string>App需要您的同意,才能访问相册</string>
<!-- 相机 -->
<key>NSCameraUsageDescription</key>
<string>App需要您的同意,才能访问相机</string>
<!-- 麦克风 -->
<key>NSMicrophoneUsageDescription</key>
<string>App需要您的同意,才能访问麦克风</string>
<!-- 位置 -->
<key>NSLocationUsageDescription</key>
<string>App需要您的同意,才能访问位置</string>
<!-- 在使用期间访问位置 -->
<key>NSLocationWhenInUseUsageDescription</key>
<string>App需要您的同意,才能在使用期间访问位置</string>
<!-- 始终访问位置 -->
<key>NSLocationAlwaysUsageDescription</key>
<string>App需要您的同意,才能始终访问位置</string>
<!-- 日历 -->
<key>NSCalendarsUsageDescription</key>
<string>App需要您的同意,才能访问日历</string>
<!-- 提醒事项 -->
<key>NSRemindersUsageDescription</key>
<string>App需要您的同意,才能访问提醒事项</string>
<!-- 运动与健身 -->
<key>NSMotionUsageDescription</key>
<string>App需要您的同意,才能访问运动与健身</string>
<!-- 健康更新 -->
<key>NSHealthUpdateUsageDescription</key>
<string>App需要您的同意,才能访问健康更新 </string>
<!-- 健康分享 -->
<key>NSHealthShareUsageDescription</key>
<string>App需要您的同意,才能访问健康分享</string>
<!-- 蓝牙 -->
<key>NSBluetoothPeripheralUsageDescription</key>
<string>App需要您的同意,才能访问蓝牙</string>
<!-- 媒体资料库 -->
<key>NSAppleMusicUsageDescription</key>
<string>App需要您的同意,才能访问媒体资料库</string>
<!-- 语音识别 -->
<key>NSSpeechRecognitionUsageDescription</key>
<string>App需要您的同意,才能使用语音识别</string>
iOS开发检测是否开启定位、是否允许消息推送等权限的更多相关文章
- iOS开发笔记8:Remote Notification远程消息推送处理
远程消息推送处理场景有三种:分别是app还没有运行.app在前台运行以及app在后台运行,下面介绍相关流程及三种场景下处理步骤 1.流程 (1)注册通知 首先是在注册远程消息推送,需要注意的是iOS8 ...
- [入门到吐槽系列] 微信小程序 敏感违规图片检测 mediaCheckAsync,客服接口 消息推送 的各种坑分享!
前言: 最近需要做个用户上传图片,服务端校验图片问题的需求.需要使用小程序消息推送,异步接受腾讯的图片验证回调.实在太多坑了. 相信10分钟看完本文的朋友,可以非常顺利避坑. 前期准备: 首先需要一个 ...
- 了解iOS消息推送一文就够:史上最全iOS Push技术详解
本文作者:陈裕发, 腾讯系统测试工程师,由腾讯WeTest整理发表. 1.引言 开发iOS系统中的Push推送,通常有以下3种情况: 1)在线Push:比如QQ.微信等IM界面处于前台时,聊天消息和指 ...
- 微信小程序开发:设置消息推送
开发设置中,启用并设置消息推送配置后,用户发给小程序的消息以及开发者需要的事件推送,都将被微信转发至该服务器地址中. 不过照着说明去操作,即使按照最简单的明文方式去设置,还是提示Token验证失败.仔 ...
- iOS开发拓展篇—CoreLocation定位服务
iOS开发拓展篇—CoreLocation定位服务 一.简单说明 1.CLLocationManager CLLocationManager的常用操作和属性 开始用户定位- (void)startUp ...
- iOS开发 检测版本更新
iOS开发 检测版本更新的实现 苹果给了我们一个接口,能根据应用id请求一些关于应用的信息.我们可以根据返回的信息,来判断版本是否和应用的版本一致,如果不一致,那么就出现新的版本了.这时,就需要向用户 ...
- IOS开发之实现App消息推送
转自:http://blog.csdn.net/shenjie12345678/article/details/41120637 第一部分 首先第一步当然是介绍一下苹果的推送机制(APNS)咯(ps: ...
- IOS开发之实现App消息推送(最新)
好久没有写过博客啦,今天就由本菜鸟给大家做一个简单的IOSApp消息推送教程吧!一切从0开始,包括XCode6, IOS8, 以及苹果开发者中心最新如何注册应用,申请证书以及下载配置概要文件,相信很多 ...
- iOS 远程消息推送,原理和开发详解篇(新手推荐)
1.APNS的推送机制 首先我们看一下苹果官方给出的对ios推送机制的解释.如下图 Provider就是我们自己程序的后台服务器,APNS是Apple Push Notification Servic ...
随机推荐
- 转: NetBean远程开发的格式与过程
1. 介绍远程3种模式 https://netbeans.org/kb/docs/cnd/remote-modes.html 评注:英文的,3种模式讲的非常到位.服务器开发还是全远程比较不错.
- weexapp 开发流程(一)开发环境配置
1.创建项目 weexpack create weexapp 2.安装必要插件 npm i jwt-simple vue-resource vue-router vuex vuex-router-sy ...
- [unity3d]unity平台的预处理
在开发中,特别是unity的跨平台中,我们常常会在各个平台游走,如安卓版,苹果版,PC版.......在此不同的平台上,有可能我们须要做不同的操作.然而我们就能够用unity的自带的平台宏定义方式来做 ...
- 亲测linux上安装svn
方法一: 1.wget http://subversion.tigris.org/downloads/subversion-1.6.1.tar.gz2.wget http://subversion.t ...
- 各种加载效果,适合做加载loading动画效果 Eclipse版
Animation.rar 链接: http://pan.baidu.com/s/1c0QkOz2 密码: kd57
- 全卷积神经网络FCN理解
论文地址:https://people.eecs.berkeley.edu/~jonlong/long_shelhamer_fcn.pdf 这篇论文使用全卷积神经网络来做语义上的图像分割,开创了这一领 ...
- 一条数据的HBase之旅,简明HBase入门教程-开篇
常见的HBase新手问题: 什么样的数据适合用HBase来存储? 既然HBase也是一个数据库,能否用它将现有系统中昂贵的Oracle替换掉? 存放于HBase中的数据记录,为何不直接存放于HDFS之 ...
- wx.request的并发问题
wepyjs - 小程序组件化开发框架 https://tencent.github.io/wepy/document.html#/ 在同时并发10个request请求测试时: 不使用WePY: 使用 ...
- HDFS运维和优化
常见问题 下面列举HDFS运行过程中可能出现的常见问题及解决方法,这些问题一般都会在日志中出现的相应的记录.Incompatible clusterIDs in … :namenode cluster ...
- GNU Makeflie
简介 Gnu Make主要用于构建和管理程序包.Makefile文件描述了整个工程的编译.连接等规则. 其中包括: 工程中的哪些源文件需要编译以及如何编译: 需要创建那些库文件以及如何创建这些库文件: ...