2015-10-26 06:09:39 +00:00
# RuCaptcha
2015-10-26 11:58:17 +00:00
[data:image/s3,"s3://crabby-images/fde9e/fde9e9d8d5f9c0de77ae43abb59b85b5870cf0fa" alt="Gem Version "](https://badge.fury.io/rb/rucaptcha)
2015-10-29 09:53:41 +00:00
[data:image/s3,"s3://crabby-images/67770/6777018a55d195617bb328fcc309f1f2b43691f4" alt="Build Status "](https://travis-ci.org/huacnlee/rucaptcha)
2015-10-26 06:09:39 +00:00
2015-10-26 09:56:47 +00:00
This is a Captcha gem for Rails Applications. It runs an ImageMagick command to draw Captcha image - so it has NO performance issues or memory leak issues.
2015-10-26 06:09:39 +00:00
2015-10-26 11:56:00 +00:00
**There is NO: RMagick**
2015-10-26 11:53:07 +00:00
2015-10-26 06:09:39 +00:00
Idea by: https://ruby-china.org/topics/20558#reply4
2015-10-26 12:25:54 +00:00
[中文介绍和使用说明 ](https://ruby-china.org/topics/27832 )
2015-10-30 03:32:02 +00:00
## Feature
- Only need `ImageMagick` , No `RMagick` , No `mini_magick` ;
- For Rails Application;
- Simple, Easy to use;
- File Caching for performance.
## Requirements
2015-10-26 06:09:39 +00:00
2015-11-05 10:29:13 +00:00
- ImageMagick
2015-10-26 06:09:39 +00:00
2015-10-30 03:32:02 +00:00
#### Ubuntu
```
sudo apt-get install imagemagick
```
#### Mac OS X
```bash
brew install imagemagick ghostscript
```
## Example
2015-10-26 10:04:35 +00:00
2015-11-05 10:30:10 +00:00
data:image/s3,"s3://crabby-images/6d825/6d825d4c8c29e0647c92f11252eb8d439151b77a" alt="captcha8 "
data:image/s3,"s3://crabby-images/df9d5/df9d52dac09fde052177a80867098cfc80236e75" alt="captcha7 "
data:image/s3,"s3://crabby-images/6b317/6b3170a9fb715eba4371e69c922317c521add519" alt="captcha6 "
data:image/s3,"s3://crabby-images/9b47c/9b47cdf2ba0104aff1fb824dfcdee1aad580272e" alt="captcha5 "
data:image/s3,"s3://crabby-images/9d17c/9d17c78d0ad801ee4a756e3ac822355a606060dd" alt="captcha4 "
data:image/s3,"s3://crabby-images/413c3/413c394f5ea287ac60f3be5d2ea214b68c25b81a" alt="captcha3 "
data:image/s3,"s3://crabby-images/1e2cc/1e2ccf8d9471f5a4df390f6eb4ef28f7edb12881" alt="captcha2 "
data:image/s3,"s3://crabby-images/6b394/6b3941a4d6cfd9d16bf5854bd3a2fab927f945f6" alt="captcha1 "
2015-10-26 10:04:35 +00:00
2015-10-30 03:32:02 +00:00
## Usage
2015-10-26 06:09:39 +00:00
Put rucaptcha in your `Gemfile` :
```
gem 'rucaptcha'
```
2015-10-27 13:27:17 +00:00
Create `config/initializers/rucaptcha.rb`
2015-10-26 06:09:39 +00:00
```rb
RuCaptcha.configure do
# Number of chars, default: 4
self.len = 4
2015-11-05 10:29:13 +00:00
# Image font size, default: 45
self.font_size = 45
2015-10-30 03:32:02 +00:00
# Cache generated images in file store, this is config files limit, default: 100
# set 0 to disable file cache.
self.cache_limit = 100
2015-10-26 06:09:39 +00:00
end
```
2015-10-27 07:13:39 +00:00
Edit `config/routes.rb` , add the following code:
2015-10-27 02:27:01 +00:00
```rb
Rails.application.routes.draw do
...
mount RuCaptcha::Engine => "/rucaptcha"
...
end
```
2015-10-26 06:09:39 +00:00
Controller `app/controller/account_controller.rb`
```rb
class AccountController < ApplicationController
def create
@user = User.new(params[:user])
if verify_rucaptcha?(@user) && @user .save
redirect_to root_path, notice: 'Sign up successed.'
else
render 'account/new'
end
end
end
```
View `app/views/account/new.html.erb`
```erb
< form >
...
< div class = "form-group" >
< %= rucaptcha_input_tag(class: 'form-control', placeholder: 'Input Captcha') %>
< %= rucaptcha_image_tag(alt: 'Captcha') %>
< / div >
...
< / form >
```
2015-10-30 03:32:02 +00:00
### Write your test skip captcha validation
2015-10-26 12:22:27 +00:00
```rb
describe 'sign up and login', type: :feature do
before do
allow_any_instance_of(ActionController::Base).to receive(:verify_rucaptcha?).and_return(true)
end
it { ... }
end
```
2015-10-26 12:53:30 +00:00