【发布时间】:2016-11-14 20:06:12
【问题描述】:
我是 Spring Social API 的新手,我正在尝试通过 facebook 登录我的应用程序,但它没有将我重定向到我的域 url。
我的应用程序在两台服务器上运行,它基于提交了 ajax 表单的 restcontroller。一个是apache web server,另一个是tomcat server。
但我的 facebook 身份验证不是基于 restcontroller,如果用户需要通过 facebook ID 登录,那么他只需点击登录 facebook 按钮和页面成功重定向到 facebook 登录页面,但不会重定向回请求的 URL .
我的代码如下:
使用 Facebook 登录@RequestMapping(value = "/fbauth", method = RequestMethod.GET) public void fbredirect(@RequestParam Map requestParams) 抛出 UnsupportedEncodingException { 字符串访问令牌 = null; // 字符串访问令牌 = // “CAAFv5tfCxvsBAMkGz7Mz63ESCLEK3jgZBEZAZBqlj3CApIyqmvA5hOrtl9Ln05O3BRTcx95TjT9IxZBfRz3fKZBjNJ74qko1SFjjzAXmdDnzVePmGXswOM8NHEGTZA6aub7bnZBYBIMO2ZBXX2gpo6ky7Dkqu2xZBUymAalAgg3ixaRQMe3e3w1ruUtVeyQrtMb3x0pehHOIaTQZDZD”; RestTemplate restTemplate = new RestTemplate(); 映射结果 = null; if (StringUtils.isEmpty(accessToken)) { 对于(字符串键:requestParams.keySet()){ 对象值 = requestParams.get(key); logger.info("键:" + 键 + " 值:" + 值); }
String code = requestParams.get("code");
if (StringUtils.isNotEmpty(code)) {
String authUrl = "http://" + request.getServerName() + "/realtybud/fbauth";
StringBuilder stringBuilder = new StringBuilder();
String fbAuthApi = "https://graph.facebook.com/v2.3/oauth/access_token?client_id=";
stringBuilder.append(fbAuthApi);
stringBuilder.append(selectAppId());
stringBuilder.append("&redirect_uri=");
stringBuilder.append(authUrl);
stringBuilder.append("&client_secret=");
stringBuilder.append(selectAppSecret());
stringBuilder.append("&code=");
stringBuilder.append(code);
String fbGraphUrl = stringBuilder.toString();
result = restTemplate.getForObject(fbGraphUrl, Map.class);
accessToken = result.get("access_token");
logger.info("Access Token: " + accessToken);
}
}
StringBuilder stringBuilder = new StringBuilder();
String fbGraphApi = "https://graph.facebook.com/v2.3/me?fields=id,name,email&access_token=";
stringBuilder.append(fbGraphApi);
stringBuilder.append(accessToken);
String fbProfileInfo = stringBuilder.toString();
// String info = restTemplate.getForObject(fbProfileInfo, String.class);
// logger.info("Info: " + info);
Map<String, String> info = restTemplate.getForObject(fbProfileInfo, Map.class);
logger.info("Id: " + info.get("id") + " name: " + info.get("name") + " email: " + info.get("email"));
String email = info.get("email");
if (StringUtils.isNotEmpty(email)) {
User user = userService.findUserByEmail(email);
if (user == null) {
user = new User();
user.setEmail(email);
user.setFacebookAccessToken(accessToken);
user.setFacebookName(info.get("name"));
userService.userSave(user);
Role userRole = new Role();
userRole.setRoleName("ROLE_USER");
userRole.setUser(user);
userService.roleSave(userRole);
List<Role> roles = new ArrayList<Role>();
roles.add(userRole);
user.setRoles(roles);
} else {
user.setFacebookAccessToken(accessToken);
user.setFacebookName(info.get("name"));
userService.userSave(user);
}
SecurityUser secUser = new SecurityUser(user);
Authentication authentication = new UsernamePasswordAuthenticationToken(secUser, secUser.getPassword(),
secUser.getAuthorities());
SecurityContextHolder.getContext().setAuthentication(authentication);
} else {
// error
}
// String fbAuthSuccessUrl = "/index?fbAuth=success";
//return "redirect:/";
}
请帮助我如何使用登录凭据重定向到 apache 网络服务器。
提前致谢。 瓦卡斯
【问题讨论】:
-
我在问题中没有提到的另一件事是。当表单提交请求从 apache web 服务器转发到 tomcat 服务器时,我只需要返回到我的 apache web 服务器域 url。我已经在 developer.facebook 应用程序中使用站点 url 设置了域 url。