登录微信用android设备,Android 之微信登录

准备工作

需要在微信开放平台注册登录账户。还得办理开发者资质认证,审核费用为300元。

2.在微信开放平台创建移动应用,填写相关信息后提交审核。

简述业务流程

1.获取appId和secret

2.通过appId和secret调微信接口获取 code

3.通过code和getAccessToken()方法再获取accessToken和 openId。(通过 unionId即可区分微信用户实现登录)

4.当然也可以通过 unionId与 用户手机号进行绑定。

5.通过access_token和openid调用api.weixin.qq.com/sns/userinfo接口获取微信昵称、性别等信息。

微信开放平台获取应用AppID及AppSecret

注意事项:

a.若遇到重名,请发起申诉;

b.在注册流程中请不要开通应用微信支付;

c.在注册流程中填写的包名、签名应与腾讯开放平台后台保持一致。

2.点击“管理中心”或“移动应用开发-查看更多-创建应用”

858d09134a1e

image.png

进入创建移动应用流程。

3.填写对应信息完成注册

Step1

858d09134a1e

填写基本信息

Step2

858d09134a1e

填写签名和包名

Step3

858d09134a1e

提交审核

注册后等待审核。审核将于7天内完成;

集成流程

Step1:在 app 下的build.gradle里添加依赖即可

dependencies {

compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:+'

}

Step2:在包名路径下,新建wxapi文件夹,再新建一个WXEntryActivity。(路径文件名必须和创建移动应用时填写的包名保持一致)

858d09134a1e

创建包与文件

Step3:打开WXEntryActivity

public class WXEntryActivity extends AppCompatActivity implements IWXAPIEventHandler

重写两个方法:

@Override

public void onReq(BaseReq baseReq) {

}

//请求回调结果处理

//向微信开放平台发起请求后,在此接收回调数据

@Override

public void onResp(BaseResp baseResp) {

}

Step4:打开 MainActivity 或者 LoginActivity

//注册api

private void regToWx() {

api = WXAPIFactory.createWXAPI(this, APP_ID, true);

api.registerApp(APP_ID);

}

//先判断用户手机是否安装了微信客户端

if (!api.isWXAppInstalled()) {

Toast.makeText(MainActivity.this, "您的设备未安装微信客户端", Toast.LENGTH_SHORT).show();

} else {

//向微信开放平台发起请求

final SendAuth.Req req = new SendAuth.Req();

req.scope = "snsapi_userinfo";

req.state = "wechat_sdk_demo_test";

api.sendReq(req);

}

Step5:在onRep()方法里获取回调,拿到返回的参数 code

//请求回调结果处理

@Override

public void onResp(BaseResp baseResp) {

//登录回调

switch (baseResp.errCode) {

case BaseResp.ErrCode.ERR_OK:

String code = ((SendAuth.Resp) baseResp).code;

//获取accesstoken

getAccessToken(code);

Log.d("fantasychongwxlogin", code.toString()+ "");

break;

case BaseResp.ErrCode.ERR_AUTH_DENIED://用户拒绝授权

finish();

break;

case BaseResp.ErrCode.ERR_USER_CANCEL://用户取消

finish();

break;

default:

finish();

break;

}

}

Step6:根据返回码,如果请求成功会返回BaseResp.ErrCode.ERR_OK:相等的值,然后通过code和getAccessToken()方法再获取accessToken。

private void getAccessToken(String code) {

createProgressDialog();

//获取授权

StringBuffer loginUrl = new StringBuffer();

loginUrl.append("https://api.weixin.qq.com/sns/oauth2/access_token")

.append("?appid=")

.append("wx45ccf8958a0a24c7")

.append("&secret=")

.append("e9c071f3326663856bc6cf02c2d6b657")

.append("&code=")

.append(code)

.append("&grant_type=authorization_code");

Log.d("urlurl", loginUrl.toString());

OkHttpClient okHttpClient = new OkHttpClient();

final Request request = new Request.Builder()

.url(loginUrl.toString())

.get()//默认就是GET请求,可以不写

.build();

Call call = okHttpClient.newCall(request);

call.enqueue(new Callback() {

@Override

public void onFailure(Call call, IOException e) {

Log.d("fan12", "onFailure: ");

mProgressDialog.dismiss();

}

@Override

public void onResponse(Call call, Response response) throws IOException {

String responseInfo= response.body().string();

Log.d("fan12", "onResponse: " +responseInfo);

String access = null;

String openId = null;

try {

JSONObject jsonObject = new JSONObject(responseInfo);

access = jsonObject.getString("access_token");

openId = jsonObject.getString("openid");

} catch (JSONException e) {

e.printStackTrace();

}

getUserInfo(access, openId);

}

});

}

