V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
ilaipi
V2EX  ›  程序员

帮忙看下一个 jsonp 问题

  •  
  •   ilaipi ·
    ilaipi · May 4, 2017 · 4469 views
    This topic created in 3290 days ago, the information mentioned may be changed or developed.
    我在爬一个网站,debug 了一下,看到这一步:


    这里写的是个 post 请求,但是在 network 面板看到的是一个 get 请求


    不是很明白 jsonp,如果我要模拟这个请求,用普通的 http post 可以吗?
    我用的是 nodejs+axios
    26 replies    2017-05-19 16:49:46 +08:00
    FEDT
        1
    FEDT  
       May 4, 2017 via Android
    jsonp 只能是 get 请求吧
    zhihaofans
        2
    zhihaofans  
       May 4, 2017 via iPhone
    jsonp 只能 get 吧?
    你可以翻一翻文档 http://api.jquery.com
    think2011
        3
    think2011  
       May 4, 2017
    不能,你需要明白 jsonp 的原理。
    aaronlam
        4
    aaronlam  
       May 4, 2017 via iPhone
    jsonp 是动态添加 script 标签用的是 GET 请求
    DingJZ
        5
    DingJZ  
       May 4, 2017
    jsonp 肯定是 get
    LeeSeoung
        6
    LeeSeoung  
       May 4, 2017
    回复楼上各位 jsonp post 跨域方案: http://www.jb51.net/article/68980.htm
    jyz19880823
        7
    jyz19880823  
       May 4, 2017
    @LeeSeoung 这就不叫 jsonp 了吧
    wly19960911
        8
    wly19960911  
       May 4, 2017 via Android
    jsonp 不是 ajax,jsonp 不是 ajax,jsonp 不是 ajax,

    jQuery 把 jsonp 加入 ajax 的形式可能会误导人,
    f0rger
        9
    f0rger  
       May 4, 2017 via iPhone
    jsonp 只能是 get,上面那个跨域 post 的明显都改成 json 接收参数了。你们 2 个都好好了解一下 jsonp 吧
    ilaipi
        10
    ilaipi  
    OP
       May 4, 2017
    谢谢大家,不知道怎么说,感觉关注点有点偏了,是不是需要先弄清楚这个网站的这个 jsonp 请求,我模拟的时候一定也要是 jsonp 吗?
    我是在做小爬虫
    sliwey
        11
    sliwey  
       May 4, 2017
    @LeeSeoung #6 不是所有的跨域都叫 jsonp
    LeeSeoung
        12
    LeeSeoung  
       May 4, 2017
    #7 #9 #11 我说是跨域 POST 解决方案。。能好好理解清楚我说的意思不?
    LeeSeoung
        13
    LeeSeoung  
       May 4, 2017
    wuhuaji
        14
    wuhuaji  
       May 4, 2017
    https://whj.site/2016/04/15/how-to-cross-site/ 一篇文章看明白什么 jsonp 是如何工作的。
    huijiewei
        15
    huijiewei  
       May 4, 2017
    @LeeSeoung 这个不叫 JSONP 了好吗
    Jaylee
        16
    Jaylee  
       May 4, 2017
    @LeeSeoung 这叫 cors,跟 jsonp 半毛钱关系没有
    zhangsan
        17
    zhangsan  
       May 4, 2017   ❤️ 1
    你们的回复都笑死我了,啥是 jsonp,jsonp 是为了解决浏览器的同源策略,利用 js 的( src )可跨域属性实现的一种跨域请求方法。
    jsonp 只出现在 前端浏览器,跟后端一点关系都没有。

    后端想 post 还 get 完全是看心情。

    回复一句“ jsonp 肯定是 get 的”,要搞懂本质啊
    lilydjwg
        18
    lilydjwg  
       May 4, 2017
    @LeeSeoung #12 那个是跨域 POST,搜「 MDN CORS 」有详细的教程。jsonp 只能 GET,因为 HTML 加载脚本只能用 GET 方式。

    你想要 POST,请使用「跨域 POST 」的方式,不要用「 jsonp 」。
    lilydjwg
        19
    lilydjwg  
       May 4, 2017   ❤️ 1
    如果你要模拟这个请求,用普通的 HTTP GET 就行了。因为它就是普通的 HTTP GET。你在网络请求上点右键,可以选择「复制为 cURL 命令」,就能得到这个请求发出的具体方法。
    LeeSeoung
        20
    LeeSeoung  
       May 4, 2017
    @lilydjwg 怪我表述不清。。之前想跨域 post 发现 jsonp 搞不定 POST,后来发现上面那篇文章搞定了跨域 POST
    wc951
        21
    wc951  
       May 4, 2017 via Android
    谁说 jsonp 只是前端的事,后端不提供支持,你拿头去跨域回调
    mingyun
        22
    mingyun  
       May 4, 2017
    17 楼正解
    surmon
        23
    surmon  
       May 5, 2017
    @LeeSeoung 那哪是 JSONP 搞定的,是 CORS
    ilaipi
        24
    ilaipi  
    OP
       May 6, 2017
    @lilydjwg 这个网站用 jq 的 ajax 方法,指定 method 是 post,这样的请求不算「跨域 POST 」的方式么?虽然代码里写了`method: 'post'`,但是又写了`dataType: jsonp`,然后就会让`method: post`失效了么?

    好消息是,刚刚我模拟这个 get 请求成功了。之前一直写成 post,总是模拟不成功,改成 get 成功了,太棒了。
    lilydjwg
        25
    lilydjwg  
       May 7, 2017
    @ilaipi #24 上边已经说过很多遍了,jsonp 只支持 GET。我也不知道那样做 jQuery 是怎么想的,反正实际发出的也是 GET 请求。

    请你相信这里的人的能力。就算还不到参与 W3C 标准讨论和制定的程序,至少阅读并理解 W3C 标准是毫无问题的。
    mkeith
        26
    mkeith  
       May 19, 2017
    @zhangsan jsonp 是使用动态添加 javascript 标签实现的啊???
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3238 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 78ms · UTC 14:37 · PVG 22:37 · LAX 07:37 · JFK 10:37
    ♥ Do have faith in what you're doing.