Java接入支付宝授权第三方登录的完整步骤
作者:不知所终,不知所起 发布时间:2023-01-05 01:13:54
标签:java,支付宝,授权
开发前准备
支付宝开发平台.
支付宝沙箱环境申请使用
!!!重点 授权回调地址必须要写全路径也就是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


猜你喜欢
- 实现上位机和下位机之间的通信,通常使用的是串口通信,接下来实现一个通过上位机和串口调试助手来完成串口通信测试。首先创建一个WInfrom窗体
- 1.启动项目的时候报错1.Error starting ApplicationContext. To display the auto-co
- 背景在使用Spring Boot Mvc的项目中,使用Long类型作为id的类型,但是当前端使用Number类型接收Long类型数据时,由于
- 简介 相信很多人都接触spring框架很长时间了,每次搭建spring框架的时候都需要配置好多的jar、xml,做很多繁琐重复的配置,稍微不
- 波浪球的效果一直都是想模仿的对象,在最近一段时间里模仿了这一界面,其实所用知识并不多。1)、波浪的效果是利用三角函数来实现的,在自定义vie
- 本文实例讲述了如何计算(或者说,估算)一个Java对象占用的内存数量的方法。分享给大家供大家参考。具体分析如下:通常,我们谈论的堆内存使用的
- 1. 测试用例我们以sentinel-demo中的sentinel-annotation-spring-aop为例,分析sentinel的源
- C#动态创建lambda表达式近日在使用了一下EF框架,在做多条件where查询的时候不知道怎么做,网上找了找,一开始用context.Da
- 一:算术运算符1.算术运算符有哪些①基本四则运算符:+ - * / %②增量赋值运算符:+= -= *= /= %=③自增/自减运算符++
- 展示图: 对接的完整流程如下首先是配置gzh.appid=公众号appidwxPay.mchId=商户号wxPay.key=支付密
- 什么是Java泛型Java 泛型(generics)是 Jdk 5 中引入的一个新特性, 泛型提供了编译时类型安全检测机制, 该机制允许程序
- 1. 概述锁是Java并发编程中最重要的同步机制。锁除了让临界区互斥执行外,还可以让释放锁的线程获取同一个锁的线程发送消息。锁在实际使用时只
- " 梧桐更兼细雨,到黄昏、点点滴滴。"C语言朱武大战数据结构专栏C语言植物大战数据结构快速排序图文示例C语言植物大战数据
- 本文主要介绍了关于单例模式的一些问题,想学习C#单例模式的同学们可以看一看,还是有些帮助c#中的单例模式单例模式是指在设计一个类时,保证在运
- 前言初识Android PowerManagerService省电模式 让我们省电模式的概念有了初步的认识,Androi
- Json 是一个用于 Java 对象 和 Json 文本 相互转换的工具类。安装下载源码g
- 其实这个比较简单,子线程怎么通知主线程,就是让子线程做完了自己的事儿就去干主线程的转回去干主线程的事儿。那么怎么让子线程去做主线程的事儿呢,
- 每天上下楼都是乘坐电梯的,就想电梯的工作原理是什么呢?于是自己写了个控制台程序来模拟一下电梯的工作原理!采用面向对象的编程思想!将电梯拆解为
- 一、概述Overview - LINQ to XML | Microsoft 官方文档LINQ to XMLLINQ to XML 是一种启
- 简介本次五子棋使用的是光标控制移动,通过按空格键(键值32)来落子,实现游戏的。我们额外用到的头文件有:#include<getch.