91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

實現網站微信登錄

發布時間:2020-07-16 11:04:22 來源:網絡 閱讀:160 作者:qq5ccfe88de5ba6 欄目:編程語言

先閱讀微信官方文檔
https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html

1.事先準備
網站應用微信登錄是基于OAuth3.0協議標準構建的微信OAuth3.0授權登錄系統。 在進行微信OAuth3.在進行微信OAuth3.0授權登錄接入之前,在微信開放平臺注冊開發者帳號,并擁有一個已審核通過的網站應用,并獲得相應的AppID和AppSecret,申請微信登錄且通過審核后,可開始接入流程。

2.編輯yml文件以及config文件 用于獲取配置值
application.yml文件添加以下配置
wxopen:
appid: wx025575xx69a2d5b
appsecret: deeae310axxxfa9d3e8f3
redirect_url: http://fde9ab75.ngrok.io/api/v1/wechat/user/callback #回調地址 域名開放平臺設置

其中appid就是申請的應用id,appsecret就是申請的應用秘鑰,redirect_url是掃碼登錄成功返回的地址
需是外網訪問,在申請的應用中配置

外網映射實現可使用ngrok:具體可閱讀https://gitchat.csdn.net/activity/5c6cf6044bb44360f3370255?utm_source=znx0619_2

config文件如下
/**

  • 添加微信配置類*/
    @Component
    br/>*/
    @Component
    br/>@Data

    /**

    • 微信公眾號appid
      */
      private String appid;

    /**

    • 秘鑰
      */
      private String appsecret;

    /**

    • 回調地址
      */
      private String redirectUrl;

    /**

    • 微信開發平臺二維碼連接
      */
      private final static String OPEN_QRCODE_URL = "https://open.weixin.qq.com/connect/qrconnect?appid=%s&redirect_uri=%s&response_type=code&scope=snsapi_login&state=%s#wechat_redirect";

    /**

    • 開發平臺獲取token地址
      */
      private final static String OPEN_ACCESS_TOKEN_URL = "https://api.weixin.qq.com/sns/oauth3/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code";

    /**

    • 通過token獲取用戶信息
      */
      private final static String OPEN_USER_INFO_URL = "https://api.weixin.qq.com/sns/userinfo?access_token=%s&openid=%s&lang=zh_CN";

    public static String getOpenQrcodeUrl() {
    return OPEN_QRCODE_URL;
    }

    public static String getOpenAccessTokenUrl() {
    return OPEN_ACCESS_TOKEN_URL;
    }

    public static String getOpenUserInfoUrl() {
    return OPEN_USER_INFO_URL;
    }
    }

3.編寫登錄接口以及登錄成功回調接口獲取用戶信息
/**

  • @param accessPage 登錄成功返回的地址http
  • @return
  • @throws UnsupportedEncodingException*/
    @GetMapping("/login_url")
    br/>*/
    @GetMapping("/login_url")

    //獲取開發平臺回調地址
    String redirectUrl = wxopenConfig.getRedirectUrl();
    //進行編碼
    String callbackUrl = URLEncoder.encode(redirectUrl, "GBK");
    
    String qrcodeUrl = String.format(WxopenConfig.getOpenQrcodeUrl(), wxopenConfig.getAppid(), callbackUrl, accessPage);
    
    return RespBody.success(qrcodeUrl);

    }

此時會返回給前端一個二維碼url,掃碼登錄成功,自動回調下面這個接口,并跳轉到想要的頁面即access_page的值

/**
 * 微信開放平臺回調地址
 *
 * @param code  微信開放平臺返回code 去獲取AccessToken后 用AccessToken 去獲取用戶信息
 * @param state 用戶跳轉地址
 * @param
 */
@GetMapping("/user/callback")
public void wechatUserCallback(@RequestParam(value = "code", required = true) String code,
                               String state, HttpServletResponse response) throws IOException {
    System.out.println("code:" + code);
    System.out.println("state:" + state);

    User user = iUserService.saveWeChatUser(code);
    if (user != null) {
        //生成Jwt
        String token = JwtUtils.geneJsonWebToken(user);
        //state當前用戶頁面地址需要拼接http://
        response.sendRedirect(state + "?token=" + token + "&head_img=" + user.getHeadImg()
                        + "&name=" + URLEncoder.encode( user.getName(),"UTF-8"));
    }
}

     @Override
public User saveWeChatUser(String code) {

    //獲取accessToken和openId
    String accessTokenUrl = String.format(WxopenConfig.getOpenAccessTokenUrl(), wxopenConfig.getAppid(), wxopenConfig.getAppsecret(), code);
    Map<String, Object> baseMap = HttpUtils.doGet(accessTokenUrl);

    if (baseMap == null || baseMap.isEmpty()) {
        return null;
    }
    String accessToken = (String) baseMap.get("access_token");
    String openId = (String) baseMap.get("openid");

    //更新用戶 直接返回
    User dbUser = userMapper.findByOpenid(openId);
    if (dbUser != null) {
        return dbUser;
    }

    //用AccessToken獲取用戶基本信息
    String userInfoUrl = String.format(WxopenConfig.getOpenUserInfoUrl(), accessToken, openId);
    Map<String, Object> baseUserMap = HttpUtils.doGet(userInfoUrl);

    if (baseUserMap == null || baseUserMap.isEmpty()) {
        return null;
    }

    //獲取用戶信息并轉碼
    String nickname = (String) baseUserMap.get("nickname");
    String province = (String) baseUserMap.get("province");
    String city = (String) baseUserMap.get("city");
    String country = (String) baseUserMap.get("country");
    try {
        nickname = new String(nickname.getBytes("ISO-8859-1"), "UTF-8");
        province = new String(province.getBytes("ISO-8859-1"), "UTF-8");
        city = new String(city.getBytes("ISO-8859-1"), "UTF-8");
        country = new String(country.getBytes("ISO-8859-1"), "UTF-8");
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    Double sexTemp = (Double) baseUserMap.get("sex");
    int sex = sexTemp.intValue();

    String headimgurl = (String) baseUserMap.get("headimgurl");
    StringBuffer sb = new StringBuffer(country).append("||").append(city).append("||").append(province);
    String finalAddress = sb.toString();

    User user = new User();
    user.setName(nickname);
    user.setCity(finalAddress);
    user.setSex(sex);
    user.setHeadImg(headimgurl);
    user.setOpenid(openId);
    user.setCreateTime(new Date());
    //存入用戶信息
    userMapper.insert(user);

    return user;
}
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大荔县| 泰兴市| 黎川县| 伊宁县| 浏阳市| 横峰县| 娱乐| 静宁县| 汤阴县| 家居| 莱芜市| 达孜县| 铅山县| 钟山县| 外汇| 西丰县| 普陀区| 宝丰县| 松潘县| 定日县| 台北县| 广宗县| 榆社县| 固安县| 吉林省| 调兵山市| 汾西县| 营口市| 新乐市| 贺兰县| 商南县| 蓬溪县| 沂源县| 法库县| 阿克陶县| 沐川县| 酉阳| 巩义市| 桃园市| 惠安县| 特克斯县|