当前位置: 移动技术网 > 移动技术>移动开发>Android > 详解Android微信登录与分享

详解Android微信登录与分享

2019年07月24日  | 移动技术网移动技术  | 我要评论

android 使用微信登录、分享功能

具体的文档详情微信官网上介绍(微信官网文档),本人直接按照项目部署步骤进行讲解:

第一步:申请你的appid;

第二步:依赖

dependencies {
 compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:1.0.2'
}

或者:

dependencies {
 compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:1.0.2'
}

这两个依赖包的区别是前者包含统计功能,后者没有。

第三步:在androidmanifest.xml中加入必须的权限

<uses-permission android:name="android.permission.internet"/>
<uses-permission android:name="android.permission.access_network_state"/>
<uses-permission android:name="android.permission.access_wifi_state"/>
<uses-permission android:name="android.permission.read_phone_state"/>
<uses-permission android:name="android.permission.write_external_storage"/>

第四步:注册到微信,微信的sdk在使用之前需要调用代码进行注册,注册可以是在调用微信sdk的activity,但最好还是放到入口activity或者application中;

wxapplication.java

public static string app_id="你的appid";
public static iwxapi api;
public void oncreate() {
  super.oncreate();
  api = wxapifactory.createwxapi(this, app_id, true);
  api.registerapp(app_id); 
}

第五步:微信登录。

    5.1 点击你的微信登录按钮,进行微信授权,首先需要获取一个code值,在包名下新建一个包,这里必须这样,不能随意命名,比如你的项目包名是:come.shenhua.wx则新建的包为come.shenhua.wx.wxapi在该包下创建一个wxentryactivity继承iwxapieventhandler;(注意activity的命名也不能随意更改)

loginactivity.java

private void onclickwechatlogin() {
  if (wxapplicaiton.api == null) {
   wxapplication.api = wxapifactory.createwxapi(this, wxapplication.app_id, true);
  }
  if (!wxapplication.api.iswxappinstalled()) {
   toastutils.toast("您手机尚未安装微信,请安装后再登录");
   return;
  }
  wxapplication.api.registerapp(wxapplication.app_id);
  sendauth.req req = new sendauth.req();
  req.scope = "snsapi_userinfo";
  req.state = "wechat_sdk_xb_live_state";//官方说明:用于保持请求和回调的状态,授权请求后原样带回给第三方。该参数可用于防止csrf攻击(跨站请求伪造攻击),建议第三方带上该参数,可设置为简单的随机数加session进行校验
  wxapplication.api.sendreq(req);
 }

在androidmanifest.xml中加入,(android:exported="true" 一定不能少)

<activity
   android:name=".wxapi.wxentryactivity"
   android:exported="true" />

wxentryactivity.java

public class wxentryactivity extends appcompatactivity implements iwxapieventhandler {
 public static final string tag = wxentryactivity.class.getsimplename();
 public static string code;
 public static baseresp resp = null;
 @override
 protected void oncreate(bundle savedinstancestate) {
  super.oncreate(savedinstancestate);
  setcontentview(r.layout.activity_wxentry);
  boolean handleintent = xbliveapplication.api.handleintent(getintent(), this);
     //下面代码是判断微信分享后返回wxenteryactivity的,如果handleintent==false,说明没有调用iwxapieventhandler,则需要在这里销毁这个透明的activity;
  if(handleintent==false){
   log.d(tag, "oncreate: "+handleintent);
   finish();
  }
 }
 @override
 protected void onnewintent(intent intent) {
  super.onnewintent(intent);
  setintent(intent);
  xbliveapplication.api.handleintent(intent, this);
 }
 @override
 public void onreq(basereq basereq) {
  log.d(tag, "onreq: ");
  finish();
 }
 @override
 public void onresp(baseresp baseresp) {
  if (baseresp != null) {
   resp = baseresp;
   code = ((sendauth.resp) baseresp).code; //即为所需的code
  }
  switch (baseresp.errcode) {
   case baseresp.errcode.err_ok:
    log.d(tag, "onresp: 成功");
    finish();
    break;
   case baseresp.errcode.err_user_cancel:
    log.d(tag, "onresp: 用户取消");
    finish();
    break;
   case baseresp.errcode.err_auth_denied:
    log.d(tag, "onresp: 发送请求被拒绝");
    finish();
    break;
  }
 }

resp和code定义成全局变量,在wxentrywactivity页面销毁后登录页面会走onresume()方法,在这里开始其他操作

