1.支付宝授权登录,获取用户信息:
那些导入SDK和配置设置的就不一一讲了,参照官方文档配置即可参照这里,下面主要说关键的代码处理。
1.首先要让后台服务端将拼接好的infoStr信息,通过接口方式获取得到,这个后端处理。不能放在前段不安全。
2.用得到的infoStr信息调用支付宝SDK授权获取AuthCode。
3.用得到的AuthCode去获取用户信息。
以下是关键代码:
//获取AuthCode
private void getAlipayUserData() {
if (Constant.ALIPAY_ID.equals("")) {
toast("支付宝sdk未初始化完成,请稍后再试");
} else {
getAuthInfo(authInfo);
}
}
private void getAuthInfo(String alipay_auth_info) {
Runnable authRunnable = new Runnable() {
@Override
public void run() {
// 构造AuthTask 对象
AuthTask authTask = new AuthTask(ImpowerActivity.this);
// 调用授权接口,获取授权结果
Map<String, String> result = authTask.authV2(authInfo, true);
Message msg = new Message();
msg.what = SDK_AUTH_FLAG;
msg.obj = result;
mHandler.sendMessage(msg);
}
};
// 必须异步调用
Thread authThread = new Thread(authRunnable);
authThread.start();
}
//调用支付宝SDK获取authcode;
@SuppressLint("HandlerLeak")
private Handler mHandler = new Handler() {
@SuppressWarnings("unused")
public void handleMessage(Message msg) {
switch (msg.what) {
case SDK_AUTH_FLAG: {
@SuppressWarnings("unchecked")
AuthResult authResult = new AuthResult((Map<String, String>) msg.obj, true);
String resultStatus = authResult.getResultStatus();
// 判断resultStatus 为“9000”且result_code
// 为“200”则代表授权成功,具体状态码代表含义可参考授权接口文档
if (TextUtils.equals(resultStatus, "9000") && TextUtils.equals(authResult.getResultCode(), "200")) {
toast("授权成功");
// 获取alipay_open_id,调支付时作为参数extern_token 的value, 传入,则支付账户为该授权账户
//开发者自己的方法,把code传给后台同事,他们拿code换token,这里是后台自己去获取用户信息
auth_code = authResult.getAuthCode();
if (auth_code != null) {
getAlipayBinDingInfo();
}
} else {
// 其他状态值则为授权失败
if (TextUtils.isEmpty(authResult.getAuthCode())) {
toast("授权取消");
} else {
toast(String.format("授权失败_authCode:%s", authResult.getAuthCode()));
}
}
break;
}
default:
break;
}
}
};
public static class AuthResult {
private String resultStatus;
private String result;
private String memo;
private String resultCode;
private String authCode;
private String alipayOpenId;
public AuthResult(Map<String, String> rawResult, boolean removeBrackets) {
if (rawResult == null) {
return;
}
for (String key : rawResult.keySet()) {
if (TextUtils.equals(key, "resultStatus")) {
resultStatus = rawResult.get(key);
} else if (TextUtils.equals(key, "result")) {
result = rawResult.get(key);
} else if (TextUtils.equals(key, "memo")) {
memo = rawResult.get(key);
}
}
String[] resultValue = result.split("&");
for (String value : resultValue) {
if (value.startsWith("alipay_open_id")) {
alipayOpenId = removeBrackets(getValue("alipay_open_id=", value), removeBrackets);
continue;
}
if (value.startsWith("auth_code")) {
authCode = removeBrackets(getValue("auth_code=", value), removeBrackets);
continue;
}
if (value.startsWith("result_code")) {
resultCode = removeBrackets(getValue("result_code=", value), removeBrackets);
continue;
}
}
}
private String removeBrackets(String str, boolean remove) {
if (remove) {
if (!TextUtils.isEmpty(str)) {
if (str.startsWith("\"")) {
str = str.replaceFirst("\"", "");
}
if (str.endsWith("\"")) {
str = str.substring(0, str.length() - 1);
}
}
}
return str;
}
@Override
public String toString() {
return "resultStatus={" + resultStatus + "};memo={" + memo + "};result={" + result + "}";
}
private String getValue(String header, String data) {
return data.substring(header.length(), data.length());
}
/**
* @return the resultStatus
*/
public String getResultStatus() {
return resultStatus;
}
/**
* @return the memo
*/
public String getMemo() {
return memo;
}
/**
* @return the result
*/
public String getResult() {
return result;
}
/**
* @return the resultCode
*/
public String getResultCode() {
return resultCode;
}
/**
* @return the authCode
*/
public String getAuthCode() {
return authCode;
}
/**
* @return the alipayOpenId
*/
public String getAlipayOpenId() {
return alipayOpenId;
}
}