关于ajax跨域问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Pruett/article/details/84144965

1.没进行跨域,ajax请求发不出去

对于前后端的分离,如果不是在同一个IP,同一个端口的情况下可能就需要进行跨域, 使用的是nginx进行跨域,nginx是服务器端跨域解决,下载nginx,然后安装好之后进行文件的配置,然后启动nginx进行了,(在自己的电脑上进行nginx配置),给出我的配置文件的server

server {
        listen       8099;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass http://127.0.0.1:8080;  #要把请求发到的地址
            add_header 'Access-Control-Allow-Origin' 'http://localhost:63342';#这里使用*号也可以,但是自己使用不成功,所以改成了自己webstrom的端口号
            add_header 'Access-Control-Allow-Credentials' 'true'; #允许客户端发送的时候携带cookie
            add_header 'Access-Control-Allow-Methods' 'GET, PUT, POST, DELETE, OPTIONS'; #支持请求方式
            add_header 'Access-Control-Allow-Headers' 'Content-Type,*';
        }
}

2.跨域问题解决了,但是每次请求到发新的session

ssm框架使用shiro做权限管理,每次都发新的session,nginx设置的时候,允许携带cookie,而且第一次请求的时候将session发送到客户端,但是ajax进行异步请求的时候没有携带cookie,在进行ajax请求的时候,对如下参数进行设置就可以啦

 xhrFields: {withCredentials: true},

简单的ajax

 $.ajax( {
        url: url,
        type: "POST",
        data: formDate,
        dataType: 'json',
        xhrFields: {withCredentials: true},
        async: bool,
        processData:false,
        contentType:false,
        success : function (data) {
            //代码
        }
    });

猜你喜欢

转载自blog.csdn.net/Pruett/article/details/84144965