gpt4 book ai didi

java - 使用 Angularjs 从 Grails 后端获取 JSON 数据

转载 作者:行者123 更新时间:2023-12-01 23:29:26 25 4
gpt4 key购买 nike

我遇到以下问题。我在 Grails 中有 Controller ,它返回 Json 格式的列表:

render([tweets: tweets.take(2).collect { tweet -> [id: tweet.id, content: tweet.tweetContent]}] as JSON)

这是我的 UrlMapping:

"/tweets/"(controller: "tweets", parseRequest: true) {
action = [GET: "list"]

因此,当我在任何浏览器中打开此网址时,我会获取 JSON 格式的元素列表:

{"tweets":[{"id":375238019298914304,"content":"@RonNegrita @Paolah_96 jajajajajajajajaja pues ale Negrita q nos lo has xk este del Tuit prima JAJAJAHAHAHAHA"},{"id":375238020360048640,"content":"My 38 Life Goals for next 10 years. Brewery's, Alabama Football, Concerts, Companies, Kids, Fiji, & more: http://t.co/behxfnCo5t"}]}

然后我尝试使用 Angularjs 在 HTML 页面中获取此元素。这是我的 html 页面的简单代码:

<!doctype html>
<html lang="en" ng-app id="ng-app">
<head>
<title>Page Title</title>
<script src="js/angular.js"></script>
<script>
function PostsCtrlAjax($scope, $http)
{
$scope.tweets = []
$http.get('http://localhost:8080/trutto-api/tweets/').success(function(data)
{
$scope.tweets = data; // response data
});
}
</script>
</head>
<body>
<div id="ng-app" ng-app ng-controller="PostsCtrlAjax">
<li ng-repeat="tweet in tweets>{{tweet.id}} - {{tweet.content}}</li>
</h2>
</div>
</body>
</html>

当我尝试在 Chrome 浏览器中获取数据时,出现以下错误:

"Xml http request cannot load http://localhost:8080/trutto-api/tweets/. Original null is not allowed by access-control-allow-origin"

我在这里发现了有关此错误的问题,它建议使用以下命令启动 Chrome:

"- allow-file-access-from-files". 

我尝试过 - 它不起作用,返回相同的错误。然后我在 Glassfish 服务器上尝试了它 -> 在 Chrome 中打开会导致相同的错误。

在 Mozilla Firefox 中打开会导致以下错误:

SyntaxError: JSON.parse: unexpected end of data.

我该如何解决这个问题?预先感谢您。

最佳答案

这是一个 CORS 问题。使用this plugin来解决问题。基本上,按照您本地开发设置的方式,ajax 调用会认为您正在为请求调用不同的源(域),而这是不允许的。

关于java - 使用 Angularjs 从 Grails 后端获取 JSON 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19550794/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com