    5.2 拿到code后在登录页面通过code获取access_token,官网的说法是:“access_token是调用授权关系接口的调用凭证,由于access_token有效期(目前为2个小时)较短,当access_token超时后,可以使用refresh_token进行刷新”,所以拿到access_token后再次请求进行refresh_token,刷新后拿到access_token即可发送请求获取微信用户信息了;

    获取access_token的url:accesstokenurl = "=你的appid&secret=你的appsecret&code=授权获取到的code&grant_type=authorization_code";

    刷新access_token的url:refresh_tokenurl = "=你的appid&grant_type=refresh_token&refresh_token=上一步请求到的access_token;

    获取用户信息url:userinfourl = "=刷新的access_token&openid=刷新access_token时获取的openid;

@override
 protected void onresume() {
  log.d(tag, "onresume: 1");
  super.onresume();
  //这里的判断是为了区分如果不是不是从wxentryactivity页面销毁重启的,不走下面的代码
  if (wxentryactivity.resp != null) {
   if (wxentryactivity.resp.gettype() == constantsapi.command_sendauth) {
    thread thread = new thread(downloadrun);
    thread.start();
    try {
     thread.join();
    } catch (interruptedexception e) {
     // todo auto-generated catch block
     e.printstacktrace();
    }
   }
  }
 }
 public runnable downloadrun = new runnable() {
  @override
  public void run() {
   wxgetaccesstoken();
  }
 };
 //根据code获取access_token,这里用第三方volley框架进行post请求
 private void wxgetaccesstoken() {
  string getaccesstokenurl = accesstokenurl;
  stringrequest request = new stringrequest(request.method.get, getaccesstokenurl, new response.listener<string>() {
   @override
   public void onresponse(string response) {
    log.d(tag, "onresponse: " + response);
    gson gson = new gson();
    wechatlogintokenmodel tokenmodel = gson.fromjson(response, wechatlogintokenmodel.class);
    refresh_token = tokenmodel.getrefresh_token();
    wxgetrefreshaccesstoken();
   }
  }, new response.errorlistener() {
   @override
   public void onerrorresponse(volleyerror error) {
   }
  });
  request.settag("wechatgettoken");
  xbliveapplication.gethttprequestqueue().add(request);
 }
 //拿到access_token后再次发送请求进行刷新access_token,拿到access_refresh和openid
 private void wxgetrefreshaccesstoken() {
  string getrefresh_tokenurl =refresh_tokenurl ;
  stringrequest request = new stringrequest(request.method.get, getrefresh_tokenurl, new response.listener<string>() {
   @override
   public void onresponse(string response) {
    gson gson = new gson();
    wechatlogintokenmodel tokenmodel = gson.fromjson(response, wechatlogintokenmodel.class);
    string access_token = tokenmodel.getaccess_token();
    string openid = tokenmodel.getopenid();
    wxgetuserinfo(access_token, openid);
   }
  }, new response.errorlistener() {
   @override
   public void onerrorresponse(volleyerror error) {
   }
  });
  request.settag("wechatgetrefreshtoken");
  xbliveapplication.gethttprequestqueue().add(request);
 }
 //获取用户信息
 private void wxgetuserinfo(string access_token, string openid) {
  string getuserinfourl =userinfour;
  stringrequest request = new stringrequest(request.method.get, getuserinfourl, new response.listener<string>() {
   @override
   public void onresponse(string response) {
    log.d(tag, "onresponse3: " + response);
    gson gson = new gson();
    wechatuserinfomodel userinfomodel = gson.fromjson(response, wechatuserinfomodel.class);
    string city = userinfomodel.getcity();
    string username = userinfomodel.getnickname();
    string usericon = userinfomodel.getheadimgurl();
    int sex = userinfomodel.getsex();//1:男;0:女;2:未知
    string province = userinfomodel.getprovince();
    openid_wx = userinfomodel.getopenid();
    toastutils.toast("登录成功");
   }
  }, new response.errorlistener() {
   @override
   public void onerrorresponse(volleyerror error) {
   }
  });
    //下面代码是volley框架注册,请忽视
  request.settag("wechatgetuserinfo");
  xbliveapplication.gethttprequestqueue().add(request);
 }

注意一点:在做测试时,微信的应用签名必须要保持一致,比如你在官网填写的是没有打包签名的应用签名,你测试的app也没有打包签名,那么是没有问题,但是如果你微信官网上填写的是已经上线经过打包签名的应用签名,那你在做测试时必须要用打包签名的应用去做测试。

第六步:微信分享到朋友圈:

第七步:微信分享到微信好友:

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持移动技术网!

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网