发一个关于“微笑天使包燕娜"事件的Code Review,希望对大家有用。

    以下是对“微笑天使包燕娜"事件的Code Review:
    1.    问题现象
    新用户在iPhone客户端在用新浪微博登录时,用户的名称自动变为“微笑天使包燕娜”。
    2.    现象分析
    先说明咱们的新用户登录流程,
    A.    新用户登录时首先向第三方平台,请求用户的用户id(uid)
    B.    客户端将此uid发送到咱们自己的服务器,服务器返回此用户的uid与数据库对比返回,此用户是一个新用户
    C.    客户端收到服务器发送的此用户为新用户的信息,再次利用用户的uid向第三方平台发送请求用户具体信息的消息。
    D.    第三方服务器返回用户的具体信息后,客户端再将此信息发送到咱们自己的服务器上保存。
    E.    服务器返回修改过新的用户数据,客户端保存,登录过程完毕。

    通过对登录过程的log信息进行分析发现,在A和B阶段得到的uid,与C阶段发送的uid不相同。
    改变后的uid一直为2147483647。此uid对应新浪微博的用户"微笑天使包燕娜",因此返回给咱们自己服务器的用户数据一直是这个名称。
    继续定位发现在新浪SDK中,向新浪服务器发送获得用户详细信息(C过程)请求之前,代码进行了一次将uid字符串转换为int,再转换为字符串的过程。而当用户uid非常大,大于int的最大值(2147483647)时,此时uid被转换为int的最大值2147483647。
    因此,发送到新浪的uid会一直是“2147483647”。
   
    3.    解决问题
    在新浪的SDK的WeiboClient类中,将转换int的代码去掉并修改接口直接将字符串传入发送请求的函数中,问题解决。
    修改后的代码如下:
- (void)getUser:(NSString *)userId
{
    needAuth = YES;
    NSString *path = [NSString stringWithFormat:@"users/show.%@", API_FORMAT];
    NSMutableDictionary *params = [NSMutableDictionary dictionaryWithCapacity:0];
    [params setObject: userId forKey:@"user_id"];
    [super get:[self getURL:path queryParameters:params]];
}
posted @ 2011-09-21 18:28 摇滚诗人 阅读(...) 评论(...) 编辑 收藏