您好,登錄后才能下訂單哦!
先閱讀微信官方文檔
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
/**
/**
/**
/**
/**
/**
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.編寫登錄接口以及登錄成功回調接口獲取用戶信息
/**
@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;
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。