AJAX的跨域问题使用jQuery封装的JsonP的方式实现跨域------AJAX

130 篇文章 0 订阅
45 篇文章 0 订阅
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JQJSONP</title>
</head>
<body>
    <script type="text/javascript" src="JS/jquery-3.6.1.js"></script>
    <script type="text/javascript">
        function sayHello()
        {
            $("#myDiv").html("欢迎你:" + data.name);
        }
    </script>
    <script type="text/javascript">
        $(function()
        {
            //发送jsonp请求(假ajax请求)
            $("#btn").click(function(){
                $.ajax({
                   type : "GET",//jsonp只支持get请求
                   url : "http://localhost:8081/Test/jsonP1",
                    dataType : "jsonp",//指定是jsonp格式的数据类型
                    jsonp : "fun",//用我们自己的
                    jsonpCallback : "sayHello"//不采用默认的回调函数,我们自己写的函数
                    // success : function(data){
                    //     $("#myDiv").html("欢迎你:" + data.name);
                    // }
                });
            });
        })
    </script>
    <button id="btn">JQUERY的jsonp</button>
    <div id="myDiv"></div>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JQJSONP</title>
</head>
<body>
    <script type="text/javascript" src="JS/jquery-3.6.1.js"></script>
    <script type="text/javascript">
        function sayHello()
        {
            $("#myDiv").html("欢迎你:" + data.name);
        }
    </script>
    <script type="text/javascript">
        $(function()
        {
            //发送jsonp请求(假ajax请求)
            $("#btn").click(function(){
                $.ajax({
                   type : "GET",//jsonp只支持get请求
                   url : "http://localhost:8081/Test/jsonP1",
                    dataType : "jsonp",//指定是jsonp格式的数据类型
                    jsonp : "fun",//用我们自己的
                    jsonpCallback : "sayHello"//不采用默认的回调函数,我们自己写的函数
                    // success : function(data){
                    //     $("#myDiv").html("欢迎你:" + data.name);
                    // }
                });
            });
        })
    </script>
    <button id="btn">JQUERY的jsonp</button>
    <div id="myDiv"></div>
</body>
</html>
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;
import java.io.PrintWriter;

@WebServlet("/jsonP1")
public class jsonP1 extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
//        jsonP跨域的时候只支持get请求,因为我们写src本质就是一个get请求的传递
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        //如果是输出前端代码呢?
//        out.println("alert(123);");
//        out.println("sayHello();");
        String fun = request.getParameter("fun");
//        out.println(fun + "({\"name\" : \"Jack\"});");
        out.print(fun + "({\"name\" : \"Jack\"});");
//        out.println(fun + "(5,6);");
    }
}
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;
import java.io.PrintWriter;

@WebServlet("/jsonP1")
public class jsonP1 extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
//        jsonP跨域的时候只支持get请求,因为我们写src本质就是一个get请求的传递
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        //如果是输出前端代码呢?
//        out.println("alert(123);");
//        out.println("sayHello();");
        String fun = request.getParameter("fun");
//        out.println(fun + "({\"name\" : \"Jack\"});");
        out.print(fun + "({\"name\" : \"Jack\"});");
//        out.println(fun + "(5,6);");
    }
}
  • 4
    点赞
  • 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、付费专栏及课程。

余额充值