|版权声明:本文为博主原创文章,未经博主允许不得转载。

上一个Part已经给TSSS编好了一个简单的Web服务,网页的基础模版也写好了,那从这个Part开始就慢慢增加编写功能。

先写基础功能:注册和登录的实现


复杂的安全cookies实现可以看这里 使用安全cookies,因为快速建站这个其实只相当于一个小demo,所以复杂的用户系统会在以后实现,现在只需要实现拥有用户名,密码,昵称和用户权限声明的一个用户系统就可以了。

看一下users的数据库规范然后再写代码

#数据库规范
codedb:users
	_id 		        ID
	username 	     用户名
	password     	     密码
	nickname	        昵称
        roleid                 权限声明

先写出来注册页面signup.html↓

 {% extends "main.html" %}
 {% block content %}
 <form role="form"  action="/sign/up" method="POST">
     <div class="form-group">
         <label for="exampleInput"></label>用户名<input class="form-control" name="username" />
     </div>
     <div class="form-group">
         <label for="exampleInputPassword1">密码</label><input type="password" class="form-control" id="exampleInputPassword1" name="password" />
     </div>
     <div class="form-group">
         <label for="exampleInput">昵称</label><input class="form-control"  name="nickname" />
     </div>
     <div class="checkbox">
         <label><input type="checkbox" />Check me out</label>
     </div> <button type="submit" class="btn btn-default">提交</button>
 </form>
 {% end %}

再写个登录页面signin.html↓

 {% extends "main.html" %}
 {% block content %}
 <form role="form" action="/sign/in" method="POST">
     <div class="form-group">
         <label for="exampleInput"></label>用户名<input class="form-control" name="username" />
     </div>
     <div class="form-group">
         <label for="exampleInputPassword1">密码</label><input type="password" class="form-control" id="exampleInputPassword1" name="password" />
     </div>
     <div class="checkbox">
         <label><input type="checkbox" />Check me out</label>
     </div> <button type="submit" class="btn btn-default">登录</button>
 </form>
 {% end %}

然后写SignHandler↓

 class SignHandler(web.RequestHandler):
     def get(self,choice):
         if choice == 'in':
             self.render('sign\signin.html')
         else if choice == 'up':
             self.render('sign\signup.html')
     def post(self,choice):
         coll = self.application.db.users
         if choice == 'in':
             username = self.get_argument('username')
             if coll.find_one({'username':username}):
                 if self.get_argument('password')==coll.find_one({'username':username})['password']:
                     self.set_cookie('username',username)
                     self.set_cookie('nickname',coll.find_one({'username':username})['nickname'])
                     self.redirect('/')
                 else:
                     self.write({'error':'password is wrong'})
             else:
                 self.write({'error':'no this user'})
         else if choice == 'up':
             username = self.get_argument('username')
             password = self.get_argument('password')
             nickname = self.get_argument('nickname')
             if coll.find_one({'username':username}):
                 self.write({'error':'the username has been used'})
             else:
                 coll.insert({'username':username,'password':password,'nickname':nickname,'roleid':0})
                 self.redirect('/')

这样注册和登录的功能就实现了

--Part.Three--

Python快速建站系列-Part.Three-注册和登录的更多相关文章

  1. Python快速建站系列-Part.One-组装开发环境

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 源代码都在github上:SmallStudyStation 现在是个demo,但回来会租个服务器,等功能完善了放到服务器上挂着,域名jusot ...

  2. Python快速建站系列-Part.Five.1-个人主页及发表文章

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 现在的TSSS已经有了注册和登录的功能,首页的内容也填充好了,那这一节就完成用户个人主页的内容和发表文章功能的实现. 先完成用户个人主页的use ...

  3. Python快速建站系列-Part.Four-首页内容填充

    |版权声明:本文为博主原创文章,未经博主允许不得转载. Part.Three中实现了注册和登录的功能,那这一节完成主页内容的填充,并且主页中要实现简单的可以查找代码的功能. 而且有于公共代码部分存储在 ...

  4. Python快速建站系列-Part.Two-结构化和布局

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 首先明确我们要建一个什么样的站,作为教程(也算自己使用tornado的一个小总结),自然功能不能太多,但又满足一个普通网站需要的就行了. 目前想 ...

  5. Python快速建站系列-Part.Six-文章内容浏览

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 其实到这里网站的基本功能已经完成一半了,第六节就完成文章内容的阅读功能. 完成blogview.html↓ {% extends "m ...

  6. Python快速建站系列-Part.Five.3-个人主页及资料页面

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 第五部分最后一节,完成个人主页里资料页面的个人资料的展示和修改功能,不过毕竟功能比较少,个人资料其实只有昵称一项,手动滑稽. 一如既往先写出来u ...

  7. Python快速建站系列-Part.Five.2-个人主页及文章列表

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 从usercen.html就可以发现我为个人主页设了三个分开的小版面:写文章.个人文章目录.个人资料 所以按顺序Part.Five的第二部分就完 ...

  8. PHPCMS快速建站系列之网站迁移(本地到服务器,服务器迁移,更换域名等)

    可能出现的问题: 1.后台登录验证码显示不正常(修改/caches/configs/system.php文件) //网站路径'web_path' => '/', 2.phpsso修改 如果不修改 ...

  9. PHPCMS快速建站系列之搜索功能

    默认模板的搜索功能代码 <div class="bd"> <form action="{APP_PATH}index.php" method= ...

随机推荐

  1. mysql主从复制过滤

    主从复制过滤: 配置文件中的[mysqld]块中: master:(考虑到即时点还原一般不在主过滤) binlog_do_db= #数据库白名单 binlog_ignore_db= #数据库白名单 s ...

  2. php继承后构造函数的特性

    在5.x版本的php中: 如果父类有构造函数,它的子类也有构造函数,那么在运行子类时就“不会执行父类的构造函数”. 要想执行父类的构造函数,需要在子类的构造函数中加上: parent::__const ...

  3. PHP执行系统命令

    <?phpexec("ping www.baidu.com -n 1",$output,$status);var_dump($output);var_dump($status ...

  4. asp.net 与数据库操作

    <configuration> <system.web><compilation debug="true" targetFramework=" ...

  5. javascript平时小例子⑥(简易计算器的制作)

    <!doctype html><html><head><meta charset="utf-8"><title>无标题文 ...

  6. C++中嵌入Lua脚本环境搭建

    第一步(环境准备工作): 工具: ●LuaForWindows_v5.1.4-46.exe傻瓜式安装. 作用:此工具可以在windows环境下编译运行Lua脚本程序.安装完成后会有两个图标:Lua和S ...

  7. Vue 双向数据绑定原理分析 以及 Object.defineproperty语法

    第三方精简版实现 https://github.com/luobotang/simply-vue Object.defineProperty 学习,打开控制台分别输入以下内容调试结果 userInfo ...

  8. HTTP Status 500 - org.apache.jasper.JasperException: com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException

    HTTP Status 500 - org.apache.jasper.JasperException: com.sun.org.apache.xerces.internal.impl.io.Malf ...

  9. 杭电ACM 1201

    #include <stdio.h> int func(int year){ if ( year % 400 == 0 || (year % 4 == 0 &&year % ...

  10. Sharepoint 2013 回收站知识整理

    回收站机制可有利于防止内容的永久删除与误删除. 一.SharePoint 2013 回收站包括两种:第一回收站(End user Recycle Bin items)与 第二回收站(Deleted f ...