qq登陆,新浪微博登陆 ,接口开发

给linux命令在线中文手册加了,qq登陆和新浪微博登陆,认证用的是auth2.0,而且用了js api和php api相结合的方式来作的。我的以为这种方式,兼顾安全和人性化。之前写过一篇关于申请的博客,请参考:qq登陆,新浪微博登陆接口申请过程当中遇到的问题javascript

1,js api的优势,就是弹窗登陆,不要跳来跳去,烦的很,数据都是后获取的,能够经过浏览器的开发者工具,看到返回的数据,这样保存api返回的数据就不安全了,在浏览器上能够直接写代码,模拟提交php

2,php api的缺点,页面跳转,我的感受跳来跳去,很是让人不爽。可是在保存数据时,要安全的多,而且随时能够到第三方进行数据审核。html

若是两者结合起来,不用跳来跳去,数据也能够获得校验。java

一,qq登陆linux

qq登陆,JS API登陆,并获取我的数据,异步提交给php程序,php程序,对提交来的数据,进行第三方校验,也就是说,根据传来的参数,在请求一次php的api,来获取信息,入本地数据库。qq的open id是qq的惟一标识,主要代码以下。ajax

1,js代码数据库

  1. <script type="text/javascript" src="http://qzonestyle.gtimg.cn/qzone/openapi/qc_loader.js" data-appid="你的appid"  charset="utf-8"></script>  
  1. function qq_login(){  
  2.    QC.Login({  
  3.        btnId:"qqlogin",  
  4.        scope:"all",  
  5.        size: "A_M"  
  6.    }, function(reqData, opts){  
  7.         if(QC.Login.check()){  
  8.             QC.Login.getMe(function(openId, accessToken){  
  9.                 if(openId){  
  10.                     $.ajax({  
  11.                         type:"POST",  
  12.                         url:"./?mod=ajax&app=ajax_login&act=qq",  
  13.                         async:false,  
  14.                         data:{'openid':openId,'access':accessToken,'login':'only'},  
  15.                         success: function(msg){  
  16.                              if(msg == 'yes'){  
  17.                                 这里是你的操做  
  18.                              }  
  19.                         }  
  20.                      });  
  21.                 }  
  22.             });  
  23.         }  
  24.    });  
  25. }  

2,php代码api

  1. require_once("路径/qqConnectAPI.php");   //顶部包含这个文件  
  2.   
  3. public function qqAction(){  
  4.   
  5.     if(emptyempty($_POST['openid']) || emptyempty($_POST['access'])){  
  6.         echo "no";  
  7.         exit;  
  8.     }  
  9.   
  10.     $this->open_id = $_POST['openid'];  
  11.     $this->access = $_POST['access'];  
  12.   
  13.     $qc = new QC($this->access,$this->open_id);     //对数据进行校验  
  14.     $arr = $qc->get_user_info();  
  15.   
  16.     $result = $this->save_qq($arr);      //保存数据  
  17.     if(!emptyempty($result){  
  18.         echo "yes";  
  19.         exit;  
  20.     }else{  
  21.         echo "no";  
  22.         exit;  
  23.     }  

二,新浪微博登陆浏览器

js api登陆过程,获取到登陆数据,而且存储到cookie中,异步提交时,不用传参数到,php程序。php api有方法读取登陆的access token,并获取惟一标识,user id安全

在这里再吐槽一下,新浪的接口,仍是不错的,可就是尼玛,文档乱的一踏糊涂,找个东西,那叫痛苦。

1,js 代码

  1. <script src="http://tjs.sjs.sinajs.cn/open/api/js/wb.js?appkey=应用的app id" type="text/javascript" charset="utf-8"></script>  

新浪微博的app key,app secret有多个,一个是网站的app key,app secret,网站下,每一个建立应用都有一个app key,app secret。

  1. function weibo_login (){  
  2.       WB2.anyWhere(function(W){  
  3.         W.widget.connectButton({  
  4.             id: "weibologin",  
  5.             type:'3,2',  
  6.             callback : {  
  7.                 login:function(o){    //登陆后的回调函数  
  8.                     $.ajax({  
  9.                         type:"POST",  
  10.                         url:"./?mod=ajax&app=ajax_login&act=weibo",  
  11.                         async:false,  
  12.                         data:{'login':'only'},  
  13.                         success: function(msg){  
  14.                              if(msg == 'yes'){  
  15.                                 你的操做  
  16.                              }  
  17.                         }  
  18.                      });  
  19.                 }  
  20.             }  
  21.         });  
  22.     });  
  23. }  

2,php代码

  1. include_once('路径/config.php');  
  2. include_once('路径/saetv2.ex.class.php');  
  3.   
  4. public function weiboAction(){  
  5.   
  6.     $o = new SaeTOAuthV2( WB_AKEY , WB_SKEY );  
  7.     $access = $o->getTokenFromJSSDK();       //从cookie中获取数据  
  8.   
  9.     $c = new SaeTClientV2( WB_AKEY , WB_SKEY , $access['access_token'] );  
  10.     $user_message = $c->show_user_by_id( $access['uid']);  
  11.   
  12.     $result = $this->save_sina($user_message);      //保存数据  
  13.     if(!emptyempty($result){  
  14.         echo "yes";  
  15.         exit;  
  16.     }else{  
  17.         echo "no";  
  18.         exit;  
  19.     }  
  20. }  

三,小结

qq登陆和微博登陆的接口都仍是不错的,qq登陆在实用性,灵活性,安全性上,比微博就好一点。特别是文档方面,qq登陆比微博登陆好的太多。新浪微博团队能不能改进一下呢。这就比如,有了家电,没有说明书是同样的。

相关文章
相关标签/搜索