Step7:这里我们在请求之前新建一个progressDialog,避免长时间白屏(因为在进行多次网络请求)造成卡死的假象

private void createProgressDialog() {

mContext=this;

mProgressDialog=new ProgressDialog(mContext);

mProgressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);//转盘

mProgressDialog.setCancelable(false);

mProgressDialog.setCanceledOnTouchOutside(false);

mProgressDialog.setTitle("提示");

mProgressDialog.setMessage("登录中,请稍后");

mProgressDialog.show();

}

Step8:如果请求成功,我们通过JSON解析获取access和token值,再通过getUserInfo(access, openId)方法获取用户信息

@Override

protected void onResume() {

super.onResume();

SharedPreferences sp= getSharedPreferences("userInfo", MODE_PRIVATE);

String responseInfo= sp.getString("responseInfo", "");

if (!responseInfo.isEmpty()){

try {

JSONObject jsonObject = new JSONObject(responseInfo);

nickname = jsonObject.getString("nickname");

headimgurl = jsonObject.getString("headimgurl");

} catch (JSONException e) {

e.printStackTrace();

}

tv.setText("昵称:"+ nickname+ "\n"+ "头像:"+ headimgurl);

SharedPreferences.Editor editor= getSharedPreferences("userInfo", MODE_PRIVATE).edit();

editor.clear();

editor.commit();

}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/428899.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1013 数素数 (20 分)

1013 数素数 (20 分) 令 P ​i ​​ 表示第 i 个素数。现任给两个正整数 M≤N≤10 ​4 ​​ ,请输出 P ​M ​​ 到 P ​N ​​ 的所有素数。 输入格式: 输入在一行中给出 M 和 N,其间以空格分隔。 输出格式: 输出从 P ​M ​​…

《浅谈CT》总结

注明来自 http://www.ssdfans.com/?p1941 这里说的CT,不是医院里面的CT,而是闪存的一种技术:Charge Trap。 闪存不只有Floating Gate,还有Charge Trap。 浮栅极材料是导体,一般为多晶硅。 CTF(Charge Trap…

android可见区域,识别目标View在HorizontalScrollView可见区域

完成需求的时候涉及到这个所以撸了一下本文章是本人原创,转载请带原地址连接先放效果图(霁雪清虹"是目标):首先需要一个自定义HorizontalScrollView,复写一个View的onScrollChanged方法,用于监听滑动变化代码如下&#xff1a…

1015 德才论 (25 分)

1015 德才论 (25 分) 宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人。凡取人之术,苟不得圣人,君子而与之&#xff0c…

AI单挑Dota 2世界冠军:被电脑虐哭……

OpenAI的机器人刚刚在 Dota2 1v1 比赛中战胜了人类顶级职业玩家 Denti。以建设安全的通用人工智能为己任的 OpenAI,通过“Self-Play”的方式,从零开始训练出了这个机器人。 Dota2沦陷 继横扫顶级的人类国际象棋大师和围棋大师后,计算机如今在…

用session实现html登录页面跳转页面跳转页面跳转,js判断登录与否并确定跳转页面的方法...

这篇文章主要介绍了js判断登录与否并确定跳转页面的方法,涉及Ajax及session使用的技巧,非常具有实用价值,需要的朋友可以参考下本文实例讲述了js判断登录与否并确定跳转页面的方法。分享给大家供大家参考。具体如下:使用session存储,确定用户是否登录&am…

7-26 Windows消息队列(25 分)

7-26 Windows消息队列(25 分) 消息队列是 Windows 系统的基础。对于每个进程,系统维护一个消息队列。如果在进程中有特定事件发生,如点击鼠标、文字改变等,系统将把这个消息加到队列当中。同时,如果队列不…

Java——操作集合的工具类:Collections

Java 提供了一个操作 Set 、List 和 Map 等集合的工具类 :Collections,该工具类里提供了大量方法对集合元素进行排序、查询和修改等操作 转载于:https://www.cnblogs.com/szj-ang/p/7383027.html

鸿蒙关键技术研究,华为鸿蒙 2.0 系统主题演讲公布,详细架构 9 月 11 日揭晓

IT之家 8 月 30 日消息 华为 9 月 10 日将举行华为开发者大会 2020,华为官网表示,“我们将与您分享 HMS Core 5.0 最新进展, 揭开 HarmonyOS 和 EMUI 11 的神秘面纱。 振奋人心的新技术,深入的交流学习机会, 更灵动的想…

shell 提示符个性化设置

提示符具体含义可参考: http://billie66.github.io/TLCL/book/zh/chap14.html Ubuntu16.04个人配置如下,供以后查阅 1 function git_branch {2 branch"git branch 2>/dev/null | grep "^\*" | sed -e "s/^\*\ //""3…

如何设置鼠标滚轮html,win7如何设置鼠标滚轮

你们知道在W7中怎么设置鼠标的滚轮吗?下面是小编带来的关于win7如何设置鼠标滚轮的内容,欢迎阅读!Win7设置滚轮方法一:首先要在电脑的左下角点击开始按钮点击开始按钮以后出现上拉菜单,在菜单上面点击控制面板点击控制面板以后进入到控制面板…

湛江高考2021成绩查询,2021广东省高中学业水平考试成绩查询(入口+方式)

2021年广东高中学业水平合格性考试成绩查询查询方式:考生登录广东省教育考试服务中心的广东教育考试服务网,通过综合查询栏目页面,按相关提示即可查询考试成绩。查询入口二:“广东省教育考试院”小程序查询方式:①在“…

A. Red and Blue Beans

题意&#xff1a;红豆子和绿豆子分在不同的篮子里。问最小的最大差是能不能比给的d小。 方法&#xff1a;尽可能用更多的篮子里。 #include<iostream> using namespace std; int main() {double a,b,k;int n;cin>>n;for (int i0;i<n;i){cin>>a>>b&…

JAVA经典算法40题

【程序1】 题目&#xff1a;古典问题&#xff1a;有一对兔子&#xff0c;从出生后第3个月起每个月都生一对兔子&#xff0c;小兔子长到第四个月后每个月又生一对兔子&#xff0c;假如兔子都不死&#xff0c;问每个月的兔子总数为多少&#xff1f; 1.程序分析&#xff1a; 兔子…

中英对照 关于计算机的科技英语,《计算机专业英语》(中英文对照).pdf

《计算机专业英语》(中英文对照)计算机专业英语Computer EnglishChapter 1 The History andFuture of Computers2009.9.1Chapter 1 The History and Future of ComputersKey points:Key points:useful terms and definitions ofuseful terms and definitions ofcomputerscomput…

[php] in_array 判断问题(坑)

<?php $arr array("Linux"); if (in_array(0, $arr)) {echo "match"; } ?> 执行以上代码&#xff0c;0和字符串是可以匹配成功的。 原因是在in_array&#xff0c;如果比较的类型不匹配&#xff0c;并且第一个参数是0&#xff0c;它会返回true&…

B. The Cake Is a Lie

题意&#xff1a;从&#xff08;1&#xff0c;1&#xff09;走到他给的点&#xff0c;只能向上和向右。int cou 0;如果向上就coux;,如果向右就couy; 题解&#xff1a;最大的cou是两条直线。最小的cou是一直转弯。 注意点&#xff1a;如果x>y 先走x;反之亦反&#xff1b; #i…

学计算机应该具备什么能力,学习计算机专业该具备那些能力?

计算机专业涵盖软件工程专业&#xff0c;主要培养具有良好的科学素养&#xff0c;系统地、较好地掌握计算机科学与技术包括计算机硬件、软件与应用的基本理论、基本知识和基本技能与方法&#xff0c;能在科研部门、教育单位、企业、事业、技术和行政管理部门等单位从事计算机教…

度度熊与邪恶大魔王

链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid6082 Problem Description 度度熊为了拯救可爱的公主&#xff0c;于是与邪恶大魔王战斗起来。邪恶大魔王的麾下有n个怪兽&#xff0c;每个怪兽有a[i]的生命值&#xff0c;以及b[i]的防御力。度度熊一共拥有m种攻击方…

Codeforces Round #719 (A-C)

第一题题意&#xff1a;就是不能回去&#xff1a; #include<iostream> using namespace std; int main() {int t;cin>>t;while (t--){int n,ch[1001]{0};cin>>n;string str;cin>>str;bool flag true;ch[str[0]];for (int i1;i<n;i){if (str[i]!st…