Android (微信扫码登录) 获取微信二维码+扫码登录
话不多说 直接上菜!
一.因为是微信扫码登录,所有要在微信开放平台 微信开放平台 (qq.com) 进行注册----- 如下
1.资源中心 里面也有详细的官方讲解,里面也有demo 可以下载


2.在 管理中心 创建应用 填写一系列的信息

3. 提交审核,大概需要三到五天的时间审核完成;
4. 审核完成微信开放平台会生成一个appid,和sercet 这两个是唯一的id 需要妥善保管;
5. 按照微信开放平台给的文档,下载相应的sdk以及签名工具,在此强调 必须是用签名打包的正式版的apk才可以调起微信的客户端进行授权登录,必须保证应用的签名(用签名工具可以获取)和开放平台上填写的信息一致。 签名工具获取----》首页-----》资源中心---》资源下载



二.代码部分
1、依赖:在app build.gradle 中添加
implementation ‘com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+’
implementation 'com.google.code.gson:gson:2.8.5'
2.我用的是HTTP 请求 当然也可以用OKHTTP 会更简单一些
新建 HttpsUtils 类库,写里面的 submitGetData 方法如下:
/**
* 使用GET方法读取http中的数据
*
* @param strUrlPath url地址
* @return 请求的响应数据
*/
public static String submitGetData(String strUrlPath, @NonNull Map<String, String> requestPropertys) throws Exception {
// 创建URL对象
URL url = new URL(strUrlPath);
// 打开连接 获取连接对象
URLConnection connection = url.openConnection();
connection.setConnectTimeout(6000);
if (requestPropertys != null) {
//设置 安卓端flag
for (Map.Entry<String, String> entry : requestPropertys.entrySet()) {
connection.setRequestProperty(entry.getKey(), entry.getValue());
}
}
// 从连接对象中获取网络连接中的输入字节流对象
InputStream inputStream = connection.getInputStream();
// 将输入字节流包装成输入字符流对象,并进行字符编码
InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "UTF-8");
// 创建一个输入缓冲区对象,将字符流对象传入
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
// 定义一个字符串变量,用来接收输入缓冲区中的每一行字符串数据
String line;
// 创建一个可变字符串对象,用来装载缓冲区对象的数据,使用字符串追加的方式,将响应的所有数据都保存在该对象中
StringBuilder stringBuilder = new StringBuilder();
// 使用循环逐行读取输入缓冲区的数据,每次循环读入一行字符串数据赋值给line字符串变量,直到读取的行为空时标识内容读取结束循环
while ((line = bufferedReader.readLine()) != null) {
// 将从输入缓冲区读取到的数据追加到可变字符对象中
stringBuilder.append(line);
}
// 依次关闭打开的输入流
bufferedReader.close();
inputStreamReader.close();
inputStream.close();
// 将可变字符串转换成String对象返回
return stringBuilder.toString();
}
3.把申请出来的appID,secret 放在新建的Constant类中

