微信第三方登录,超详细,傻瓜式教学

微信三方
获取登陆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等工具测试(完事儿!)
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java2_ben

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值