Python全栈 Web(Django框架、forms对象、cookie、session)

简介: Flask、Python、Django、框架、服务器、客户端、浏览器、交互、WEB、Python前端、CSS、JAVA、HTML、H5、PHP、JavaScript、JQuery、分布式开发、项目、flask项目、项目实战、django框架、Python项目、Python的Flask框架、Pytho.

forms模块的高级处理
    将models和forms结合到一起使用
    1.在forms.py中创建class  继承自forms.ModelForm
    2.创建一个内部类Meta来关联Model
        model  指定要关联的实体类是谁
        fields 指定从model中取出那些字段生成控件
            取值  "__all__"表示全部属性都要生控件
                 列表  声明允许生成控件的属性名
        labels 指定每个属性所关联的label  取值为字典
            label = {
                '属性名':'label文本',
                '属性名':'label文本',
            }

class RegisterForm(forms.ModelForm):
  #通过内部类Meta表示关联的信息
  class Meta:
    #1.指定关联的Model
    model = User
    #2.指定要生成控件的字段们
    fields = "__all__"
    #3.指定每个控件对应的label
    labels = {
      'uphone':'电话号码',
      'upwd':'登录密码',
      'uname':'用户名称',
      'uemail':'电子邮件',
    }

  if request.method == 'GET':
    form = RegisterForm()
    return render(request,'05-register.html',locals())

    小部件:
        什么是小部件?
            widget表示生成到页面上的控件类型以及其他的HTML属性
        常用小部件类型
            TextInput:      type="text"
            PasswordInput:  type="password"
            NumberInput:    type="number"
            EmailInput:     type="email"
            URLInput:       type="url"
            HiddenInput:    type="hidden"
            CheckboxInput:  type="checkbox"
            Textarea:       <textarea></textarea>
            Select:         <select></select>
        小部件的使用
            继承自forms.Form
                基本
                    只需要指定控件的类型
                    class RemarkForm(forms.Form):
                        属性 = forms.CharField(
                            label:'文本',
                            widget=forms.小部件类型
                        )
                高级
                    指定控件类型的基础上 还允许设置HTML的一些相关属性
                    属性 = forms.CharField(
                        label="文本"
                        widget=forms.小部件类型(
                            attrs = {
                                "html属性名":"html属性值",
                                "html属性名":"HTML属性值"
                            }
                        )
                    )

            继承自forms.ModelForm
                class xxxForm(forms.ModelForm):
                    class Meta:
                        model = User
                        fields = "__all__"
                        labels = {
                            "属性":"label"
                        }
                        widgets = {
                            "属性1": forms.小部件类型(attrs={
                            }),

                        }

class LoginForm(forms.ModelForm):
  class Meta:
    model = User
    fields = ['uphone','upwd']
    labels = {
      'uphone':'注册电话',
      'upwd':'登录密码',
    }
    #指定小部件
    widgets = {
      'upwd':forms.PasswordInput(attrs={
        'placeholder':'请输入您的密码'
      })
    }

class WidgetLoginForm(forms.Form):
  uphone = forms.CharField(label='电话号码')
  #为pwd指定小部件,显示为 密码框
  # upwd = forms.CharField(label='登录密码',widget=forms.PasswordInput)
  upwd = forms.CharField(
    label='登录密码',
    widget=forms.PasswordInput(
      attrs = {
        'placeholder':'请输入密码',
        'class':'form-control',
      }
    )
  )

cookies在Django中的实现
    django中使用cookies
        设置cookies:
            响应对象.set_cookie(key, value, expires)
              key:cookie的名字
              value:cookie的值
              expires:保存时间 以s为单位
            响应对象:
                HttpResponse()
                  resp = HttpResponse("hello")
                  resp.set_cookie(response, "xxx.html", locals())
                  return resp
                render()
        获取cookies的值:
            通过request.COOKIES 获取当前站点下对的所有的cookie的信息

def login_views(request):
  if request.method == 'GET':
    #判断uname是否存在于cookies中,如果有的话,直接提示登录成功,否则,去往09-login模板
    if 'uname' in request.COOKIES:
      return HttpResponse('您已成功登录过')
    return render(request,'09-login.html')
  else:
    # 获取用户名称和密码
    uname=request.POST['uname']
    upwd = request.POST['upwd']
    # 判断用户名称和密码的
    if uname=='wangwc' and upwd=='123456':
      # 如果用户名和密码正确的话,判断有没有勾住记住密码
      resp = HttpResponse("登录成功")
      if 'isSaved' in request.POST:
        # 如果有勾住记住密码,则将用户名称保存进cookies
        resp.set_cookie('uname',uname,60*60*24*90)
      return resp
    else:
      return HttpResponse('登录失败')

