Rails Digest认证实现和原理

2023-05-16

优势

Http Digest是一种Http(不仅限于Web页面)认证框架,相比通常使用的基本认证,Digest认证的优点是相对安全、基于网络标准和简单,它不需要编写登录表单页面,对登录信息进行加密,这样就可以很好的支持较安全的程序自动连接(非浏览器连接),可以广泛的应用到数据服务领域。

实现

在Rails中实现Http Digest认证是非常简单的,有两个步骤:

1. 在控制器中配置一个before_filter过滤器,指向验证方法

2. 定义一个验证方法,使用authenticate_or_request_with_http_digest 语句块就可以了

实现代码如下

# 定义before_filer过滤器,指向验证函数

before_filter :dig_auth

# 在此处定义了密码数字,当然也可以用数据库或者自己定义的验证函数

USERS = { "yanjh" => "hello","shixc" => "hello" }

Realm="cdcr.com"

# 验证方法

def dig_auth

authenticate_or_request_with_http_digest(Realm) do |name|

# 当前验证的用户,预先赋给一个会话变量

@cuser=name

# 向语句块(认证系统)返回用户密码,由系统判断该密码匹配,通过验证后续的方法会执行,否则返回验证失败头信息

USERS[name]

end

end

原理

在网络上基本上没有人探讨该认证方式实现的原理,经过实验和分析,大体搞清楚了Digest验证的原理。

通常验证我们会直接从认证请求中获得用户名和密码,然后自己判断匹配性;但在这里我们只能获取用户名,然后我们可以依据此用户名在外部查找密码(明文或者md5密文都可以),返回给认证系统,再次注意,这里返回的是密码!再由系统来判断是否匹配,这样虽然逻辑上有点古怪,但将认证密码传输和解析黑箱化,确实更安全了。

原文链接:http://hi.baidu.com/yan__jh/blog/item/2f263100df2077f509fa93a7.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Rails Digest认证实现和原理 的相关文章