4.我们回到 MainActivity中
//定义变量
private ImageView IvWeChat; //显示 二维码的图片控件
IDiffDevOAuth oauth;
String noncestr;
String timeStamp;
String sha;
Toast mToast;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
oauth = DiffDevOAuthFactory.getDiffDevOAuth(); //添加
IvWeChat = (ImageView) findViewById(R.id.iv_wxm);
ConnectWechat();
}
//回调
OAuthListener mOAuthListener = new OAuthListener() {
@Override
public void onAuthGotQrcode(String s, byte[] bytes) {
Log.e(TAG, "onAuthGotQrcode: ");
IvWeChat.setImageBitmap(null);
Bitmap bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length, new BitmapFactory.Options());
IvWeChat.setImageBitmap(bitmap);
}
@Override
public void onQrcodeScanned() {
}
@Override
public void onAuthFinish(OAuthErrCode oAuthErrCode, String s) {
Log.e(TAG, "onAuthFinish: ");
if (oAuthErrCode == OAuthErrCode.WechatAuth_Err_OK) {
new Thread(new Runnable() {
@Override
public void run() {
try {
String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + Constant.WECHAT_APPID + "&secret=" + Constant.WECHAT_SECRET + "&code=" + s + "&grant_type=authorization_code";
Log.e(TAG, "onAuthFinish: url: " + url);
String res = HttpsUtils.submitGetData(url, null);
Log.e(TAG, "服务器返回: " + res);
JSONObject jsonObject = new JSONObject(res);
String openid = jsonObject.getString("openid");
String access_token = jsonObject.getString("access_token");
url = "https://api.weixin.qq.com/sns/userinfo?access_token=" + access_token + "&openid=" + openid;
res = HttpsUtils.submitGetData(url, null);
Log.e(TAG, "服务器返回: " + res);
jsonObject = new JSONObject(res);
String unionid = jsonObject.getString("unionid");
openid = jsonObject.getString("openid");
String nickName = jsonObject.getString("nickname");
int sex = jsonObject.getInt("sex");
String headimgurl = jsonObject.getString("headimgurl");
String language = jsonObject.getString("language");
String city = jsonObject.getString("city");
String province = jsonObject.getString("province");
String country = jsonObject.getString("country");
JSONArray privilege = jsonObject.getJSONArray("privilege");
Log.e(TAG, "unionid: " + unionid);
Log.e(TAG, "openid: " + openid);
Log.e(TAG, "nickName: " + nickName);
Log.e(TAG, "sex: " + sex);
Log.e(TAG, "headimgurl: " + headimgurl);
Log.e(TAG, "language: " + language);
Log.e(TAG, "city: " + city);
Log.e(TAG, "province: " + province);
Log.e(TAG, "country: " + country);
Log.e(TAG, "privilege: " + privilege);
runOnUiThread(new Runnable() {
@Override
public void run() {
//扫码成功 然后跳转
startActivity(new Intent(此页面.this, 想要跳转的页面.class));
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
} else if (oAuthErrCode == OAuthErrCode.WechatAuth_Err_Timeout) {
showTip("二维码已过期,请点击刷新"); //这个是提示 也可以用 吐司
//Toast.makeText()
} else if (oAuthErrCode == OAuthErrCode.WechatAuth_Err_Cancel) {
showTip("没有授权返回在刷新一下二维码");
} else if (oAuthErrCode == OAuthErrCode.WechatAuth_Err_NetworkErr) {
showTip("网络错误");
}
}
};
/**
* 获取access_token
*
* @param
*/
private void ConnectWechat() {
new Thread(new Runnable() {
@Override
public void run() {
try {
String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + Constant.WECHAT_APPID + "&secret=" + Constant.WECHAT_SECRET;
Log.e(TAG, "url_1: " + url);
String res = HttpsUtils.submitGetData(url, null);
Log.e(TAG, "服务器返回: " + res);
//获取access_token
String access_token = new JSONObject(res).getString("access_token");
url = "https:api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + access_token + "&type=2";
Log.e(TAG, "url_2: " + url);
res = HttpsUtils.submitGetData(url, null);
Log.e(TAG, "服务器返回: " + res);
String ticket = new JSONObject(res).getString("ticket");
StringBuilder str = new StringBuilder();// 定义变长字符串
// 随机生成数字,并添加到字符串
for (int i = 0; i < 8; i++) {
str.append(new Random().nextInt(10));
}
noncestr = str.toString();
timeStamp = Long.toString(System.currentTimeMillis()).substring(0, 10);
String string1 = String.format("appid=%s&noncestr=%s&sdk_ticket=%s×tamp=%s", Constant.WECHAT_APPID, noncestr, ticket, timeStamp);
sha = EncryptUtils.getSHA(string1);
Log.e(TAG, "二维码验证方式" + sha);
oauth.auth(Constant.WECHAT_APPID, "snsapi_userinfo", noncestr, timeStamp, sha, mOAuthListener);
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
}
//重写onDestroy
@Override
protected void onDestroy() {
super.onDestroy();
//二维码登录
oauth.removeAllListeners();
oauth.stopAuth();
}
//OK,到这里呢,就结束了!
//兄弟们,加油,干就完了,奥里给!没有什么能阻挡我们前进的步伐。
Android (微信扫码登录) 获取微信二维码+扫码登录的更多相关文章
- PHP开发微信公众号(一)二维码的获取
要开发微信公众号,首先进行需要注册一个,然后认证.这就不用多说了. 当然如果没有,也可以去申请一个测试号来使用,地址:https://mp.weixin.qq.com/debug/cgi-bin/sa ...
- 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-7.授权登录获取微信用户个人信息实战
笔记 7.授权登录获取微信用户个人信息实战 简介:讲解使用授权码code获取用户个人信息接口 关键点:看微信文档,字段尽量用拷贝 1.通过code获取access_token ...
- .net Core 调用微信Jsapi接口,H5解析二维码
项目里需要用到扫描二维码,自己实现,不会. 找到了两种解决方案: 通过reqrcode.js,这是一个前端解析二维码内容的js库.如果二维码比较清晰,用这种效果也不错 调用微信扫一扫功能,这种效果很好 ...
- 微信内点击链接或扫描二维码可直接用外部浏览器打开H5链接的解决方案
很多朋友问我怎么解决微信内点击链接或扫描二维码可以直接跳出微信在外部浏览器打开网页链接,其实这并不难,只要我们使用微信跳转浏览器接口实现跳转功能即可. 简单的处理方案 1. 用浏览器打开我们需要用到的 ...
- 微信小程序动态生成保存二维码
起源:最近小程序需要涉及到一些推广方面的功能,所以要写一个动态生成二维码用户进行下载分享,写完之后受益良多,特此来分享一下: 一.微信小程序动态生成保存二维码 wxml: <view class ...
- Android生成二维码--保存和分享二维码图片
之前写过生成自定义二维码的两篇文章:<Android生成自定义二维码><Android生成二维码–拍照或从相册选取图片>,下面就介绍一下Android应用内如何保存以及分享二维 ...
- day111:MoFang:邀请好友流程&生成邀请好友二维码&第三方应用识别二维码&本地编译测试&记录邀请人信息
目录 1.邀请业务逻辑流程图 2.邀请好友-前端 3.邀请好友-后端接口(生成二维码) 4.前端获取后端生成的二维码 5.前端长按页面,保存图片到相册 6.客户端通过第三方识别微信二维码,服务端提供对 ...
- 二维码相关---java生成二维码名片,而且自己主动保存到手机通讯录中...
版权声明:本文为博主原创文章,未经博主credreamer 同意不得转载 违者追究法律责任. https://blog.csdn.net/lidew521/article/details/244418 ...
- QR二维码生成器源码(中间可插入小图片)
二维码终于火了,现在大街小巷大小商品广告上的二维码标签都随处可见,而且大都不是简单的纯二维码,而是中间有个性图标的二维码. 我之前做了一个使用google开源项目zxing实现二维码.一维码编码解码的 ...
- Swift3.0生成二维码、扫描二维码、相册读取二维码,兼容iOS7(结合ZXingObjC)
二维码生成 //MARK: 传进去字符串,生成二维码图片(>=iOS7) text:要生成的二维码内容 WH:二维码高宽 private func creatQRCodeImage(text: ...
随机推荐
- 安卓记账本开发学习day1
学习了一些简单的布局与界面设计
- python爬虫---字体反爬
目标地址:http://glidedsky.com/level/web/crawler-font-puzzle-1 打开google调试工具检查发现网页上和源码之中的数字不一样, 已经确认该题目为 字 ...
- Java语言学习day04--7月1日
###09数据类型转换_自动转换 * A: 自动类型转换 * a:表示范围小的数据类型转换成范围大的数据类型,这种方式称为自动类型转换 自动类型转 ...
- Java语言学习day28--8月03日
###10接口作为方法参数与返回值 * A: 接口作为方法参数 接口作为方法参数的情况是很常见的,经常会碰到.当遇到方法参数为接口类型时,那么该方法要传入一个接口实现类对象.如下代码演示. //接 ...
- 2021.12.21 eleveni的刷题记录
2021.12.21 eleveni的刷题记录 0. 有意思的题 P6701 [POI1997] Genotype https://www.luogu.com.cn/problem/P6701 状压优 ...
- 论文解读(CGC)《CGC: Contrastive Graph Clustering for Community Detection and Tracking》
论文信息 论文标题:CGC: Contrastive Graph Clustering for Community Detection and Tracking论文作者:Namyong Park, R ...
- python学习-Day33
目录 今日内容详细 socket socket套接字简介 socket模块 服务端 客户端 通信循环 服务端 客户端 链接循环 半连接池 概念 产生半连接的两种情况 黏包问题 多次发送被并为一次 TC ...
- 斯坦福NLP课程 | 第2讲 - 词向量进阶
作者:韩信子@ShowMeAI,路遥@ShowMeAI,奇异果@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/36 本文地址:http://www. ...
- LeetCode数组刷题——448、48、240、769
1.[LeetCode448]:448. 找到所有数组中消失的数字 题目分析: 1-n之间有重复的,有没出现的,有出现一次.使用hashmap,空间复杂度为O(n) 方法一:哈希表,但是空间复杂度超过 ...
- Blazor Hybrid / MAUI 简介和实战
1. Blazor Blazor 是一个使用 .NET 生成交互式客户端 Web UI 的框架: 使用 C# 代替 JavaScript 来创建信息丰富的交互式 UI. 共享使用 .NET 编写的服务 ...