java接入支付宝api实现支付宝手机扫码登录
文章目录
前言
本章将讲解java如何接入支付宝api以及实现扫码登录操作。
一、创建应用
1.登录支付宝开放平台进入管理中心
2.在控制台页面选择网页与应用并创建应用
3.输入相应的数据并创建
注意:要是没有域名的话就无法审核通过,但还可以使用支付宝沙箱来进行实现登录效果,不过只能使用沙箱提供的账号进行登录。使用沙箱的操作步骤--》
4.审核完成后就可以看到应用了
5.进入应用后在能力列表中选择以下两种能力
6.在应用信息中配置开发信息
配置应用的密钥(重要),应用私钥自己要保存好不然到时候找不到要重新配置。具体操作查看官方文档
使用沙箱的话就不用填写回调地址
7.将应用与商家账号绑定
a.选择服务管理
b.选择体验商家服务
c.进入商家中心选择账号中心
d.选择绑定appid
绑定成功后就可以无忧使用了。
二、java代码实现
1.引maven依赖
<!-- alipay -->
<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>3.1.0</version>
</dependency>
<!-- fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.48</version>
</dependency>
2.创建AliLogin.java
package com.aililogin.linux.controller;
import com.aililogin.linux.cache.Cache;
import com.alibaba.fastjson.JSON;
import com.alipay.api.AlipayApiException;
import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import com.alipay.api.request.AlipaySystemOauthTokenRequest;
import com.alipay.api.request.AlipayUserInfoShareRequest;
import com.alipay.api.response.AlipaySystemOauthTokenResponse;
import com.alipay.api.response.AlipayUserInfoShareResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@RestController
public class AilLogin {
@Autowired
private Cache cache;
//商户appid
public static String APPID = "";
//开发者私钥 pkcs8格式的
public static final String APP_PRIVATE_KEY = "";
//支付宝公钥
public static final String ALIPAY_PUBLIC_KEY = "";//请求网关地址
public static String URL = "https://openapi.alipay.com/gateway.do";
//沙箱支付网关
public static String sandbox_url = "https://openapi.alipaydev.com/gateway.do";
/**
* 支付宝登录
*
* @Param: [appAuthCode 支付宝权限code]
* @return
*/
@GetMapping("/alilogin")
public void alilogin(@RequestParam("auth_code") String appAuthCode, @RequestParam("app_id") String appId ,
@RequestParam("source") String source,HttpServletResponse httpServletResponse) throws AlipayApiException {
//使用 auth_code 换取 access_token 及用户 userId
AlipayClient alipayClient = new DefaultAlipayClient(URL, appId, APP_PRIVATE_KEY, "json", "utf-8", ALIPAY_PUBLIC_KEY, "RSA2");
AlipaySystemOauthTokenRequest request = new AlipaySystemOauthTokenRequest();
request.setCode(appAuthCode);
request.setGrantType("authorization_code");
try {
AlipaySystemOauthTokenResponse oauthTokenResponse = alipayClient.execute(request);
//调用接口获取用户信息
AlipayClient alipayClient2 = new DefaultAlipayClient(
URL, appId, APP_PRIVATE_KEY, "json", "utf-8",
ALIPAY_PUBLIC_KEY,"RSA2");
AlipayUserInfoShareRequest request2 = new AlipayUserInfoShareRequest();
String token =oauthTokenResponse.getAccessToken();
System.out.println(token);
AlipayUserInfoShareResponse response = alipayClient2.execute(request2, token);
if (response.isSuccess()) {
System.out.println("调用成功"); System.out.println(ReflectionToStringBuilder.toString(response));
} else {
System.out.println("调用失败");
System.out.println(response.getSubCode() + ":" + response.getSubMsg());
}
} catch (AlipayApiException | IOException e) {
//处理异常
e.printStackTrace();
}
}
}
}
三.测试
1.拼接授权页面url
https://openauth.alipay.com/oauth2/publicAppAuthorize.htm?app_id=商户的APPID&scope=auth_user&redirect_uri=ENCODED_URL&state=init
注意:
• url 中的 app_id 参数是商户实际使用的 appId。
• scope 参数传递 auth_user。
• redirect_uri 为页面跳回地址(重定向地址)。
• state 为商户自定义参数。
参考官方文档
沙箱注意事项
使用沙箱的url为https://openauth.alipaydev.com/oauth2/publicAppAuthorize.htm?app_id=商户的APPID&scope=auth_user&redirect_uri=ENCODED_URL&state=init
appid为沙箱的appid;
公钥和私钥也是沙箱的;
回调地址可以自定义本地地址例如:http://localhost:8080/alilogin
使用沙箱时将网关切换为沙箱网关
//沙箱支付网关
public static String sandbox_url = "https://openapi.alipaydev.com/gateway.do";
//原网关
public static String URL = "https://openapi.alipay.com/gateway.do";