'''
pip install redis redis 可以看成内存中的大字典 redis五大数据类型 --> 指的是第一层的value值的类型
- 字符串 "k1"
- 列表 [11,22,33,11]
- 集合 {11,22,33}
- 字典 {
'kk1':vv1,
'kk2':vv2,
'kk3':{} 这个value不能是字典,如果有需要,则需要转换成字符串的形式。
}
- 有序集合 {('alex',4),('standby',3),('egon',9)}
''' import redis conn = redis.Redis(host='10.0.0.2',port=6379) # 字符串
conn.set('k1','v1',ex=10)
conn.get('k1') # 列表
# 可以当消息队列来使用
conn.lpush('users','alex')
conn.rpush('users','eric')
conn.lpop('users')
conn.rpop('users') # 双向队列,可以hang住,可以模拟栈和队列, 爬虫,爬网页-广度优先和深度优先
conn.blpop('users',timeout=10)
conn.brpop('users',timeout=10) conn.expire('key','超时时间') count = conn.llen('users')
print(count) vals = conn.lrange('users',0,10)
print(vals) # redis针对列表类型,没有提供 iter 方法,需要自己实现
def list_scan_iter(key):
# count = conn.llen(key)
start = 0
step = 3
while True:
vals = conn.lrange(key,start,start+step)
start = start + step + 1
if not vals:
return
for val in vals:
yield val result = list_scan_iter('users')
for item in result:
print(item) # 集合 # 哈希 # 有序结合

遍历DB

import redis

conn = redis.StrictRedis(host='8.8.8.8', port=6379, db=8, password='1234567890')

cursor_num, keys = conn.execute_command('scan', 0, "count", 100)

while True:
print keys
if 0==int(cursor_num):
break
cursor_num, keys = conn.execute_command('scan', cursor_num, "count", 100)

  

Django通过redis实现session共享示例

安装插件 Django 1.11 以上版本才可以使用

pip2.7 install django-redis

配置插件

SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
SESSION_CACHE_ALIAS = 'default' CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://10.10.10.10:6379",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"CONNECTION_POOL_KWARGS": {"max_connections": 100},
"PASSWORD": "your_password_for_redis",
}
}
}

使用redis

from django_redis import get_redis_connection
conn = get_redis_connection("default")

使用redis存储session信息

class UserAuth(object):
def __init__(self, request, response=None, user=None, autologin=None):
self.request = request
self.response = response
if user:
self.uid = str(user.id)
self.name = str(user.username)
self.autologin = autologin
self.sessionkey = None
self.logger = get_logger('UserAuth') def session_check(self):
self.sessionkey = self.request.COOKIES.get('yoursessionkey', None)
if self.sessionkey and conn.exists('yoursessionkey_%s' % self.sessionkey):
return conn.hget('yoursessionkey_%s' % self.sessionkey, 'userinfo')
return None def set_cookie_session(self):
self.sessionkey = self.request.COOKIES.get('yoursessionkey', None)
ttl = 60*60*24 if self.autologin else 60*60
if not self.sessionkey:
# set cookie
h = hashlib.md5()
h.update(str(int(time.time())))
self.sessionkey = h.hexdigest()
self.response.set_cookie('yoursessionkey', h.hexdigest(), max_age=ttl)
self.logger.error('New sessionid: {} for {}'.format(self.sessionkey,self.name)) key = 'yoursessionkey_%s' % self.sessionkey
if not conn.exists(key):
# set session
conn.hset(key, 'userinfo', '_'.join([self.name,self.uid]))
conn.expire(key,ttl)
self.logger.error('New redis key: {}, ttl: {}'.format(key,ttl))
return True

登录的视图函数

