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

<!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);");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值