您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Java模擬實現QQ三方登錄的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
本次例子模擬這樣的情況:
一共有2個spring boot應用:
一個是某公司的web,第二個是QQ服務端。
某公司的應用為127.0.0.1:8082
QQ服務端為127.0.0.1:8081
演示如下:
點擊使用QQ登錄:
在彈出的界面輸入數據點擊登錄后:
關鍵代碼如下:
某公司web端:
MyController.java
package cn.it1995.login.controller; import cn.it1995.login.util.CookieUtil; import cn.it1995.login.util.Result; import com.alibaba.fastjson.JSON; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.ResponseEntity; import org.springframework.util.LinkedMultiValueMap; import org.springframework.util.MultiValueMap; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; @RestController public class MyController { @Autowired private RestTemplate restTemplate; private static final String USER_KEY="user_key"; private ConcurrentMap<String, Object> user = new ConcurrentHashMap<>(); @GetMapping("/getUser") public Object getUser(HttpServletRequest request, HttpServletResponse response){ String loginCookie = CookieUtil.getLoginCookie(request, response); Object o = user.get(loginCookie); return Result.success(o); } @PostMapping("/loginByQQ") public Object loginByQQ(String token, HttpServletResponse response, HttpServletRequest request){ MultiValueMap<String, Object> paramMap = new LinkedMultiValueMap(); paramMap.add("token", token); ResponseEntity<Object> objectResponseEntity = restTemplate.postForEntity("http://127.0.0.7:8081/getLoginInfo", paramMap, Object.class); Object body = objectResponseEntity.getBody(); String uuid = CookieUtil.setLoginCookie(request, response); //json標準化 String newJson = body.toString().replace("=", ":"); System.out.println(newJson); Map map = JSON.parseObject(newJson, Map.class); Map data = JSON.parseObject(map.get("data").toString(), Map.class); user.put(uuid, data); return Result.success(); } }
QQ服務端:
UserController.java
package cn.it1995.qqServer.controller; import cn.it1995.qqServer.util.JwtUtil; import cn.it1995.qqServer.util.Result; import com.alibaba.fastjson.JSON; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.*; import java.util.HashMap; import java.util.Map; import java.util.UUID; @Controller public class UserController { @ResponseBody @RequestMapping("/login") public Object login(@RequestParam("username") String username, @RequestParam("password") String password){ Map<String, Object> map = new HashMap<>(); map.put("username", username); map.put("password", password); String jwt = JwtUtil.createJWT(UUID.randomUUID().toString(), JSON.toJSONString(map), 3600 * 24); return jwt; } @ResponseBody @RequestMapping("/getLoginInfo") public Object getLoginInfo(String token){ String subject = JwtUtil.parseJWT(token).getSubject(); return Result.success().data(subject); } }
關于Java模擬實現QQ三方登錄的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。