0

我目前正在使用带有 CAS 的 Spring Security 作为身份验证机制来保护 Web 应用程序以及我的 RESTful 服务 API(在单独的服务器上)。我想在 AJAX 中从我的 Web 应用程序调用 RESTful 服务。我已成功设置从 Web 应用程序到服务的 CAS 代理。在我的 AJAX/JQuery 代码中使用 PGT 调用服务以检索服务数据的最佳方式是什么?

现在我可以使用以下测试 servlet 成功读取服务数据,但想知道使用 AJAX 的方法是什么。

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
    throws ServletException, IOException {
String targetUrl = "https://example.com/services/helloworld";

final CasAuthenticationToken token = (CasAuthenticationToken) req
    .getUserPrincipal();
final String proxyTicket = token.getAssertion().getPrincipal()
    .getProxyTicketFor(targetUrl);

// Make a remote call using the proxy ticket
final String serviceUrl = targetUrl + "?ticket="
    + URLEncoder.encode(proxyTicket, "UTF-8");
String proxyResponse = CommonUtils.getResponseFromServer(serviceUrl);

resp.setStatus(HttpServletResponse.SC_OK);
resp.setContentType("text/plain");
PrintWriter writer = resp.getWriter();
writer.println(proxyResponse);
writer.flush();
}
4

1 回答 1

1

我最终放弃了这个并转向 OAuth 2 解决方案。

于 2012-07-16T13:04:08.667 回答