angularjs - Angular JS : No 'Access-Control-Allow-Origin' header is present on the requested resource

标签 angularjs web-services jakarta-ee cors

我正在尝试创建一个网络服务。我在客户端使用 AngularJS,并在 Web 服务中使用 Java。这是我的客户端代码

var url = 'http://localhost:8010/something';
    var data = {
            "departmentID":$scope.departmentID ,
            "departmentName":$scope.departmentName,
        };
    var config = {
        headers: {
          'Content-Type': 'Application/JSON',
        },
        withCredentials : true
    };
    $http.put(url,data).success(
        function(data, status, headers, config){
            alert("success :"+data);
        }).error(
        function(data, status, headers, config){
            alert("Failure :"+data);
        }       
    );

这是我的服务器端代码

@PUT
@Consumes(MediaType.APPLICATION_JSON)
public Response add(final Department department) {
    try {
        DepartmentRelation.addDepartment(department);
        return Response.status(Status.OK).header("Access-Control-Allow-Origin", "*").header("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT").header("Access-Control-Allow-Credentials",true).build();
    } catch (ClassNotFoundException | IOException e) {
        e.printStackTrace();
        return Response.status(Status.INTERNAL_SERVER_ERROR).header("Access-Control-Allow-Origin", "*").header("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT").build();
    } catch (SQLException e) {
        e.printStackTrace();
        return Response.status(Status.BAD_REQUEST).header("Access-Control-Allow-Origin", "*").header("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT").build();
    }
}

但我收到此错误 - “请求的资源上不存在“Access-Control-Allow-Origin” header 。因此不允许访问 Origin“http://localhost”。”当我尝试使用它时。

最佳答案

浏览器将使用 OPTIONS 方法执行预检请求来检查对资源的访问。您需要在 JAX-RS 后端实现一个方法,以响应带有 CORS header 的 OPTIONS 请求(就像您在“add”方法中所做的那样)。

@OPTIONS
public Response options() {
    return Response
            .status(Response.Status.OK)
            .header("Access-Control-Allow-Origin", "*")
            .header("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT")
            .header("Access-Control-Allow-Credentials",true)
            .build();
}

关于angularjs - Angular JS : No 'Access-Control-Allow-Origin' header is present on the requested resource,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28306103/

相关文章:

angularjs - 在 IE 上运行时,'Promise' 是未定义的错误

jquery - 如何以 AngularJS 1.x 方式将 Kendo-UI 网格的高度扩展到 100%?

javascript - 无法显示下拉菜单和弹出窗口 AngularJS

android - 刷新数据 Android 应用程序

java - 如何使用 JAX-WS 从 Web 服务访问 DAO

python - 将 POST 消息中的数据发送到 RESTful Web 服务

javascript - Sails.js 将 key 和数据流式传输到 Angular

java - 无法从远程机器联系 EJB

mysql - 基于 J2EE 表单的登录错误

java - 企业应用开发-RMI和EJB