cocos2dx lua 接微博SDK(一)--微博登陆

看到同事和朋友都有在写博客,也来练练手。。。

环境:cocos code ide 1.2 ,  Android 新浪weiboSDK 3.0.1 ,cocos2dx 3.3F,eclipse

一、认证授权(PS:不就是登录吗?),手机有无安装微博客户端都可用


1,申请APP_KEY,注册 应用程序包名和签名,和导入eclipse,及AndroidManifest.xml里要修改的权限(文档里讲得很详细。。)

2,eclipse下 打开 AppActivity.java,把weibo demo里的constants.java 和AccessTokenKeeper.java复制到org.cocos2dx.lua目录下,并自行修改包,key等。。


3,在类AppActivity里创建 变量

private static AuthInfo mAuthInfo;

private static Oauth2AccessToken mAccessToken;

private static SsoHandler mSsoHandler;

public static AuthListener auth;

public static boolean isEnter;  //是否登陆,


4,在

protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
里添加
// 创建授权认证信息
        mAuthInfo = new AuthInfo(this, Constants.APP_KEY, Constants.REDIRECT_URL, Constants.SCOPE);
        mSsoHandler = new SsoHandler(AppActivity.this, mAuthInfo);

isEnter = false;

auth = new AuthListener();

5,回到类AppActivity里添加

class AuthListener implements WeiboAuthListener {
   @Override
   public void onComplete(Bundle values) {
       // 从 Bundle 中解析 Token
       mAccessToken = Oauth2AccessToken.parseAccessToken(values);
       
       System.out.println("mAccessToken:" + mAccessToken);
       if (mAccessToken.isSessionValid()) {
           // 显示 Token
        // 保存 Token 到 SharedPreferences
        isEnter = true;
       
            AccessTokenKeeper.writeAccessToken(AppActivity.this, mAccessToken);
            //Toast.makeText(app, R.string.weibosdk_demo_toast_auth_success, Toast.LENGTH_SHORT).show();
            
           System.out.println("mAccessToken:  " + mAccessToken);
       } else {
           // 以下几种情况,您会收到 Code:
           // 1. 当您未在平台上注册的应用程序的包名与签名时;
           // 2. 当您注册的应用程序包名与签名不正确时;
           // 3. 当您在平台上注册的包名和签名与您当前测试的应用的包名和签名不匹配时。
           String code = values.getString("code");
           //String message = getString(R.string.weibosdk_demo_toast_auth_failed);
           if (!TextUtils.isEmpty(code)) {
               //message = message + "\nObtained the code: " + code;
           }
           System.out.println("code:" + code);
           //Toast.makeText(WeiboMain.this, message, Toast.LENGTH_LONG).show();
       }
   }


   @Override
   public void onCancel() {


   }


   @Override
   public void onWeiboException(WeiboException e) {
       Toast.makeText(AppActivity.this, 
               "Auth exception : " + e.getMessage(), Toast.LENGTH_LONG).show();
   }
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
       super.onActivityResult(requestCode, resultCode, data);
       
       // SSO 授权回调
       // 重要:发起 SSO 登陆的 Activity 必须重写 onActivityResult
       if (mSsoHandler != null) {
           mSsoHandler.authorizeCallBack(requestCode, resultCode, data);
        System.out.println("mAccessToken:" + mAccessToken);
       }
   }   


//跳转到登陆界面
public static boolean enterWeibo(){   
new Thread(new Runnable() {
  public void run() {
  if (isEnter == false )
  {  
   mSsoHandler.authorize(auth);
  }   
  }
 }).start();
return isEnter;

6,cocos2dx代码里调用public static boolean enterWeibo() 函数看返回值为TRUE就是成功登陆了

PS : 都用的静态数据 ,是为了方便方便cocos2dx的调用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值