首页
/ Humanizer 项目技术文档

Humanizer 项目技术文档

2024-12-18 17:12:30作者:胡唯隽

1. 安装指南

1.1 基本安装

  1. 在您的 Gemfile 中添加 humanizer

    gem "humanizer"
    
  2. 在终端中运行以下命令以安装 gem 并生成相关文件:

    bundle
    rails g humanizer
    

1.2 高级安装

  • 安装所有语言环境

    rails g humanizer --all-locales
    
  • 显示可用语言环境

    rails g humanizer --show-locales
    
  • 安装选定的语言环境

    rails g humanizer en fi de
    

2. 项目使用说明

2.1 在模型中使用

  1. 在您的模型中包含 Humanizer,并添加 #require_human_on 方法,例如:

    class User < ActiveRecord::Base
      include Humanizer
      require_human_on :create
    end
    
  2. 在表单中提问,例如:

    <%= f.label :humanizer_answer, @model.humanizer_question %>
    <%= f.text_field :humanizer_answer %>
    <%= f.hidden_field :humanizer_question_id %>
    
  3. 如果您使用 attr_accessible,请记住将 :humanizer_answer:humanizer_question_id 列入白名单。

  4. 如果您使用 strong_parameters,请记住允许 :humanizer_answer:humanizer_question_id

2.2 配置

默认翻译文件位于 config/locales/ 目录下。您可以通过添加或修改 locales 文件中的条目来轻松添加或更改问题和答案对。

2.3 跳过验证

在测试或 Rails 控制台中,您可能希望跳过 humanizer 验证。可以通过在模型中添加一个简单的属性来实现,例如:

attr_accessor :bypass_humanizer
require_human_on :create, unless: :bypass_humanizer

bypass_humanizertrue 时,验证将被跳过。

2.4 重新加载问题

如果您希望为用户提供更改问题的选项,可以使用 #change_humanizer_question 方法。为确保当前问题不会再次被提问,可以将当前问题的 ID 传递给该方法,例如:

@user.change_humanizer_question(params[:user][:humanizer_question_id])

3. 项目API使用文档

3.1 require_human_on 方法

该方法用于在模型中指定何时需要进行人机验证。例如:

require_human_on :create

3.2 change_humanizer_question 方法

该方法用于重新加载问题,避免重复提问。例如:

@user.change_humanizer_question(params[:user][:humanizer_question_id])

4. 项目安装方式

4.1 通过 Gemfile 安装

在 Gemfile 中添加 humanizer

gem "humanizer"

然后运行 bundle 命令进行安装。

4.2 生成器命令

使用以下命令生成相关文件:

rails g humanizer

4.3 高级选项

  • 安装所有语言环境

    rails g humanizer --all-locales
    
  • 显示可用语言环境

    rails g humanizer --show-locales
    
  • 安装选定的语言环境

    rails g humanizer en fi de
    

通过以上步骤,您可以成功安装并使用 Humanizer 项目。

热门项目推荐
相关项目推荐

项目优选

收起
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
74
55
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
51
39
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
258
66
mybatis-plusmybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.com
Java
22
0
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
177
42
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
400
103
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
168
37
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
26
18
hyperionhyperion
仓颉语言实现的TCP通信框架,支持添加自定义编解码器,积木式添加IoFilter处理入栈出栈消息。仓颉redis-sdk和activemq4cj项目使用了该框架。
Cangjie
113
16
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
892
0