如果用户不存在,则不显示 jQuery 和排序


If user doesnt exist dont show jQuery and ordering

我构建了一个应用程序,用户可以注册并链接他们的Twitter帐户。

如果有人出于垃圾邮件目的创建了一个用户,但Twitter随后删除了该用户,他们仍然留在我的网站上。如果另一个用户试图关注他们,我会回复一条消息,说用户不再有效,但这已经成为一个严重的问题,并且有很多垃圾邮件帐户。

我目前的解决方案是在页面加载时,使用 jQuery 检查是否加载了 Twitter 用户图像,如果没有将该用户设置为不显示任何图像。

但是,我想知道,有没有办法在输出我的页面之前检查,这样我的用户就不会看到用户列表,当页面加载 X 时,他们中的 X 会消失,而是所有活动用户的列表?

谢谢


这是我页面上的 php,我知道它很旧,但是有没有办法检查用户是否存在于 Twitter 并将其与我当前拥有的内容混合?

对不起,我是PHP的新手!

$rs = mysql_query("select produgg_users.id, twitterUser, coff, credits from produgg_users where twitterUser != '' and active !='' and credits >= coff and  
                produgg_users.id IN (select concat_ws(',', id) from produgg_users where credits > 0 and id != ".$usersClass->userID().") and produgg_users.id NOT IN (select concat_ws(',', followedID) from produgg_activity where followerID = '".$usersClass->userID()."') and produgg_users.id NOT IN (select concat_ws(',', userid) from produgg_featured) ORDER BY coff DESC LIMIT 30;") or die(mysql_error());    
$nr = @mysql_num_rows($rs);
if($nr != 0) {
    print "<h2>More Friendr Users!</h2><div>";
    while($row=@mysql_fetch_object($rs))
    {
        $divLeft = '<div class="user-box" id="thediv_'.$row->id.'"><div class="twithandlepic"><img src="http://api.twitter.com/1/users/profile_image/';
        $divRight = '<div class="twithandle">';
        $clearDiv = '<div style="clear:both;"></div>';
        $row->coff = $row->coff - 1;

    print $divLeft.strip_tags($row->twitterUser)."?size=bigger'" style='"width:73px; height:73px;'"/><br '/>".$row->twitterUser.$divRight."<a href='javascript:void(0);'   id='vote_$row->id' class='getPoint'>Get $row->coff <input type='hidden' value='$row->coff' class='credoff' name='credoff'/> credit(s)</a><br /></div>$clearDiv</div></div>"; 

} print "</div>";
echo " <a href='earn-credits.php' class='refreshlist'>Refresh</a>";
}else{
    print "<p>No twitter users to show</p>";    
}

您只需向twitter.com/username发送请求并查看响应代码:如果用户存在,则为 200,如果用户不存在,则为 404。 例如,尝试 http://twitter.com/somefakeperson,你会得到一个 404。

使用 CURL,它看起来像这样:

   while($row=@mysql_fetch_object($rs)) 
    {
      $ch = curl_init('http://twitter.com/'.$row->twitterUser);
      curl_exec($ch);
      if(!curl_errno($ch))
      {
       $info = curl_getinfo($ch);
       if($info['http_code'] == '200') {
        $divLeft = '<div class="user-box" id="thediv_'.$row->id.'"><div class="twithandlepic"><img src="http://api.twitter.com/1/users/profile_image/';
        $divRight = '<div class="twithandle">';
        $clearDiv = '<div style="clear:both;"></div>';
        $row->coff = $row->coff - 1;

        print $divLeft.strip_tags($row->twitterUser)."?size=bigger'" style='"width:73px; height:73px;'"/><br '/>".$row->twitterUser.$divRight."<a href='javascript:void(0);'   id='vote_$row->id' class='getPoint'>Get $row->coff <input type='hidden' value='$row->coff' class='credoff' name='credoff'/> credit(s)</a><br /></div>$clearDiv</div></div>"; 

       }
     }
     curl_close($ch);
   }

顺便说一句,在遇到无效用户时,将更新发送回数据库也可能很好,以便以某种方式删除或标记该用户。 然后,您将来可以直接在数据库级别过滤掉这些用户。

Twitter API 调用 GET users/lookup 允许你查看用户是否处于活动状态。例如,在此处向端点发出 REST API 调用:

https://api.twitter.com/1/users/lookup.json?
    screen_name=twitterapi&include_entities=true

如果用户存在,将为您提供 HTTP 200 OK 响应。但是,屏幕名称不存在的呼叫会返回 404,例如:

https://api.twitter.com/1/users/lookup.json?
    screen_name=dsklfjdkl&include_entities=true

在向用户显示页面之前,您的服务器可以检查用户名是否存在(如果不存在,只需将它们从页面中删除/将它们标记为数据库中无效)。