当前位置: 首页 > 编程笔记 >

浅谈在django中使用redirect重定向数据传输的问题

南门建章
2023-03-14
本文向大家介绍浅谈在django中使用redirect重定向数据传输的问题,包括了浅谈在django中使用redirect重定向数据传输的问题的使用技巧和注意事项,需要的朋友参考一下

环境:

python 3.6.4

django2.0.6

使用重定向redirect(‘url name') 如果不需要传数据的话那这样就OK了 如果要传数据的话 我琢磨了半天 还是决定用session来传输

所以 就这么干:

request.session['key_name] = value

request.session['msg'] = u'用户未登录'

然后在模板中使用:

<h1>{{ request.session.username }}</h1> {# 输出username保存的值 #}
{# {{ request.session['username' }} 以及{{ request.session.get('username') }} 和{% request.session.get('username') %} 都是错误的写法 #}}

就可以了。嗯 搞定。

补充知识:在django中,redirect如何传递message。

众所周知,在django中,默认的message,只能在同一个request中传递。

但如果在请求过程中,使用了redirect跳转,那么,这个一次性的message就会失败,

无法在前端给用户提示。

https://stackoverflow.com/questions/29673537/django-redirect-with-context/29673951#29673951

网上提供的思路,有如下两种:

一,使用message框架中的storeage存储实现。我觉得如果消息使用得频繁,且消息比较长时使用。

二,使用session来实现,这个实现更简单,但不可太频繁使用。

下面,就使用第二种来试试吧。

1,在有redirect的view中,加入session。

# 跨request传递message,使用session。
self.request.session['create_app'] = name
return redirect(reverse_lazy('app:list', args=()))

2,在需要获取message的view中,加入消息。

# 获取创建组件成功的session提示,同request传递message。
create_app = self.request.session.pop('create_app', False)
if create_app:
   messages.info(self.request, '{}创建成功,请编辑它的配置!'.format(create_app))

3,在前端网页中,显示此message。

{% for message in messages %}
<div class="alert alert-success alert-dismissible fade in" role="alert">
  <button type="button" class="close" data-dismiss="alert" aria-label="Close">
    <span aria-hidden="true">×</span>
  </button>
  <strong>组件创建提示!</strong> {{ message }}.
</div>
{% endfor %}

4,样子

以上这篇浅谈在django中使用redirect重定向数据传输的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 通过重定向界面,您可以将域或特定网页的所有访问者或流量发送到新域。 例如,如果您将网站移至新域并且想要将所有访问者重定向到新网站,则需要设置重定向。 有两种类型的重定向可用 - Permanent (301) Redirect 这会将您的访问者重定向到新网站并更新访问者的书签。 这也会将搜索引擎引导到您的新网站。 此重定向是渗透性的,意味着页面已移动。 因此,搜索引擎和其他抓取工具会根据新链接更新

  • 本文向大家介绍浅谈Django前端后端值传递问题,包括了浅谈Django前端后端值传递问题的使用技巧和注意事项,需要的朋友参考一下 前端后端传值问题总结 前端传给后端 通过表单传值 1、通过表单get请求传值 在前端当通过get的方式传值时,表单中的标签的name值将会被当做action的地址的参数 此时,在后端可以通过get请求相应的name值拿到对应的value值 例子: html中: 视图中

  • 重定向到一个 URL 。 使用 window.location.href 或 window.location.replace() 重定向到 url 。 传递第二个参数来模拟链接点击(true - 默认值)或HTTP重定向(false)。 const redirect = (url, asLink = true) => asLink ? (window.location.href = url)

  • +++ title = “Redirect 重定向” url = “/middleware/redirect” [menu.side] name = “Redirect 重定向” parent = “middleware” weight = 5 +++ Redirect 中间件 HTTPS 重定向 HTTPS 重定向中间件将 http 请求重定向到 https。例如,http://laily.ne

  • 本文向大家介绍浅谈jquery中使用canvas的问题,包括了浅谈jquery中使用canvas的问题的使用技巧和注意事项,需要的朋友参考一下 使用jquery控制canvas的时候会出现一些问题, 修改的方式为: 原因:jQuery()返回的是jQuery对象,而jQuery对象是没有getContext方法的,需要把jQuery对象转换成Dom对象,官方文档推荐的方法如上述代码,其实jQuer

  • 本文向大家介绍浅谈vue中数据双向绑定的实现原理,包括了浅谈vue中数据双向绑定的实现原理的使用技巧和注意事项,需要的朋友参考一下 vue中最常见的属v-model这个数据双向绑定了,很好奇它是如何实现的呢?尝试着用原生的JS去实现一下。 首先大致学习了解下Object.defineProperty()这个东东吧! 以上总结了对象的defineProperty四个属性:configurable,e