python_django_web开发:9 DTL的url命名配置与博客编辑页面完善

先来配置 从主页面到 详情页的 url地址

<a href="article/{{ article.id }}" target="_blank">{{article.title}}</a>

Django超链接的目标地址:
DTL的特殊写法:

{% url ‘app_name:url_name’  param  %}

其中 app_name url_name 都是在url中配置的

url函数的名称参数 的两种写法:
1、根urls 写在include()的第二个参数位置 namespace=‘blog’
2、应用下则写在url()的第三个参数位置 name=‘article_page’

url.py

from . import views
from django.conf.urls import url


urlpatterns = [
    url(r'^index/', views.index, name='index'),
    url(r'^article/(?P<article_id>[0-9]+)$', views.article_page, name='article'),
    url(r'^article/edit/$',views.article_edit_page, name='article_edit_page'),
    url(r'^article/edit/action/$', views.article_edit_page_action, name='article_edit_page_action')
]

article_page.html

<a href="{% url 'blog:article_page' article.id %}" target="_blank">{{article.title}}</a>

下面来搞 编辑页面
页面内容:标题编辑栏 内容编辑栏 提交按钮 表单组件form

编辑表单的响应函数 action post
使用request.POST[‘参数名’]获取表单数据
创建对象:

models.Article.objects.create(title,content)

views.py


def article_edit_page_action(request):
    title = request.POST.get('title', '默认标题')
    content = request.POST.get('content', '默认内容')
    models.Article.objects.create(title=title, content=content)
    articles = models.Article.objects.all()

    return render(request, 'blog/index.html', {'articles': articles})

CSRF验证失败. 请求被中断. 安全性的问题 Django的安全性是比较高的

{%  csrf_token %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>博客的编辑页面</title>
</head>
<body>
<form action="{% url 'blog:article_edit_page_action' %}" method="post">
    {% csrf_token %}
    <label>博客标题
        <input type="text" name="title">
    </label>
    <br>
    <label>博客内容
        <input type="text" name="content">
    </label>
    <br>
    <input type="submit" name="提交">
</form>
</body>
</html>

跨站请求伪造 网站攻击

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值