iOS开发错误之Attempting to badge the application icon but haven't received permiss

针对iOS8及更高版本中通知权限的变化,本文介绍如何通过代码实现应用首次启动时请求用户授权,以支持badge、alert和sound等功能。适用于iOS开发者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(1)原因

一切都是iOS8捣的鬼。您如果把模拟器换成iOS7.1或者更早的,就不会有这个问题。而现在在iOS8中要实现badge、alert和sound等都需要用户同意才能,因为这些都算做Notification“通知”,为了防止有些应用动不动给用户发送“通知”骚扰用户,所以在iOS8时,要“通知”必须要用户同意才行。

(2)解决思路:我们判断一下,如果系统版本大于等于8.0的话,我们就在用户打开应用的时候弹出一个框框提示说我们要发送通知给你,你同意不?如果用户同意,那么我们就可以了。而如果系统版本小于8.0的话,因为默认是可以的,所以我们不需要做任何事情。

那么问题来了:怎么弹个框框给用户,并且用户同意让我们发通知呢?

——首先这个是在应用程序第一次被打开加载完毕的时候就要弹出这个框,安装过APP的人都不会陌生吧。所以,需要在AppDelegate.m的didFinishLaunching方法中写。

——其次,我们判断系统版本,用if语句,获取系统版本,把NSString转换成float可以比较,这些都没问题。

——最终,核心是if里面的三句话。大体意思是,我们先定义一个“通知设置”,然后把这个“通知设置”注册到“用户通知设置”里面,而注册到“用户通知设置”里面的那些“通知设置”,都是用框框弹出来让用户决定是否接受这种通知的。

——这个“通知设置”,主要是定义“通知类型”。我们本例中只是badge,但是还有alert和sound都属于通知类型,所以我们“多此一举”,把所有的通知类型都囊括进来,这样,我们就不需要以后一个一个的去设置alert和sound了。


- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  float sysVersion=[[UIDevice currentDevice]systemVersion].floatValue;
  if (sysVersion>=8.0) {
    UIUserNotificationType type=UIUserNotificationTypeBadge | UIUserNotificationTypeAlert | UIUserNotificationTypeSound;
    UIUserNotificationSettings *setting=[UIUserNotificationSettings settingsForTypes:type categories:nil];
    [[UIApplication sharedApplication]registerUserNotificationSettings:setting];
  }
  // Override point for customization after application launch.
  return YES;
}


### 解决方案分析 当遇到 `MySqlException: Fatal error encountered attempting to read the resultset` 的错误时,通常表明数据库查询过程中出现了严重问题。此类错误可能由多种原因引起,包括但不限于连接超时、数据不一致、SQL语法错误或网络中断等问题。 以下是可能导致该错误的原因及其解决方案: #### 1. 数据库连接配置不当 如果数据库连接池设置不合理或者连接参数有误,可能会导致读取结果集失败。例如,连接超时时间不足或最大连接数过低都可能是潜在因素[^1]。 - **建议调整连接字符串中的超时参数**: ```java String connectionString = "jdbc:mysql://localhost:3306/mydb?connectTimeout=10000&socketTimeout=30000"; ``` #### 2. 查询语句存在问题 某些情况下,执行的 SQL 查询可能存在语法错误或逻辑缺陷,这会引发异常并阻止正常的结果集读取操作[^3]。 - **验证 SQL 查询的有效性**: 确保所有动态生成的 SQL 都经过严格测试,并避免硬编码常量值。可以考虑使用预编译语句来减少风险。 ```sql PreparedStatement stmt = connection.prepareStatement("SELECT column_name FROM table_name WHERE id = ?"); stmt.setInt(1, userId); ResultSet rs = stmt.executeQuery(); ``` #### 3. 输入数据未正确处理 输入数据未经充分解析和规范化就直接用于构建查询条件,容易引入安全隐患以及运行期错误。特别是对于复杂格式的数据(如日期),应先完成校验再继续后续流程[^2]。 - **示例代码展示如何安全地转换日期字段** ```java SimpleDateFormat sdf = new SimpleDateFormat(Constants.dateFormat); // 使用全局定义好的日期格式化器 Date parsedDate; try { parsedDate = sdf.parse(inputDateString); } catch (ParseException e) { throw new IllegalArgumentException("Invalid date provided", e); } // 将解析后的日期对象存储到 PreparedStatement 中作为绑定变量之一 preparedStatement.setDate(indexOfParameter, new java.sql.Date(parsedDate.getTime())); ``` #### 4. 时间区域差异影响 跨地域部署的应用程序如果没有统一管理好各个组件间的时间戳表示方式,则可能出现同步上的偏差甚至崩溃情况。因此,在设计阶段就应该明确规定采用何种标准来进行时间记录与交换。 - **推荐做法是在应用层面上始终以 UTC 表达时刻信息** --- ### 总结 通过上述方法可以从多个角度排查并修复 “Fatal error reading resultset” 这一常见 MySQL 错误现象。具体实施时需结合实际业务场景灵活运用这些技巧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值