【发布时间】:2017-03-17 11:50:01
【问题描述】:
我有一个使用 SpringBoot 开发的弹簧RestController。
@RestController
@RequestMapping("/myRoot")
public class MyRestController {
@Autowired
private MyService myService;
@RequestMapping(value="/add/{myItem}", method=RequestMethod.POST)
public @ResponseBody void addMyItem(@PathVariable("myItem") String myItem){
myService.addMyItem(myItem);
}
}
我的 Spring Boot 类包含 main 方法是:
@SpringBootApplication(scanBasePackages={"org.mypackage"})
public class MyRestApp {
public static void main(String[] args) {
SpringApplication.run(MyRestApp .class, args);
}
}
当我编译项目时,在 Eclipse 中将生成的 Jar 作为 Java 应用程序运行,控制台显示:
2017-03-17 22:33:14.363 INFO 2292 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http)
2017-03-17 22:33:14.371 INFO 2292 --- [ main] o.n.todo.springboot.SuperrDuperrRestApp : Started MyRestApp in 7.056 seconds (JVM running for 7.837)
在 Chrome 上的 Postman 上发帖调用 http://localhost:8080/MyRestApi/myRoot/add/myItem 会返回成功 (200 OK)。
这意味着我的 rest api 已正确公开并启动并运行。
我正在尝试从我的 AngularJs 1 应用程序中调用以上 URI,如下所示:
'use strict';
var myApp = angular.module("MyFirstAngularRestApp",[]);
myApp.controller("myCtrl",myCtrl);
function myCtrl($http){
console.log("myCtrl");
var REST_SERVICE_URI = 'http://localhost:8080/MyRestApi/';
this.AddItem = function(newItem){
console.log("AddItem");
console.log(newItem);
$http.post(this.REST_SERVICE_URI + 'myRoot/add/' + newItem).then(function(response){
console.log("success");
});
}
}
但是,这不起作用。我收到以下错误:
XMLHttpRequest cannot load file:///C:/myDevelopment/Angular/MyAngularApp/undefinedtoDo/add/ReadABook. Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https, chrome-extension-resource.
Possibly unhandled rejection: {"data":null,"status":-1,"config":{"method":"POST","transformRequest":[null],"transformResponse":[null],"jsonpCallbackParam":"callback","url":"undefinedtoDo/addItem/Read a Book","headers":{"Accept":"application/json, text/plain, */*"}},"statusText":""}
我对 AngularJs 1 完全陌生,所以无法理解为什么我的休息电话不起作用。我错过了什么?
我的 AngularJs 项目位于笔记本电脑驱动器上的不同位置,而我的 Eclipse 工作区位于不同的目录。但我认为这不应该是重要的。
如果有人可以指导我如何解决此错误,我将不胜感激。要求尽可能详细地回答,因为我是新手。
谢谢!
【问题讨论】:
标签: angularjs spring rest spring-boot