python3 django整理(九) django 接收参数,以json彼此传递post与get

本文深入解析POST与GET两种HTTP请求方法的区别,包括数据传输位置、安全性考量及服务器处理方式。并通过一个Django示例,展示如何在实际项目中应用POST请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载请注明出处:https://blog.youkuaiyun.com/HHTNAN/
首先我们来说一说,post与get的区别
POST和GET差异:

  1. POST和GET是HTTP协议定义的与服务器交互的方法。GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。另外,还有PUT和DELETE方法。

  2. POST和GET都可以与服务器完成查,改,增,删操作。

  3. GET提交,请求的数据会附在URL之后,以?分割URL和传输数据,多个参数用&连接;

    POST提交,把提交的数据放置在HTTP包的包体中;因此,GET提交的数据会在地址栏中显示出来,而POST提交,地址栏不会改变。

HTTP没有要求,如果Method是POST数据就要放在BODY中。也没有要求,如果Method是GET,数据(参数)就一定要放在URL中而不能放在BODY中。

HTTP协议对GET和POST都没有对长度的限制
HTTP协议明确地指出了,HTTP头和Body都没有长度的要求。而对于URL长度上的限制,有两方面的原因造成:

  1. 浏览器。据说早期的浏览器会对URL长度做限制。据说IE对URL长度会限制在2048个字符内(流传很广,而且无数同事都表示认同)。但我自己试了一下,我构造了90K的URL通过IE9访问live.com,是正常的。网上的东西,哪怕是Wikipedia上的,也不能信。

  2. 服务器。URL长了,对服务器处理也是一种负担。原本一个会话就没有多少数据,现在如果有人恶意地构造几个几M大小的URL,并不停地访问你的服务器。服务器的最大并发数显然会下降。另一种攻击方式是,把告诉服务器Content-Length是一个很大的数,然后只给服务器发一点儿数据,嘿嘿,服务器你就傻等着去吧。哪怕你有超时设置,这种故意的次次访问超时也能让服务器吃不了兜着走。有鉴于此,多数服务器出于安全啦、稳定啦方面的考虑,会给URL长度加限制。但是这个限制是针对所有HTTP请求的,与GET、POST没有关系。

首先在view中定义一个post请求,
django 2.0.5
Python 3.6.5

views中的请求函数

def apis(request):
     print("hello input")
     # p={"word":"data"}
     #查看客户端发来的请求,前端的数据
     print("request.body={}".format(request.body))
     #返回给客户端的数据
     result="success"
     if request.method=="POST":
         print(request.POST)

     return JsonResponse({"status": 200, "msg": "OK","data": result})

这里写图片描述

由于是post的请求,所以其请求体在request.body中,即客户端发过来的请求,即前端发过来的参数。一般都会对参数进行处理,之后返回result再次传输给前端,这里我没有进行处理,直接返回给以一个result.

之后配置url
这里写图片描述

最后新建一个client(客户端)来测试接口是否成功。这里是使用django 自带的tests.py 写了一个函数。

from django.test import TestCase

# Create your tests here.
import requests,json
def dodo():
    req={34:1}
    url='http://127.0.0.1:8000/apis'
    #params 为发送给服务器的请求
    params = {
          "name":"前端输入参数"
        }
    #请求头,是浏览器正常的就行
    headers = {"User-agent":"none/ofyourbusiness","Spam":"Eggs"}
    #发送请求,返回新数据
    data = requests.post(url,data=params,headers=headers)

    print(data)
    print(data.text)
dodo()

这里写图片描述
运行结果如上,表示成功。
我是做算法的,可能对于后端来说这个很简单,但是对于我这个算法来说弄了小半天。终于解决了,记录一下。

以下为参考的用django实现的获取用户输入方法示例。

URLS 配置
#urls.py
from django.conf.urls.defaults import *
from mysite.views import search , result
# Uncomment the next two lines to enable the admin:
# from django.contrib import admin
# admin.autodiscover()

urlpatterns = patterns('',
    # Example:
    # (r'^mysite/', include('mysite.foo.urls')),
 
    # Uncomment the admin/doc line below to enable admin documentation:
    # (r'^admin/doc/', include('django.contrib.admindocs.urls')),
 
    # Uncomment the next line to enable the admin:
    (r'^$', search),
    (r'^search/$', result)
)

VIEW.py配置

    #views.py
    #-*- coding: UTF-8 -*-
    from django.shortcuts import render_to_response
     
    def search(request):
        return render_to_response('search.html')
    def result(request):
        key = request.GET['q']
        if not key :
            message = u'请输入搜索内容'
            return render_to_response('result.html',{'message':message})
        else :
            message = u'你输入的是' + key
            return render_to_response('result.html',{'message':message})
     
     
    <html><!--search.html-->
    <head>
        <title>Search</title>
    </head>
    <body>
        <form action="/search/" method="get">
            <input type="text" name="q">
            <input type="submit" value="Search">
        </form>
    </body>
    </html>
     
    <html><!--result.html-->
    <head>
        <title>Search</title>
    </head>
    <body>
            {{message}}
    </body>
    </html>

参考前台通过form表单向Django后台传输数据,Django处理后返回给前台

微信号
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT界的小小小学生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值