django中url,静态文件,POST请求的配置

平时使用的是pycharm,所以这篇文章主要也是使用pycharm默认创建的django项目为基础进行讲解。项目目录如下图:

1.URL的配置

当创建好项目后,运行项目就可以看到django默认的页面。那么怎么访问自己创建的页面呢?

因为django是类MVC的开发模式。这里面就涉及到配置URL的问题。创建一个自己的APP(也可以称为一个模块),包含的文件内容如下图:

然后需要在setting.py的文件INSTALLED_APPS中注册新创建的App:

新创建项目的默认url配置如下:

from django.conf.urls import patterns, include, url
from django.contrib import admin

admin.autodiscover()

urlpatterns = patterns(‘‘,
                       # Examples:
                       # url(r‘^$‘, ‘django_static_file_config.views.home‘, name=‘home‘),
                       # url(r‘^blog/‘, include(‘blog.urls‘)),
                       url(r‘^admin/$‘, include(admin.site.urls)),
                       )

那么怎么把新创建的Appurls.py和项目默认的urls.py关联起来呢?需要做如下的配置:

from django.conf.urls import patterns, include, url
from django.contrib import admin

admin.autodiscover()

urlpatterns = patterns(‘‘,
                       # Examples:
                       # url(r‘^$‘, ‘django_static_file_config.views.home‘, name=‘home‘),
                       # url(r‘^blog/‘, include(‘blog.urls‘)),
                       url(r‘^admin/$‘, include(admin.site.urls)),
                       #通过include()函数包含新APP种的url
                       url(r‘^load/‘, include(‘index.urls‘)),
                       )

新创建APP中的urls.py的配置如下:

#!usr/bin/env python
# coding: utf-8
from django.conf.urls import patterns
from django.conf.urls import url

urlpatterns = patterns(‘‘,
                       url(r‘^load_index/$‘, ‘index.view.load_index‘, name=‘load_index‘),
                       )

那么访问的url是:

http://127.0.0.1:8000/load/load_index/

上面两个配置文件的意义是:

当django接收到请求的时候,会按照url中的层级中第一层(例子中的时/load/)去扫描默认的配置文件,即下面的这条语句:

 url(r‘^load/‘, include(‘index.urls‘)),

如果能够扫瞄到就接着按照第二层load_index去扫描include导入的url,也就是项目中新创建APP的urls.py中url是否有匹配项。

2.静态文件的配置

之前在学习django的时候,在静态文件的配置上花费了很多时间,而且没有解决问题,网上也是一搜一大堆的各种解决办法,但是仍然不适用自己的项目。因为不同版本的django都会有些变化,所以强烈建议根据自己的当前版本,选择阅读官方文档:

首先看django的官方文档(我使用的版本是django1.6版本):

https://docs.djangoproject.com/en/1.6/howto/static-files/

当创建一个django的项目的时候在项目的根目录都会生成一个默认的配置文件setting.py:

关于静态文件的默认配置如下代码:

# Static files (CSS, JavaScript, Images)
# 这里已经为我们生成了官方文档的地址
# https://docs.djangoproject.com/en/1.6/howto/static-files/

STATIC_URL = ‘/static/‘

TEMPLATE_DIRS = (
    os.path.join(BASE_DIR,  ‘templates‘),
)

阅读过官方文档以后(强烈建议),我们只需要在setting.py中添加如下的代码指定静态文件的目录即可:


# -----config static file
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, "static"),
)

当我浏览网页的时候,可以发现能够正确的找到静态文件。如下图:

3.POST请求的配置

在看post请求之前,先看一下get请求的方式,前端jQuery的代码如下:

$(function () {
    $(‘.test-post‘).on(‘click‘, function () {
        var url = ‘/load/getmethod/‘
        $.ajax({
            type: ‘GET‘,
            data:{
              test:‘test‘
            },
            url: url,
            success: testSuccess,
            dataType: ‘html‘,
            async: false
        });
    });
})
var testSuccess =function (){
};

后端python处理的方式:

def getmethod(request):
    test = request.GET.get(‘test‘,‘‘)
    return HttpResponse(test)

能够正常接收到get方式传递的参数:

看下结果,如下图:

那么使用POST的方式会怎么样呢?

只需要修改jQuery代码中的参数即可,先修改url为:

var url = ‘/load/postmethod/‘

然后修改:

 type: ‘POST‘,

当再次尝试往后端传递参数的时候,结果如下图:

发生了403的错误,请求被拒绝了。这是因为django默认的配置MIDDLEWARE_CLASSES中一个中间件CSRF(跨站请求伪造),维基百科地址(点击这里):

‘django.middleware.csrf.CsrfViewMiddleware‘,

post请求做了验证。

第一种解决办法:

我们首先尝试注释掉这一行,验证是否能够正常的发送POST请求。

可以看到结果是OK的,如下图:

第二种解决办法:

导入

from django.views.decorators.csrf import csrf_exempt

模块,并且在接受post的参数的函数前面添加如下的前缀,

@csrf_exempt
def postmethod(request):
    test = request.POST.get(‘test‘,‘‘)
    return HttpResponse(test)

经过验证,可以正常的接受post请求(有一个缺点就是,在项目的所有的POST请求的处理函数前面都得加这样的标记):

