我需要通过angularjs调用基于Spring控制器的url,并将从Spring控制器返回的响应打印到浏览器。
因此,这是一个PoC,当用户单击该按钮时,主页中会包含一个按钮,该按钮内部会调用一个函数,并在该函数中调用Spring控制器。
当消息包装在 Java Bean类中并按原样返回Java Bean类时,它将显示消息。
但是,当我从控制器返回直接的String值时,它正在浏览器控制台中打印 undefined 。
我是Angular + Spring集成的新手,所以有什么方法可以从控制器返回直接的 String / Integer obj。
MyController
-------------------
@RestController
public class MyController {
@RequestMapping(value="/home")
public ModelAndView showHome() {
return new ModelAndView("home");
}
@RequestMapping(value="/getMessage",method=RequestMethod.GET,produces="application/json")
public String getMessage() {
/*Message msg= new Message();
msg.setMesg("Hello From AngularJS");*/
return "Hello From AngularJs";
}
}
注意-,我直接从控制器而不是 Message 对象返回String值。
Home.jsp
-------------
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Home| Page</title>
<link rel="stylesheet" href='<c:url value="/main.css"></c:url>'>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.9/angular.min.js"></script>
<script type="text/javascript">
var app= angular.module("myApp",[]);
app.controller("hello",function($scope,$http){
$scope.getMessage= function(){
$http({
method: 'GET',
url: 'getMessage' /* Tried even with fully qualified url 'http://localhost:8080/AngularJs-Spring-HelloWorld/getMessage' */
}).then(function successCallback(response){
$scope.user= response.data;
},function errorCallback(response){
console.log(response.statusText);
});
}
});
</script>
</head>
<body ng-app="myApp" ng-controller="hello">
<div class="bb">
<h2 style="color: orange;text-align: center;">Angularjs Spring MVC sample application!!</h2>
<button style="text-align: center;" ng-click="getMessage()">Greet User</button>
<p>{{user}}</p>
</div>
</body>
</html>
如何从控制器返回字符串值并在浏览器中显示它。有什么方法可以从控制器返回String值吗?
否则,返回的字符串值将像在普通spring-mvc应用程序中一样视为视图页面名称。
答案 0 :(得分:1)
将GSON jar导入您的应用程序,并按如下所示更改return语句,然后可以从spring控制器返回一个字符串。
@RequestMapping(value="/getMessage",method=RequestMethod.GET,produces="application/json")
public String getMessage() {
/*Message msg= new Message();
msg.setMesg("Hello From AngularJS");*/
return new GSON. toJson("Hello From AngularJs");
}
类似地,如果您要返回任何类型的Java bean,则可以将bean转换为JSON字符串,并按如下所示将其作为字符串返回
@RequestMapping(value="/getMessage",method=RequestMethod.GET,produces="application/json")
public String getMessage() {
Message msg= new Message();
msg.setMesg("Hello From AngularJS");
return new GSON.toJson(msg);
}