AJAX跨域使用代理Servlet避开浏览器的CORS机制绕过浏览器实现跨域------AJAX

130 篇文章 0 订阅
45 篇文章 0 订阅
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <script type="text/javascript" src="JS/jQuery-1.0.0.js"></script>
    <script type="text/javascript">
        $(function()
        {
           $("#btn").click(function(){
               var ajax = new XMLHttpRequest();
               ajax.onreadystatechange = function()
               {
                   if (ajax.readyState === 4)
                   {
                       if (ajax.status === 200)
                       {
                           $("#myDiv").html(ajax.responseText);
                       }
                       else
                       {
                           alert(ajax.status);
                       }
                   }
               }
               ajax.open("GET","http://localhost:8080/ajax/Proxy",true);
               ajax.send();
           });
        });
    </script>
    <button id="btn">使用代理机制实现的ajax跨域请求</button>
    <div id="myDiv"></div>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <script type="text/javascript" src="JS/jQuery-1.0.0.js"></script>
    <script type="text/javascript">
        $(function()
        {
           $("#btn").click(function(){
               var ajax = new XMLHttpRequest();
               ajax.onreadystatechange = function()
               {
                   if (ajax.readyState === 4)
                   {
                       if (ajax.status === 200)
                       {
                           $("#myDiv").html(ajax.responseText);
                       }
                       else
                       {
                           alert(ajax.status);
                       }
                   }
               }
               ajax.open("GET","http://localhost:8080/ajax/Proxy",true);
               ajax.send();
           });
        });
    </script>
    <button id="btn">使用代理机制实现的ajax跨域请求</button>
    <div id="myDiv"></div>
</body>
</html>
package com.bjpowernode.AJAX;

import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

@WebServlet("/Proxy")
public class ProxyServlet extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
        //通过HttpClient发送get或者post请求,访问我们另一个服务器
        String url = "http://localhost:8081/Test/hello";
        HttpGet httpGet = new HttpGet(url);
        // 设置类型 "application/x-www-form-urlencoded" "application/json"
        httpGet.setHeader("Content-Type", "application/x-www-form-urlencoded");
        System.out.println("调用URL: " + httpGet.getURI());//        httpClient实例化
        CloseableHttpClient httpClient = HttpClients.createDefault();
        // 执行请求并获取返回
        HttpResponse resp = httpClient.execute(httpGet);//
        System.out.println("Response toString()" + resp.toString());
        HttpEntity entity = resp.getEntity();
        System.out.println("返回状态码:" + resp.getStatusLine());
        //得到返回数据的长度;没有该参数返回-1//
        if (entity != null)
        {
            System.out.println("返回消息内容长度: " + entity.getContentLength());
        }
        // 显示结果
        BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), "UTF-8"));
        String line = null;
        StringBuffer responseSB = new StringBuffer();
        while ((line = reader.readLine()) != null) {
            responseSB.append(line);
        }
        System.out.println("返回消息:" + responseSB);
        response.getWriter().println(responseSB);
        reader.close();
        httpClient.close();
    }
}
package com.bjpowernode.AJAX;

import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

@WebServlet("/Proxy")
public class ProxyServlet extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
        //通过HttpClient发送get或者post请求,访问我们另一个服务器
        String url = "http://localhost:8081/Test/hello";
        HttpGet httpGet = new HttpGet(url);
        // 设置类型 "application/x-www-form-urlencoded" "application/json"
        httpGet.setHeader("Content-Type", "application/x-www-form-urlencoded");
        System.out.println("调用URL: " + httpGet.getURI());//        httpClient实例化
        CloseableHttpClient httpClient = HttpClients.createDefault();
        // 执行请求并获取返回
        HttpResponse resp = httpClient.execute(httpGet);//
        System.out.println("Response toString()" + resp.toString());
        HttpEntity entity = resp.getEntity();
        System.out.println("返回状态码:" + resp.getStatusLine());
        //得到返回数据的长度;没有该参数返回-1//
        if (entity != null)
        {
            System.out.println("返回消息内容长度: " + entity.getContentLength());
        }
        // 显示结果
        BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), "UTF-8"));
        String line = null;
        StringBuffer responseSB = new StringBuffer();
        while ((line = reader.readLine()) != null) {
            responseSB.append(line);
        }
        System.out.println("返回消息:" + responseSB);
        response.getWriter().println(responseSB);
        reader.close();
        httpClient.close();
    }
}
import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;

import java.io.IOException;

@WebServlet("/hello")
public class Hello extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        //设置响应头
//        response.setHeader("Access-Control-Allow-Origin","http://localhost:8080");
        //跨域访问的资源允许访问,设置响应头的方式原理是

        response.getWriter().println("{\"username\" : \"zhangSan\"};");
    }
}
import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;

import java.io.IOException;

@WebServlet("/hello")
public class Hello extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        //设置响应头
//        response.setHeader("Access-Control-Allow-Origin","http://localhost:8080");
        //跨域访问的资源允许访问,设置响应头的方式原理是

        response.getWriter().println("{\"username\" : \"zhangSan\"};");
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
跨域访问是基于浏览器的同源策略所限制的,阻止了从一个源加载的文档或脚本来与来自另一个源的资源进行交互。为了实现跨域访问,可以通过设置服务器的响应头中的Access-Control-Allow-Origin字段来允许特定的域进行访问。 在使用Ajax进行跨域请求时,需要在服务器端设置响应头中的Access-Control-Allow-Origin字段。这个字段的值可以是具体的域名、通配符(*)或者null。 如果你想允许所有的域名进行跨域访问,可以将Access-Control-Allow-Origin字段设置为通配符*: ``` response.setHeader("Access-Control-Allow-Origin", "*"); ``` 如果你只想允许特定的域名进行跨域访问,可以将Access-Control-Allow-Origin字段设置为具体的域名: ``` response.setHeader("Access-Control-Allow-Origin", "https://www.example.com"); ``` 注意:在真实的生产环境中,应该根据具体需求来设置允许跨域访问的域名,不建议使用通配符*,因为这样可能存在安全风险。 另外,还可以设置其他的Access-Control-Allow-*字段来进一步控制跨域请求,例如Access-Control-Allow-Methods、Access-Control-Allow-Headers等。 需要注意的是,以上设置只是在服务器端进行了配置,还需要确保浏览器端的请求中包含了正确的跨域请求头信息,例如使用XMLHttpRequest对象时,需要设置withCredentials为true,以允许发送跨域请求的cookie。 希望以上信息对你有帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值