我目前正在使用带有 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();
}