session在django中的实现:
    设置session的值:
        request.session["key"] = value
    获取session的值:
        value = request.session["key"]
    删除session的值
        del request.session["key"]
    在settings.py中设置session的相关设置
        SESSION_COOKIE_AGE
            设置 sessionID在cookies中的保存时间
            SESSION_COOKIE_AGE = 60 * 60 * 24  # 最多保存24小时
        SESSION_EXPIRE_AT_BROWSER_CLOSE
            设置关闭浏览器是则清空服务器上对应的session空间
            bool值

# 设置session
def setSession_views(request):
  request.session['uname']='wangwc'
  return HttpResponse('Set Session Succefull')

# 获取session
def getSession_views(request):
  uname = request.session['uname']
  return HttpResponse('uname:'+uname)

相关文章
|
16天前
|
JSON 数据库 数据格式
使用 Django Q 对象构建复杂查询条件
通过本文示例,我们展示了如何使用Django的Q对象来构建复杂的查询条件,以及如何实现分页功能。Q对象的强大之处在于它能够轻松地组合多个查询条件,支持“与”、“或”关系,极大地提高了查询的灵活性和可读性。希望本文对你在实际项目中使用Django ORM构建复杂查询有所帮助。
|
17天前
|
开发框架 中间件 PHP
Laravel框架:优雅构建PHP Web应用的秘诀
**Laravel 框架简介:** Laravel是PHP的优雅Web开发框架,以其简洁语法、强大功能和良好开发者体验闻名。它强调代码的可读性和可维护性,加速复杂应用的构建。基础步骤包括安装PHP和Composer,然后运行`composer create-project`创建新项目。Laravel的路由、控制器和Blade模板引擎简化了HTTP请求处理和视图创建。模型和数据库迁移通过Eloquent ORM使数据库操作直观。Artisan命令行工具、队列、事件和认证系统进一步增强了其功能。【6月更文挑战第26天】
19 1
|
18天前
|
JavaScript 前端开发 开发者
Angular框架:企业级Web应用的强大后盾
Angular,谷歌支持的JavaScript框架,因其组件化架构、双向数据绑定、依赖注入和路由系统,成为企业级Web开发首选。组件化促进代码重用,如`AppComponent`示例。双向数据绑定简化DOM操作,减少手动工作。依赖注入通过示例展示易管理依赖,提升测试性。路由则支持SPA开发,平滑页面过渡。Angular的特性增强了开发效率和应用质量,使其在Web开发领域保持领先地位。【6月更文挑战第25天】
22 2
|
19天前
|
存储 前端开发 JavaScript
VSCode调试揭秘:Live Server助力完美测试Cookie与Session,远超“Open in Browser“!
VSCode调试揭秘:Live Server助力完美测试Cookie与Session,远超“Open in Browser“!
|
1天前
|
安全 API 数据库
Django/Flask不只是框架,它们是你Web开发路上的超级英雄!
【7月更文挑战第14天】Django与Flask,Python Web开发的双雄。Django提供全面功能,如ORM、模板引擎,适合大型项目;Flask轻量灵活,适用于快速迭代的定制化应用。Django示例展示ORM简化数据库操作,Flask示例演示构建RESTful API的便捷。两者各有所长,为开发者创造无限可能。**
|
5天前
|
存储 JavaScript 前端开发
WEB三大主流框架之Angular
WEB三大主流框架之Angular
|
5天前
|
存储 JavaScript 前端开发
WEB三大主流框架之Vue.js
WEB三大主流框架之Vue.js
|
5天前
|
XML 前端开发 JavaScript
WEB三大主流框架之React
WEB三大主流框架之React
|
12天前
|
存储 JavaScript 安全
深入理解与应用:在Web框架中高效管理环境变量
【7月更文挑战第3天】本文阐述了在Web开发中使用环境变量的重要性,如增强安全性和灵活性,并以Django、Flask和Express为例展示了如何管理这些变量。通过`os.environ`或特定库,开发者可以从环境中读取配置,避免敏感信息硬编码。最佳实践包括最小权限、加密、默认值、文档化和环境隔离,确保项目安全和易维护。
35 0
|
18天前
|
移动开发 开发框架 JavaScript
技术心得记录:手机Web开发框架
技术心得记录:手机Web开发框架
19 0