CSRF推荐阅读:

http://www.cnblogs.com/lins05/archive/2012/12/02/2797996.html

时间: 2024-12-20 01:21:04

django中url,静态文件,POST请求的配置的相关文章

在django中访问静态文件(js css img)

刚开始参考的是别的文章,后来参考文章<各种 django 静态文件的配置总结>才看到原来没有但是没有注意到版本,折腾了一晚上,浪费了很多很多时间.后来终于知道搜索django1.7访问静态文件.真是傻×. 环境:python 2.7.3django 1.7.5 django是不善于处理静态文件这种事情的.这样的工作要交给nginx或者apache这样的服务器.但是在调试时还是要配置一下的django 1.7.5配置访问静态文件貌似比其他的版本都要简单一些.只需要如下步骤: 收集静态文件,然后放

Django中的静态文件导入

1. 在django项目的根目录创建名为static的python包,亦可创建在app中 2. 更改项目的settings.py文件 STATIC_URL = '/static/' STATICFILES_DIRS = ( os.path.join(BASE_DIR, 'static'), ) STATIC_URL = '/static/' 中的static为静态文件的绝对路径的别名,与包名static不同,包名可以随便取名.在调用静态文件时,只能用别名. 这样做的好处是,便与后期更改,STAT

Django 中的js文件 post请求的url无法使用使用{% url ‘path’ %}

具体问题: 解决方法1:

Swift3.0服务端开发(二) 静态文件添加、路由配置以及表单提交

今天博客中就来聊一下Perfect框架的静态文件的添加与访问,路由的配置以及表单的提交.虽然官网上有聊静态文件的访问的部分,但是在使用Perfect框架来访问静态文件时还是有些点需要注意的,这些关键点在其官方文档上并未提出.今天我们要做的事情就是通过浏览器访问静态文件,然后在静态文件中使用form表单往指定的路由上进行提交相应的数据. 一.静态文件的添加与访问 1.未使用Xcode管理的Perfect的静态文件根目录的配置 在PHP开发或者Java Web开发中,都有一个根目录来存储相应的静态文

使用Django来处理对于静态文件的请求

引言 本方法适用于linux+python2.7+django1.2,使用django自带的web服务. 同样也适用于sina app engine. 1.准备工作 准备css文件,准备js文件,准备image文件. 在网站根目录新建目录[medias],在[medias]目录新建目录[styles],用来存放css文件. 2.配置对于静态文件访问的路径 2.1.在settings.py文件中添加静态文件的目录 假设mysite是网站的根目录,medias是刚才我们新建的目录 ? 1 2 3 4

django中url路由配置及渲染方式

今天我们学习如何配置url.如何传参.如何命名.以及渲染的方式,内容大致有以下几个方面. 创建视图函数并访问 创建app django中url规则 捕获参数 路径转换器 正则表达式 额外参数 渲染方式 创建视图并访问 项目中自带的Python文件中,并没有带有视图,因此我们自己创建一个,通常,我们把视图命名views.py. 然后在views.py中,导入头文件  from django.http import HttpResponse 然后我们在views.py中,写一些Python函数,用来

Dotnet Core 在ASP.NET Core中使用静态文件

来自微软官网  在ASP.NET Core中使用静态文件:https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/static-files: 提供静态文件 静态文件通常位于web root(<content-root> / wwwroot)文件夹中.有关详细信息,请参阅内容根和Web根.您通常将内容根设置为当前目录,以便web root在开发过程中找到项目. public static void Main(string[] args)

Django中url的逆向解析 -&gt; Reverse resolution of URLs

之前的一篇文章中介绍了url的基本用法[Django的url用法] 解析的过程可以概括为URL request -> view calling 同时,django又提供了另一种解析方式 - Reverse resolution of URLs 它的解析过程为 view calling -> URL request 因为Django奉行的是DRY原则,所以使用这种方式,就无需对url地址进行硬编码.在原本需要硬编码url的地方,直接可以使用url的名字,然后逆向解析出url地址. Django提

Asp.Net Core 中的静态文件

Asp.Net Core 中的静态文件 在这节中我们将讨论如何使 ASP.NET Core 应用程序,支持静态文件,如 HTML,图像,CSS 和 JavaScript 文件. 静态文件 默认情况下,Asp.Net Core 应用程序不会提供静态文件. 静态文件的默认目录是wwwroot,此目录必须位于项目文件夹的根目录中. 将图片复制并粘贴到 wwwroot 文件夹中.我们假设文件的名称是 banner.jpg.为了能够从浏览器访问此文件,路径为:http://{{serverName}}/b

霸气!Nginx 中缓存静态文件秘籍

导读 这篇教程说明你应该怎样配置 nginx.设置 HTTP 头部过期时间,用 Cache-Control 中的 max-age 标记为静态文件(比如图片. CSS 和 Javascript 文件)设置一个时间,这样用户的浏览器就会缓存这些文件.这样能节省带宽,并且在访问你的网站时会显得更快些(如果用户第二次访问你的网站,将会使用浏览器缓存中的静态文件). 1.准备事项 我想你需要一个正常工作的 nginx 软件,可以查看另一篇的帖子:在 Ubuntu 16.04 LTS 上安装 Nginx,P