随机推荐

  • 解决 VMware 虚拟机 中被提示 “请不要在虚拟机中运行此程序”或者“Themida Sorry, this application cannot run under a Virtual Mac

    解决 VMware 虚拟机 中被提示 请不要在虚拟机中运行此程序 或者 Themida Sorry this application cannot run under a Virtual Machine 设置 xff1a 1 用记事本打开
  • ASP一句话木马大全

    lt eval request 34 MH 34 gt lt execute request 34 MH 34 gt lt execute request 34 MH 34 gt lt If Request 34 MH 34 lt gt 3
  • 过TP保护与解除游戏驱动保护(可以借鉴)

    TP 是国内腾讯游戏一款比较流行的驱动级保护程序 负责保护腾讯每款游戏不被修改破坏 xff0c 也许大家也是研究腾讯游戏的爱好者 对腾讯的游戏都有过这样的体会 例如OD与CE无法进行如以下操作 xff1a 无法附加进程 无法打开进程 游戏进
  • HG255D[OpenWrt]从入门到精通

    本文针对华为HG255D xff0c 但同时具有一定的通用参考价值 一 刷机篇 要想放心大胆的玩学会刷机是少不了的 xff0c 经过我的反复多次的折腾总结了自己认为稳定而且简单的方法 xff0c 最终达到刷不死的境界 1 刷机和恢复教程 x
  • 【深度相机系列三】深度相机原理揭秘--双目立体视觉

    本文已经首发在个人微信公共号 xff1a 计算机视觉life xff08 微信号CV life xff09 xff0c 欢迎关注 xff01 导读 为什么非得用双目相机才能得到深度 xff1f 双目立体视觉深度相机的工作流程 双目立体视觉深
  • Linux Ubuntu18.04系统 USB转串口驱动安装,查看串口号

    When you plugin your USB UART converter and run gt ls dev tty if you don t see the dev ttyUSB0 or similar your Linux doe
  • Keil编译警告:function "assert_param" declared implicitly的解决方法

    1 问题描述 新建STM32的keil工程 xff0c 在编译时出现警告 FWLIB src stm32f10x rcc c 273 warning 223 D function assert param declared implicit
  • 寻路A*算法 (下)

    这样还剩下 5 个相邻的方格 当前方格下面的 2 个方格还没有加入 open list xff0c 所以把它们加入 xff0c 同时把当前方格设为他们的父亲 在剩下的 3 个方格中 xff0c 有 2 个已经在 close list 中 一
  • ROS学习笔记之七:ROSSerial初试

    总体来说 xff0c ROS更偏重软件 xff0c 其涉及的控制 算法都是偏策略或复杂的 xff0c 但机器人是要和现实世界打交道的 xff0c 必须有相应的执行机构 xff0c 使ROS所能做的那些 高 大 上 的工作落地 真正能够和执行
  • 单片机的堆和栈(Heap & Stack)详解

    一 程序内存分配 由c C 43 43 编译的程序占用的内存分为以下几个部分 1 栈区 xff08 stack xff09 由编译器自动分配释放 xff0c 存放函数的参数值 xff0c 局部变量的值等 其操作方式类似于数据结构中的栈 2
  • 汽车CAN通信基础知识-CAN数据结构

    目录 1 CAN总线概述 2 基于CAN总线的汽车电气网络结构 3 CAN总线的特点 4 CAN协议分层结构和功能 5 CAN数据帧类型 1 CAN总线概述 a CAN Controller Area Network 即控制器局域网络 由于
  • lubuntu18.04工控屏QT开发

    lubuntu18 04工控屏QT开发 备忘 系统更新中文语言包及输入法QT安装QWT安装QT程序的打包和运行Lubuntu开机自启动脚本程序方法Lubuntu开机跳过输入密码自动登录 13 3寸触摸工控屏 xff0c lubuntu18
  • 数据FIFO的读写和信息FIFO的基本使用方法

    数据FIFO 一 写使能 wr en xff0c 写数据 wdata din 8bit assign wr en 61 din vld din vld 为数据有效指示信号 assign wdata 61 din sop din eop di
  • 获取系统当前时间和特定格式的时间

    java中获取系统当前时间 SimpleDateFormat formatter 61 new SimpleDateFormat 34 yyyy年MM月dd日 HH mm ss 34 Date curDate 61 new Date Sys
  • HTTP认证模式:Basic & Digest

    引言 经常在工作中使用到了各种认证方式 xff0c 但从未考虑过这些认证方式所属的知识范畴 xff0c 同时也解释不清楚它们 曾用到的认证方式 xff08 看看是否您也用过 xff0c 但很难解释清楚他们 xff09 xff1a Basic
  • Could not retrieve

    输入where nvm 找到nvm安装文件夹 在nvm文件夹下找到settings txt 添加以下代码 xff1a xff08 若没有则新建settings txt文件 xff09 node mirror npm taobao org m
  • Jetson Xavier gpio编程 (8)

    GPIO lines are attached to gpiochips Look in sys class gpio and you should see gpiochip240 248 and 288 I haven t yet det
  • curl 函数

    1 curl close 关闭一个cURL会话 语法 xff1a curl close span class hljs variable ch span span class hljs variable ch span 由 curl ini
  • CMake Error at /opt/ros/kinetic/share/catkin/cmake/catkinConfig.cmake:83 (find_package):

    出现了这样的情况的话如 xff1a CMake Error at opt ros kinetic share catkin cmake catkinConfig cmake 83 find package Could not find a
  • Rails Digest认证实现和原理

    优势 Http Digest是一种Http 不仅限于Web页面 认证框架 xff0c 相比通常使用的基本认证 xff0c Digest认证的优点是相对安全 基于网络标准和简单 xff0c 它不需要编写登录表单页面 xff0c 对登录信息进行