AFNetwork 2.0在请求时报错code=-1016 和 3840

在进行网络请求时出现-1016 是因为只支持

text/json,application/json,text/javascript

你可以添加text/html 

一劳永逸的方法是 在

AFURLResponseSerialization.h

里面搜索

self.acceptableContentTypes

然后 在里面 添加

@"text/html",@"text/plain"

这样就可以解决-1016的错误了

但是随之而来的是3840错误

Error Domain=NSCocoaErrorDomain Code=3840 "The operation couldn’t be completed. (Cocoa error 3840.)" (JSON text did not start with array or object and option to allow fragments not set.) UserInfo=0x9152780 {NSDebugDescription=JSON text did not start with array or object and option to allow fragments not set.}

你会发现出现此错误

怎么办呢

添加如下语句 就可以解决问题了

manger.requestSerializer = [AFHTTPRequestSerializerserializer];

manger.responseSerializer = [AFHTTPResponseSerializerserializer];


是否成功了,成功了吧!但是新问题出现了  编码问题  如果服务器返回a 的话   你收到的 是<61>

这样  怎么能行呢?

当你用浏览器 去请求时 发现 响应头Content-Type: text/html;charset=UTF-8 是这样的

但是afNetwork 请求是Content-Type:text/plain;charset=ISO-8859-1 是这样的  不一致了吧

为什么 pc浏览器 访问的 和用afNetwork 访问的 不一致呢? 不了解 什么情况?

接着发现  其实 添加 如下二句 即可  也不用去修改AFURLResponseSerialization.h 里面的东西

manger.requestSerializer = [AFHTTPRequestSerializerserializer];

manger.responseSerializer = [AFHTTPResponseSerializerserializer];

把 收到的

responseObject 转换一下 编码 就OK了

NSData *doubi = responseObject;

NSString *shabi =  [[NSString alloc]initWithData:doubi encoding:NSUTF8StringEncoding];

### 回答1: db2 errorcode=-4229是指在执行SQL语句发生了死锁(Deadlock)错误。这种错误通常是由于多个事务同请求相同的资源而导致的。为了解决这个问题,可以通过重新设计事务或者增加资源来避免死锁的发生。同,也可以通过使用DB2的锁定机制来避免死锁的发生。 ### 回答2: db2 errorcode=-4229是一种数据库错误代码,通常与db2数据库服务器的连接相关的问题有关。当用户无法成功连接到db2数据库服务器,数据库服务器会返回这个错误代码。 通常错误码-4229可能是由于以下原因引起的: 1.连接被拒绝:在db2数据库中,通常会出现许多不同的错误导致拒绝连接,在此情况下,错误码-4229可能是由于连接帐户密码错误或无法识别的连接源所致。 2. db2数据库服务器没有启动或处于宕机状态:db2数据库服务器可能无法运行或处于宕机状态,这可能导致无法连接到数据库服务器,从而生成错误码-4229。 3. 数据库协议错误:db2数据库可能需要使用特定的日期格式或其他协议才能与客户端成功通信。如果客户端使用的协议与db2服务器不匹配,则可能会发生错误码-4229。 4. 数据库启用了安全机制:在db2数据库中,可能需要对客户端进行身份验证以授权访问。如果客户端无法成功通过身份验证,则连接将被拒绝并且生成错误码-4229。 以上是造成db2 errorcode=-4229的主要原因,用户在遇到此错误码应该验证连接帐户密码、检查数据库服务器是否启动、确保协议匹配或与管理员联系获取进一步支持。 ### 回答3: DB2错误码-4229是一种数据库错误。发生此类错误,DB2无法识别一个或多个SQL语句或命令。这种错误的常见原因是数据库不兼容或错误的SQL语句及语法错误。 解决DB2错误码-4229需要以下步骤: 第一步是检查SQL语句是否正确。如果有语法问题,则需要修复该语句以使其适用于数据库。这通常涉及到使用正确的关键词、拼写单词正确、正确的语句顺序及将语句与正确的数据类型配对。 第二步是检查数据库是否与应用程序兼容。如果应用程序使用的数据库与数据库不兼容,则会导致此类型的错误。这可以通过检查数据库的版本、兼容性与应用程序的要求来确定。 第三步是检查数据库日志和错误日志以确定出错的具体原因。这可以帮助确定问题的根本原因。 第四步是查看DB2文档以了解该错误码的详细细节及其解决方案。这可以为您提供其他建议和正确的操作来解决错误。 最后,如果您无法解决DB2错误-4229,请与您的开发团队、数据库管理员或DB2支持服务联系,以帮助诊断和解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值