先閱讀微信官方文檔
https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html
成都創(chuàng)新互聯(lián)網(wǎng)絡(luò)公司擁有十載的成都網(wǎng)站開發(fā)建設(shè)經(jīng)驗(yàn),上1000+客戶的共同信賴。提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、網(wǎng)站開發(fā)、網(wǎng)站定制、外鏈、建網(wǎng)站、網(wǎng)站搭建、成都響應(yīng)式網(wǎng)站建設(shè)公司、網(wǎng)頁設(shè)計(jì)師打造企業(yè)風(fēng)格,提供周到的售前咨詢和貼心的售后服務(wù)
1.事先準(zhǔn)備
網(wǎng)站應(yīng)用微信登錄是基于OAuth3.0協(xié)議標(biāo)準(zhǔn)構(gòu)建的微信OAuth3.0授權(quán)登錄系統(tǒng)。 在進(jìn)行微信OAuth3.在進(jìn)行微信OAuth3.0授權(quán)登錄接入之前,在微信開放平臺(tái)注冊(cè)開發(fā)者帳號(hào),并擁有一個(gè)已審核通過的網(wǎng)站應(yīng)用,并獲得相應(yīng)的AppID和AppSecret,申請(qǐng)微信登錄且通過審核后,可開始接入流程。
2.編輯yml文件以及config文件 用于獲取配置值
application.yml文件添加以下配置
wxopen:
appid: wx025575xx69a2d5b
appsecret: deeae310axxxfa9d3e8f3
redirect_url: http://fde9ab75.ngrok.io/api/v1/wechat/user/callback #回調(diào)地址 域名開放平臺(tái)設(shè)置
其中appid就是申請(qǐng)的應(yīng)用id,appsecret就是申請(qǐng)的應(yīng)用秘鑰,redirect_url是掃碼登錄成功返回的地址
需是外網(wǎng)訪問,在申請(qǐng)的應(yīng)用中配置
外網(wǎng)映射實(shí)現(xiàn)可使用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.編寫登錄接口以及登錄成功回調(diào)接口獲取用戶信息
/**
@throws UnsupportedEncodingException*/
@GetMapping("/login_url")
br/>*/
@GetMapping("/login_url")
//獲取開發(fā)平臺(tái)回調(diào)地址
String redirectUrl = wxopenConfig.getRedirectUrl();
//進(jìn)行編碼
String callbackUrl = URLEncoder.encode(redirectUrl, "GBK");
String qrcodeUrl = String.format(WxopenConfig.getOpenQrcodeUrl(), wxopenConfig.getAppid(), callbackUrl, accessPage);
return RespBody.success(qrcodeUrl);
}
此時(shí)會(huì)返回給前端一個(gè)二維碼url,掃碼登錄成功,自動(dòng)回調(diào)下面這個(gè)接口,并跳轉(zhuǎn)到想要的頁面即access_page的值
/**
* 微信開放平臺(tái)回調(diào)地址
*
* @param code 微信開放平臺(tái)返回code 去獲取AccessToken后 用AccessToken 去獲取用戶信息
* @param state 用戶跳轉(zhuǎn)地址
* @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當(dāng)前用戶頁面地址需要拼接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 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 baseUserMap = HttpUtils.doGet(userInfoUrl);
if (baseUserMap == null || baseUserMap.isEmpty()) {
return null;
}
//獲取用戶信息并轉(zhuǎn)碼
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;
}