Java接入支付宝授权第三方登录的完整步骤
作者:不知所终,不知所起 时间:2023-01-05 01:13:54
开发前准备
支付宝开发平台.
支付宝沙箱环境申请使用
!!!重点 授权回调地址必须要写全路径也就是controller最终路径(下面有具体细节)
RSA2的密钥生成: 支付宝提供生成密钥地址.
获取用户授权
生成唤起支付宝授权连接
用到appid+回调路径 回调路径=在上面配置的全路径 具体路径:
https://openauth.alipay.com/oauth2/publicAppAuthorize.htm?
app_id=2016####&scope=auth_user&edirect_uri=http://ip | 域名 + 接口地址
也可以使用自定义参数的连接:
https://openauth.alipay.com/oauth2/publicAppAuthorize.htm?app_id=2016####
&state=自定义参数(多个用逗号拼接)&scope=auth_user&edirect_uri=http://ip | 域名 + 接口地址
具体怎么用??? 在线生成二维码用支付宝沙箱app扫码
回调地址接收支付宝参数
构建请求支付宝客户端
yml:
# 支付宝配置
ali:
appId: 2016####
# 自己的私钥
merchantPrivateKey: 连接生成的私钥
# 支付宝公钥
alipayPublicKey: 链接生成的公钥配置后支付宝给到的支付宝公钥
# 签名方式
signType: RSA2
# 字符编码格式
charset: UTF-8
# 字符编码格式
format: json
# 支付宝网关 https://openapi.alipay.com/gateway.do 是正式的
gatewayUrl: https://openapidev.alipay.com/gateway.do #dev是沙箱
Property:
import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
/**
* 支付宝配置
*/
@Data
@Component
@ConfigurationProperties(prefix = "ali")
public class AliPayProperty {
/**
* 支付宝APPID
*/
public String appId;
/**
* 商户私钥,您的PKCS8格式RSA2私钥
*/
public String merchantPrivateKey ;
/**
* 支付宝公钥,查看地址:https://openhome.alipay.com 对应APPID下的支付宝公钥。
*/
public String alipayPublicKey;
/**
* 接口格式规范
*/
public String format;
/**
* 签名方式
*/
public String signType;
/**
* 字符编码格式
*/
public String charset;
/**
* 支付宝网关 https://openapi.alipay.com/gateway.do 这是正式地址
*/
public String gatewayUrl;
/**
* 支付宝客户端
* @return
*/
public AlipayClient getAlipayClient(){
AlipayClient alipayClient = new DefaultAlipayClient(
this.gatewayUrl,
this.appId,
this.merchantPrivateKey,
this.format,
this.charset,
this.alipayPublicKey,
this.signType);
return alipayClient;
}
}
业务流程代码
controller:
@GetMapping(value = "/loginCallBack")
public String loginCallBack(HttpServletRequest request){
return aliPayService.loginCallBack(request);
}
service:
public String loginCallBack(HttpServletRequest request){
//获取用户扫码授权的参数
Map<String,String> map = this.getAliPayParam(request);
//获取用户扫码后的code
String code = map.get("auth_code");
//构建阿里客户端
AlipayClient alipayClient = aliPayProperty.getAlipayClient();
//获取阿里用户token
AlipaySystemOauthTokenResponse aliUserToken =
this.getAliUserToken(code, alipayClient,0);
//获取用户信息
AlipayUserInfoShareResponse infoShareResponse =
this.getUserInfo(alipayClient, aliUserToken, 0);
//!!!沙箱环境用户没有这些基本信息但是可以看到支付宝接口是成功的
return "SUECCSS";
}
封装接收参数方法:
public Map<String,String> getAliPayParam(HttpServletRequest request) {
Map<String,String> map = new HashMap();
Map<String, String[]> requestParams = request.getParameterMap();
for (Iterator<String> iter = requestParams.keySet().iterator(); iter.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) requestParams.get(name);
String valueStr = "";
for (int i = 0; i < values.length; i++) {
valueStr = (i == values.length - 1) ? valueStr + values[i] : valueStr + values[i] + ",";
}
// 乱码解决,这段代码在出现乱码时使用
// valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
map.put(name, valueStr);
log.info("接受支付宝回调参数:{}",map);
}
return map;
}
获取token方法:
private AlipaySystemOauthTokenResponse getAliUserToken(String code, AlipayClient alipayClient,int number) throws AlipayApiException {
AlipaySystemOauthTokenRequest alipaySystemOauthTokenRequest = new AlipaySystemOauthTokenRequest();
alipaySystemOauthTokenRequest.setGrantType("authorization_code");
alipaySystemOauthTokenRequest.setCode(code);
AlipaySystemOauthTokenResponse oauthTokenResponse = alipayClient.execute(alipaySystemOauthTokenRequest);
log.info("获得用户+++++++++++++++token:{}+++++++++++++++",oauthTokenResponse.getAccessToken());
log.info("获得用户+++++++++++++++uuid:{}+++++++++++++++",oauthTokenResponse.getUserId());
if(oauthTokenResponse.isSuccess()){
log.info("成功");
} else {
log.info("***********失败,自旋开始第:{}次",number);
number += 1;
if(number < 3){
log.info("获取token失败,尝试:*******{}*******",number);
return this.getAliUserToken(apiPayLoginReq, alipayClient, number);
}
}
return oauthTokenResponse;
}
获取用户支付宝信息方法:
private AlipayUserInfoShareResponse getUserInfo(AlipayClient alipayClient,AlipaySystemOauthTokenResponse aliUserToken,int number) throws AlipayApiException {
AlipayUserInfoShareRequest alipayUserInfoShareRequest = new AlipayUserInfoShareRequest();
AlipayUserInfoShareResponse infoShareResponse = alipayClient.execute(alipayUserInfoShareRequest,aliUserToken.getAccessToken());
log.info("----------------获得支付宝用户详情:{}",infoShareResponse.getBody());
UserInfoReq userInfoReq = new UserInfoReq();
if(infoShareResponse.isSuccess()){
//用户授权成功
log.info("----------------获得支付宝用户基本而信息:{}",userInfoReq);
log.info("成功");
} else {
log.info("***********失败,自旋开始第:{}次",number);
number += 1;
if(number < 3){
log.info("调用用户详情失败,尝试:*******{}*******",number);
return this.getUserInfo(alipayClient,aliUserToken,number);
}
return infoShareResponse ;
}
}
串业务
用户扫码后后会跳到你配置的回调地址上!!!但是因为代码中返回是success,用户收到的只是个字符串。所以此处因该是配置支付宝去回调前端地址 然后参数让前端原封不动传向后端 后端解析成功后,前端引导用户进行下一步操作
总结
来源:https://blog.csdn.net/weixin_44440642/article/details/117906000
标签:java,支付宝,授权
0
投稿
猜你喜欢
C#实现文件上传与下载功能实例
2022-11-18 07:59:03
详解App保活技术实现
2023-05-24 18:06:26
Java实现二分查找的变种
2023-11-07 11:26:28
Android App应用启动分析与优化
2023-06-09 01:08:11
android编程实现图片库的封装方法
2023-12-20 07:51:27
springboot项目中使用Swagger的简单示例
2023-01-14 05:18:24
C#实现组合排列的方法
2021-10-04 02:25:01
在Kotlin开发中如何使用集合详解
2022-03-06 02:22:30
Java实现考试系统
2023-11-18 04:15:03
SpringBoot中使用 RabbitMQ的教程详解
2023-10-22 01:02:42
一文带你全面了解Java Hashtable
2021-09-19 01:39:39
Android 动画之RotateAnimation应用详解
2022-08-17 17:03:07
c# 删除所有的空文件夹的小例子
2023-09-10 06:53:44
Linux下用java -jar运行可执行jar包的方法教程
2022-11-24 18:01:46
C#实现实体类和XML相互转换
2023-06-16 04:37:32
formfile文件上传使用示例
2023-06-23 03:41:58
C#中字符串编码处理
2023-10-03 09:56:12
Android 高仿微信语音聊天页面高斯模糊(毛玻璃效果)
2021-09-27 18:56:46
c#接口使用示例分享
2022-02-22 17:38:46
C#使用SQL Dataset数据集代码实例
2023-02-24 08:23:07