def verify(raw_password,encoded):
# 以PBKDF2PasswordHasher这个算法为例
from django.contrib.auth.hashers import PBKDF2PasswordHasher
hasher = PBKDF2PasswordHasher()
algorithm, iterations, salt, hash = encoded.split('$', 3)
encoded2 = hasher.encode(raw_password, salt, int(iterations))
return encoded == encoded2 class LoginForm(forms.Form):
username = forms.CharField()
password = forms.CharField(widget=forms.PasswordInput)
autologin = forms.BooleanField(required=False)
next = forms.CharField(widget=forms.HiddenInput) def user_login(request):
next = request.GET.get('next',reverse('index'))
if 'POST' == request.method:
form = LoginForm(request.POST)
if form.is_valid():
name = form.cleaned_data['username']
pwd = form.cleaned_data['password']
autologin = form.cleaned_data['autologin']
user = UserInfo.objects.filter(username=name)
if user[0] and verify(pwd,user[0].password):
response = redirect(next)
user_auth = UserAuth(request, response, user[0], autologin)
if user_auth.set_cookie_session():
user.update(last_login=time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
return response
context = {'form':form,'errors':'用户名或密码错误'}
return render(request,'login.html',context)
else:
context = {'form':form,'errors':'用户名或密码不能为空'}
return render(request,'login.html',context)
form = LoginForm({'next':next})
context = {'form':form}
return render(request,'login.html',context)

登录验证中间件

import re
from django.shortcuts import redirect
from django.utils.deprecation import MiddlewareMixin
from django.conf import settings class UserAuthMiddleware(MiddlewareMixin):
def process_request(self,request):
# Set white list which not check login
current_request_url = request.path_info
for url in settings.VALID_URL_LIST:
if re.match(url, current_request_url):
return None
user_auth = UserAuth(request)
if user_auth.session_check():
return None
else:
import urllib
params = urllib.urlencode({'next':request.path_info})
return redirect('/userlogin' + "?" + params)

  

参考:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

redis基本操作的更多相关文章

  1. 三、Redis基本操作——List

    小喵的唠叨话:前面我们介绍了Redis的string的数据结构的原理和操作.当时我们提到Redis的键值对不仅仅是字符串.而这次我们就要介绍Redis的第二个数据结构了,List(链表).由于List ...

  2. 二、Redis基本操作——String(实战篇)

    小喵万万没想到,上一篇博客,居然已经被阅读600次了!!!让小喵感觉压力颇大.万一有写错的地方,岂不是会误导很多筒子们.所以,恳请大家,如果看到小喵的博客有什么不对的地方,请尽快指正!谢谢! 小喵的唠 ...

  3. 一、Redis基本操作——String(原理篇)

    小喵的唠叨话:最近京东图书大减价,小喵手痒了就买了本<Redis设计与实现>[1]来看看.这里权当小喵看书的笔记啦.这一系列的模式,主要是先介绍Redis的实现原理(可能很大一部分会直接照 ...

  4. Redis基本操作-20150608

    Redis基本操作-20150608 [http://my.oschina.net/u/241255/blog/206991]   Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存 ...

  5. 【原】Redis基本操作

    Redis基本操作 遍历操作 Pub-Sub server Lua脚本 Redis中的这些操作都是不分大小写的. 除了针对于具体类型的具体操作.还有一些其他操作. 遍历操作 SCAN cursor [ ...

  6. Redis基本操作——List

    Redis基本操作——List(原理篇) 学习过数据结构的同学,一定对链表(Linked List)十分的熟悉.相信我们自己也曾经使用过这种数据结构. 链表分为很多种:单向链表,双向链表,循环链表,块 ...

  7. Redis基本操作-list

    Redis的5种数据结构:string.list.hash.set和zset; Redis 所有的数据结构都是以唯一的 key 字符串作为名称,然后通过这个唯一 key 值来获取相应的 value 数 ...

  8. Redis基本操作-string

    Redis的5种数据结构:string.list.hash.set和zset; Redis 所有的数据结构都是以唯一的 key 字符串作为名称,然后通过这个唯一 key 值来获取相应的 value 数 ...

  9. jedis使用线程池封装redis基本操作

    redisclient jedis 经常使用的 操作 key value hash list set zset 的基本操作 package cn.zto.util; import java.util. ...

  10. Redis 基本操作(一)

    redis和普通的Key-Value结构不同,Redis的Key支持灵活的数据结构,除了strings,还有hashes.lists. sets 和sorted sets等结构.正是这些灵活的数据结构 ...

随机推荐

  1. 【BZOJ5471】[FJOI2018]邮递员问题(动态规划)

    [BZOJ5471][FJOI2018]邮递员问题(动态规划) 题面 BZOJ 洛谷 给定平面上若干个点,保证这些点在两条平行线上,给定起点终点,求从起点出发,遍历所有点后到达终点的最短路径长度. 题 ...

  2. 【BZOJ4832】抵制克苏恩(矩阵快速幂,动态规划)

    [BZOJ4832]抵制克苏恩(矩阵快速幂,动态规划) 题面 BZOJ 题解 一模一样 #include<iostream> #include<cstdio> using na ...

  3. yii2 阿里云短信 aliyun-dysms

    aliyun-dysms安装 composer require "saviorlv/yii2-dysms:dev-master" 或者添加下列代码在composer.json文件中 ...

  4. Python By 360、小米

    小米 乱谈Python并发 说实话,我一直觉得PHP真的是最好的语言,不仅养活了一大批PHP程序员,同时还为安全人员提供了大量的就业机会.然而,令人唏嘘的是,安全界很多人其实是吃着Python的饭,操 ...

  5. 【转】服务化框架技术选型与京东JSF解密

    [京东技术]声明:本文转载自微信公众号“开涛的博客”,转载务必声明. 作者:章耿,原京东资深架构师,曾负责京东服务框架,配置中心等基础平台.近十年工作经验,专注于基础中间件等底层技术架构,对分布式系统 ...

  6. jQuery ajax读取本地json文件

    jQuery ajax读取本地json文件 json文件 { "first":[ {"name":"张三","sex": ...

  7. C# winfrom 递归(城市名)

    递归的定以:递归在运行过程中,自己调用自己的过程: List<ChinaStates> list = new ChinaData().SelectAll();//查询所有中国的城市的方法: ...

  8. [luogu1020][导弹拦截]

    题目位置 https://www.luogu.org/problemnew/show/P1020 题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的 ...

  9. react-native中的TextInput

    TextInput是一个允许用户输入文本的基础组件.它有一个名为onChangeText的属性,此属性接受一个函数, 而此函数会在文本变化时被调用.另外还有一个名为onSubmitEditing的属性 ...

  10. python pip NameError:name 'pip' is not defined”

    https://www.jianshu.com/p/f57f98ebcb21 问题: 如果直接在命令行里面输入pip或者pip3,提示:(如图1) “NameError:name 'pip' is n ...