申请网站应用并不用多说了,下面是我应用的平台信息:
整个代码流程是这样的:
1.用户在login.html页面点击qq登录图标,浏览器访问我们Controller的/qqOauth
2.我们的服务器向浏览器发送重定向到qq后台
浏览器访问qq后台:"https://graph.qq.com/oauth2.0/authorize"
+ "?response_type=code"
+ "&client_id=" + APP_ID
+ "&state=" + qqState
+ "&redirect_uri=" + "http://snownihao.cn/callback";
3.qq后台向浏览器发送重定向,浏览器访问我们的回调http://snownihao.cn/callback并附带了必要的参数
4.我们服务器后台与qq后台交互,也就是callback方法里边的那三个url,具体为
4.1用第3步的参数获取accessToken
4.2用4.1中的accessToken获取用户在此应用的openID
4.3用上面两部获取到的accessToken和openID获取用户信息
5.跳转到信息展示页面
这是获取到用户信息后的页面:
Controller:
package noon.demo_qq.controller;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.util.EntityUtils;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.util.Random;
@Controller
public class test {
final static String APP_ID = "你的appID";
final static String APP_KEY = "你的appKey";
@RequestMapping("/qqOauth")
public String qqOauth(HttpSession session) {
int rand = 10000 + new Random().nextInt(10000);
String qqState = String.valueOf(rand);
session.setAttribute("qqState", qqState);