微信三方
获取登陆openid的方法
温馨提示:请先申请下来您的公众号和域名
微信开发文档
一:java代码
1.导入依赖
<dependency>
<groupId>com.github.wxpay</groupId>
<artifactId>wxpay-sdk</artifactId>
<version>0.0.3</version>
</dependency>
2.自己写的单例模式(单纯的用于获取各种参数)
public class WXPayConfigImpl implements WXPayConfig {
private byte[] cerData;
private static WXPayConfigImpl INSTANCE;
public static WXPayConfig getInstance() {
if (INSTANCE == null) {
synchronized (WXPayConfigImpl.class){
if (INSTANCE == null){
INSTANCE = new WXPayConfigImpl();
}
}
}
return INSTANCE;
}
@Override
public String getAppID() { //公众号id
return "";
}
@Override //商户号
public String getMchID() { //商户号id
return "";
}
@Override
public String getKey() { //支付密钥
return "";
}
@Override
public InputStream getCertStream() {
return null;
}
@Override
public int getHttpConnectTimeoutMs() {
return 10000;
}
@Override
public int getHttpReadTimeoutMs() {
return 10000;
}
public int getHttpReadTimeoutM() {
return 10000;
}
public String getNotifyUrl(){ //支付回掉接口
return "";
}
//密钥
public String getAppSecret() {
return "";
}
public String getRedirectUri(){ //登陆回掉获取openId
return "";
}
}
3.自己写的登录(自己的逻辑要脸无勿喷,感恩家银)
前后端跨域问题链接
WxAPI下载链接 & 提取码:ubyu
ps:MallClient是我自己写的实体类,详情请看第3.1,JWTUtil3.2,
有可能遇到存储问题(有些人的微信名称中可能有Emoji图片)
Incorrect string value: ‘\xF0\x9F\x98\x82’ for column ‘name’ at row 1,请点击下方链接
Incorrect string value:解决
/**
* 登录
* @param code 用户携带的code
* @return
* @throws Exception
*/
@PostMapping("/login")
public AjaxJson login(String code,HttpSession session) {
AjaxJson result = new AjaxJson();
try {
if(StringUtils.isEmpty(code)){
result.setMsg("code为空");
result.setErrorCode("0");
return result;
}
//微信支付配置
WXPayConfig instance = WXPayConfigImpl.getInstance();
String appID = instance.getAppID();
String key = instance.getKey();
//获取token
String url = WxApi.getOAuthTokenUrl(appID, key, code);
JSONObject jsonObject = WxApi.httpsRequest(url, HttpMethod.POST);
String access_token = (String) jsonObject.get("access_token");
System.out.println("access_token:"+access_token);
String scope = (String) jsonObject.get("scope");
System.out.println("scope:"+scope);
String openid = (String) jsonObject.get("openid");
System.out.println("openid:"+openid);
if(StringUtils.isEmpty(openid)){
result.setMsg("公众号错误");
result.setErrorCode("0");
return result;
}
String userinfoUrl = WxApi.getOAuthUserinfoUrl(access_token, openid);
JSONObject userInfoUrlMap = WxApi.httpsRequest(userinfoUrl, HttpMethod.POST);
//获取微信昵称
String nickname = (String) userInfoUrlMap.get("nickname");
//获取微信头像
String headimgurl = (String) userInfoUrlMap.get("headimgurl");
//将openID存在token中,传给前端
String token = JWTUtil.createJwt(openid);
result.put("token",token);
// String openid = "123456";
//将openID存在session中
session.setAttribute("openid",openid);
//判断openID是否获取到用户
MallClient mallClient = apiMallClientService.getUserByOpenid(openid);
result.setMsg("登录成功");
result.setErrorCode("1");
if(mallClient != null){
result.put("data",mallClient);
return result;
}
mallClient = new MallClient();
mallClient.setName(nickname);
mallClient.setHeadPortrait(headimgurl);
mallClient.setOpenId(openid);
mallClient.setId(IdGen.uuid());
mallClient.setPhoneNum("");
//存储错误
int i = apiMallClientService.save(mallClient);
if(i<0){
result.setMsg("系统内部错误,请联系客服");
result.setErrorCode("0");
return result;
}
result.put("data",mallClient);
return result;
} catch (Exception e) {
e.printStackTrace();
//未知异常
result.setMsg("连接超时,请重试");
result.setErrorCode("0");
System.out.println("系统内部错误,请联系客服");
return result;
}
}
3.1MallClient实体类(Dao和Service层还是各位自己写吧就不放了)
public class MallClient extends DataEntity<MallClient> {
private static final long serialVersionUID = 1L;
private String id;
private String openId; // 微信用户的openid
private String name; // 昵称
private String phoneNum; // 手机号
private String headPortrait; // 头像
public MallClient() {
super();
}
public String getId() {
return id;
}
public void setId(String id) {
this.id= id;
}
public String getOpenId() {
return openId;
}
public void setOpenId(String openId) {
this.openId = openId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhoneNum() {
return phoneNum;
}
public void setPhoneNum(String phoneNum) {
this.phoneNum = phoneNum;
}
public String getHeadPortrait() {
return headPortrait;
}
public void setHeadPortrait(String headPortrait) {
this.headPortrait = headPortrait;
}
}
3.2JWTUtil
pom依赖:
<dependency>
<groupId>com.auth0</groupId>
<artifactId>java-jwt</artifactId>
<version>3.2.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt -->
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>0.7.0</version>
</dependency>
java代码:
public class JWTUtil {
@Autowired
static Jedis jedis;
//自己随便写一个盐
public static String key = "asdadsadasdaca1014140";
public static String createJwt(String userId){
//默认签发有效期30天
return createJwt(userId,"subject","issure",2592000000l);
}
public static String createJwt(String id, String subject, String issure, long till) {
JwtBuilder jwtBuilder = Jwts.builder().setId(id)
.signWith(SignatureAlgorithm.HS256, new SecretKeySpec(DatatypeConverter.parseBase64Binary(key), SignatureAlgorithm.HS256.getJcaName()))
.setIssuer(issure)
.setSubject(subject)
.setExpiration(new Date(System.currentTimeMillis() + till));
return jwtBuilder.compact();
}
public static String parseJwt(HttpServletRequest request) {
Claims claims = null;
try {
claims = Jwts.parser().setSigningKey(DatatypeConverter.parseBase64Binary(key)).parseClaimsJws(request.getHeader("token")).getBody();
String userId = claims.getId();
/* String token = jedis.get(userId);
if(!token.equals(request.getHeader("token"))){
return null;
}*/
return claims.getId();
} catch (Exception e) {
return null;
}
}
}
二:获取openid
1:获取code(前台获取,传给后台)
微信点击获取,
https://open.weixin.qq.com/connect/oauth2/authorize?appid=你的AppID&redirect_uri=http%3a%2f%2fwww.你申请的域名.com%2fapi&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect
1.第一步,点击链接
.
2.第二步,单击后等待这个页面变为404(测试阶段)
3.点击复制链接
http://www.你的域名.com/api?code=011nDhfU1YGRVZ0A9zhU1sNxfU1nDhfb&state=STATE
4.拿到第三步的code的值去postman等工具测试(完事儿!)