## 實例:用戶登錄
**創建用戶表userinfos**
* 表結構如下
* id
* uname
* upwd
* isdelete
* 注意:需要對密碼進行加密
* 如果使用md5加密,則密碼包含32個字符
* 如果使用sha1加密,則密碼包含40個字符,推薦使用這種方式
~~~
create table userinfos(
id int primary key auto_increment,
uname varchar(20),
upwd char(40),
isdelete bit default 0
);
~~~
## 加入測試數據
* 插入如下數據,用戶名為123,密碼為123,這是sha1加密后的值
~~~
insert into userinfos values(0,'123','40bd001563085fc35165329ea1ff5c5ecbdbbeef',0);
~~~
## 接收輸入并驗證
* 創建testLogin.py文件,引入hashlib模塊、MysqlHelper模塊
* 接收輸入
* 根據用戶名查詢,如果未查到則提示用戶名不存在
* 如果查到則匹配密碼是否相等,如果相等則提示登錄成功
* 如果不相等則提示密碼錯誤
~~~
#encoding=utf-8
from MysqlHelper import MysqlHelper
from hashlib import sha1
sname=raw_input("請輸入用戶名:")
spwd=raw_input("請輸入密碼:")
s1=sha1()
s1.update(spwd)
spwdSha1=s1.hexdigest()
sql="select upwd from userinfos where uname=%s"
params=[sname]
sqlhelper=MysqlHelper('localhost',3306,'test1','root','mysql')
userinfo=sqlhelper.get_one(sql,params)
if userinfo==None:
print '用戶名錯誤'
elif userinfo[0]==spwdSha1:
print '登錄成功'
else:
print '密碼錯誤'
~~~
## python3代碼:
~~~
#!/usr/bin/env python
# -*- coding: utf-8 -*-
'''
@Time : 5/15/18 1:43 AM
@Author : haibo
@File : Login.py
'''
# 用自己封裝的MysqlHelper 模擬用戶登錄
from MysqlHelper import MysqlHelper
import hashlib
# 接收用戶輸入
name = input("請輸入用戶名:")
pwd = input("請輸入密碼:")
params = [name]
# 對密碼加密
s1 = hashlib.sha1()
s1.update(pwd.encode("utf-8"))
spwd = s1.hexdigest()
# 根據用戶名來查詢密碼
sql = "select upwd from userinfos where uname=%s"
test = MysqlHelper("localhost", 3306, "python3", "root", "haibo")
result = test.all(sql, params)
if len(result) == 0:
print("用戶名錯誤!")
elif result[0][0] == spwd:
print("登錄成功!")
else:
print("密碼錯誤!")
~~~
- mysql
- 1.創建庫和表
- 1.1.數據庫簡介
- 1.2.安裝管理
- 1.3.數據完整性
- 1.4.命令腳本操作
- 2.查詢
- 2.1.條件
- 2.2.聚合
- 2.3.分組
- 2.4.排序
- 2.5.分頁
- 3.高級
- 3.1.關系
- 3.2.連接
- 3.3.自關聯
- 3.4.子查詢
- 3.5.內置函數
- 3.6.視圖
- 3.7.事務
- 4.與python交互
- 4.1.交互類型
- 4.2.增改刪
- 4.3.查詢
- 4.4.封裝
- 4.5.用戶登錄
- Nosql簡介
- mongodb
- 1.基本操作
- 1.1.環境安裝
- 1.2.數據庫操作
- 1.3.集合操作
- 1.4.數據類型
- 1.5.數據操作
- 1.6.數據查詢
- 1.6.1.Limit與Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.統計個數
- 1.6.5.消除重復
- 2.高級操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.復制(副本集)
- 2.4.備份和恢復
- 2.5.與python交互
- redis
- 1.基本配置
- 2.數據操作
- 2.1.string
- 2.2.鍵命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高級
- 4.1.發布訂閱
- 4.2.主從配置
- 5.與python交互
- 6.login登陸完善