django生成图片验证码

def get_check_code_image(request):
    """
    验证码
    """
    
    im_name_list = ['validata_code1.jpg', 'validata_code2.jpg', 'validata_code3.jpg', 'validata_code4.jpg', \
               'validata_code5.jpg', 'validata_code6.jpg', 'validata_code7.jpg', 'validata_code8.jpg']
    
    im_path = os.path.join('medias','common_img')
    im_name = os.path.join(im_path, im_name_list[random.randint(0, 7)])
    
    im = Image.open(im_name)
    draw = ImageDraw.Draw(im)
    
    mp = md5.new()
    mp_src = mp.update(str(datetime.now()))
    mp_src = mp.hexdigest()
    rand_str = mp_src[0:4]
    
    draw.text((5,0), rand_str[0], font=ImageFont.truetype("ARIAL.TTF", random.randrange(15,35)))
    draw.text((20,0), rand_str[1], font=ImageFont.truetype("ARIAL.TTF", random.randrange(15,35)))
    draw.text((35,0), rand_str[2], font=ImageFont.truetype("ARIAL.TTF", random.randrange(15,35)))
    draw.text((50,0), rand_str[3], font=ImageFont.truetype("ARIAL.TTF", random.randrange(15,35)))
    del draw
        
    request.session['identify_code'] = rand_str
    buf = cStringIO.StringIO()
    im.save(buf, 'png')
    
    return HttpResponse(buf.getvalue(),'image/png')

 从网上找了一些利用PIL生成图片验证码的例子。自己拿过来改改便用再项目上了。

 

有些东西自己还是没见过的,菜啊。多多学习。

 

draw = ImageDraw.Draw(im),自己最近学习PIL的简单用法时候没见过这个Draw,还不是太明白,不过猜想是在原始图片上添加文字或划什么东西要用到的。光做图片处理(模糊,翻转)什么的,没用到这个ImageDraw.

 

draw.text((50,0), rand_str[3], font=ImageFont.truetype("ARIAL.TTF", random.randrange(15,35)))
这个方法以前也没见过。看起来有点复杂,不过不愿意去查文档了,乱猜加试验,前面的第一个参数(50,0)只从相对图片的位置的x,y轴吧。 rand_str[3],要写的字符,最后一个应该是字体的属性和大小,字体的大小使用了一个随机值。


    mp = md5.new()
    mp_src = mp.update(str(datetime.now()))
    mp_src = mp.hexdigest()
    rand_str = mp_src[0:4]
MD5加密,其中update,hexdigest,方法内部咋实现,返回啥值,自己不明白,不过我想也不需要知道吧。就当它是一个函数,一个类型黑盒的函数,知道传一个数进出,返回给我一个值就行了。以后就找这个写就的了。

 

buf = cStringIO.StringIO()
Google了一下cStringIO和StringIO的区别,cStringIO效率高点。不过在某些情况cStringIO是只读的。两者具体用法基本相同。

 

    im.save(buf, 'png')
   
    return HttpResponse(buf.getvalue(),'image/png')

最后两句到现在没搞明白啥意思,

学习PIL的时候只遇到save(),的时候传递一个字符串位置,而此例这个buf可是一个二进制文件啊。TODO吧,实在不明白。

最后一句return HttpResponse(buf.getvalue(),'image/png')意思是传递一个图片对象,但模板中取的值又是这个图片的URL,还是搞不太明白。

 

模板中使用此验证码

<html>

<h1>test</h1>
<img οnclick="this.setAttribute('src','/accounts/get_check_code_image/?nocache='+Math.random());" 
	src="/accounts/get_check_code_image/" alt="验证码图片" />
</html> 

 自己真是啥也不懂,不明白后面的地址跟个nocache参数做啥子,Google,好不容易Google到答案,原来是GET请求后面如果不带参数的话,会使用缓存,而后面跟个随机的参数便不会用缓存了。

this.setAttribute 方法设置参数属性,没次点击src的属性便更改,这样便就实现了动态的验证码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Django中实现图片验证码,可以按照以下步骤进行: 1. 安装Pillow库 Pillow库是Python Imaging Library(PIL)的升级版,用于处理图片。可以使用以下命令安装: ``` pip install Pillow ``` 2. 创建一个视图函数 在Django应用程序中,创建一个视图函数来生成图像验证码。以下是一个示例视图函数: ```python from django.http import HttpResponse from django.shortcuts import render from django.utils.six import BytesIO from PIL import Image, ImageDraw, ImageFont import random def create_captcha(request): # 设置验证码的宽度和高度 width, height = 100, 40 # 创建画布 im = Image.new('RGB', (width, height), 'white') # 获取画笔 draw = ImageDraw.Draw(im) # 定义字体大小 font_size = 25 # 定义字体颜色 font_color = (0, 0, 0) # 定义字体类型 font_type = 'arial.ttf' # 加载字体 font = ImageFont.truetype(font_type, font_size) # 定义验证码的字符集 captcha_str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890' # 生成随机字符串 captcha = ''.join(random.sample(captcha_str, 4)) # 将验证码存储到session中 request.session['captcha'] = captcha # 绘制验证码 for i in range(4): draw.text((10 + i * 20, 10), captcha[i], font=font, fill=font_color) # 生成图片 buf = BytesIO() im.save(buf, 'png') # 返回图片 return HttpResponse(buf.getvalue(), 'image/png') ``` 在上面的视图函数中,我们使用Pillow库生成一个白色画布,然后随机生成一个包含大写字母和数字的四位字符串作为验证码。我们将验证码存储在会话中,以便稍后验证。最后,我们使用BytesIO将图像保存为PNG格式,并将其作为HttpResponse返回。 3. 添加URL模式 在项目的urls.py文件中,添加一个URL模式来将请求路由到create_captcha视图函数: ```python from django.urls import path from . import views urlpatterns = [ # ... path('captcha/', views.create_captcha, name='captcha'), # ... ] ``` 4. 在模板中使用验证码 在表单中添加一个图像输入字段,以显示图像验证码。以下是一个示例模板代码: ```html <form method="post" action="{% url 'register' %}"> {% csrf_token %} <div class="form-group"> <label for="captcha">验证码:</label> <img src="{% url 'captcha' %}" alt="captcha"> <input type="text" name="captcha" class="form-control" id="captcha"> </div> <button type="submit" class="btn btn-primary">注册</button> </form> ``` 在上面的模板中,我们使用{% url %}模板标记来生成URL。我们还在图像标记中使用了一个alt属性,这将在图像无法显示时提供一个备用文本。 5. 验证验证码 在表单处理视图函数中,我们可以使用以下代码验证用户输入的验证码: ```python def register(request): if request.method == 'POST': form = RegistrationForm(request.POST) if form.is_valid(): # 验证验证码 captcha = request.POST.get('captcha', '') if captcha != request.session.get('captcha', ''): form.add_error(None, '验证码错误') return render(request, 'register.html', {'form': form}) # 处理表单数据 # ... else: # 处理表单无效的情况 # ... else: # 显示表单 # ... ``` 在上面的代码中,我们检查POST请求中的captcha字段是否与存储在会话中的验证码相匹配。如果不匹配,我们将表单标记为无效,并将错误消息添加到表单中。如果验证码是正确的,我们将处理表单数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值