在PSI中经常用到OPRF技术,现在系统学习一下。

PRF

Pseudo Random Function,伪随机函数,主要就是用来产生为伪随机数的。

伪随机数

什么伪随机数?

伪随机数是用确定性的算法计算出来自[0,1]均匀分布的随机数序列。并不真正的随机,但具有类似于随机数的统计特征,如均匀性、独立性等。C语言中的random()函数产生的随机数就是伪随机数,即假的随机数,因为每次运行生成的随机数都是一样的,所以实现生成随机数时需要种子不一样。

原理

PRF 是一个确定性的函数,记为\(F\)。

我们称\(F\)是定义在\((k,X,Y)\)上的 PRF,其中 \(k\) 是密钥空间,\(X\) 是输入空间,\(Y\) 是输出空间。

它有两个输入,一个是密钥 \(k\),另一个是数据块 \(x∈X\)(称作输入数据块)。它的输出\(y=F(k, x) ∈Y\) 也是一个数据块(称作输出数据块)。

对于 PRF,其安全性要求:给定一个随机产生的密钥 \(k\),函数\(F (k,.)\)应该看上去“像”是一个定义在 \(X\) 到 \(Y\) 上的随机函数。

随机函数

给定集合\(X\)和\(Y\),定义在\(X\)到\(Y\)上的映射\(f:X→Y\):

首先把所有定义在\(X\)到\(Y\)上的映射集中起来,形成一个集合。这个集合里的每个元素都是一个类似\(f\)这样的映射(函数),它们的定义域都是\(X\),值域是\(Y\)。

这个集合记为\(Funs[X,Y]\),它就是定义在\(X\)到\(Y\)上的所有函数的集合。

很明显,这个集合里一共有\(|Y|^{|X|}\)个函数,非常大!

现在,从\(Funs[X, Y]\)随机选择一个函数。这个函数就是“随机函数”。

需要注意的是,所谓的“随机函数”强调的是这个函数是随机地被选择出来的。因此,“随机函数”这个概念和函数的输出是否是随机的没有关系。即使一个函数的输出不是随机的,但只要它被选出的时候是随机选择的,那么它就是“随机函数”。理解这一点非常重要!

实现

OPRF

Oblivious Pseudorandom Function,不经意伪随机函数。

功能



假设Alice有一些输入,Bob有一个\(key\)。OPRF允许Alice将自己的输入与Bob的\(key\)结合经过一系列运算转变成相对应的数。

在这个过程中,Alice不能知道Bob的\(key\),Bob也不知道最后的结果\(F(key,x)\)。每一个输入\(x_i\)都可以计算出一个不同于其他输入的数,这些数就可以被看作伪随机数

这里可以看出,里面用到了PRF,那么原理具体怎么实现呢?

原理

OPRF的实现原理有多种方法,下面介绍几种。

基于DH的OPRF

参考:Fast secure computation of set intersection.

基于DH的OPRF是计算\(F_{\alpha}(x)=H'(H(x)^{\alpha})\),其中\(H\)是一个在\(Z_q^*\)上的hash函数,可以看作是一个喻言机。具体来说,\(G\)是一个\(q\)阶循环群,其中One-More-Gap-Diffie-Hellman(OMGDH)问题是困难的。

在Labeled PSI from Fully Homomorphic Encryption with Malicious Security 中使用的OPRF是这样的:





在Labeled PSI from Homomorphic Encryption with Reduced Computation and Communication 中使用OPRF:





那么就有疑问了:

(1)如何将item 插入到椭圆曲线上的点?

(2)如何从椭圆曲线上的点中提取\(OPRF(k,x)\)?

下面给出一种简单的方法:

该思想来自:Fast Secure Computation of Set Intersection

基于OT的OPRF

参考:隐私集合求交(PSI)-两方

基于RSA的OPRF



意思就是:

\(x=h.r^e\) , \(y=x^d=(h.r^e)^d\)

\(z=y.r^{-1}=(h.r^e)^d . r^{-1}=h^d.r^{ed-1}\)

\(z^e=(h^d.r^{ed-1})^e=h^{ed}.r^{e(ed-1)}\) ??

这个没看太懂,有朋友看懂了可以解惑?

OPPRF

Oblivious Programmable Pseudo-Random Function,可编程的不经意伪随机函数。

参考:隐私集合求交(PSI)-多方

参考

1、现代密码学3.5--伪随机函数/PRF

2、【现代密码学入门】24. 伪随机函数(PRF)(1)

OPRF的更多相关文章

  1. SQL Server优化技巧之SQL Server中的"MapReduce"

    日常的OLTP环境中,有时会涉及到一些统计方面的SQL语句,这些语句可能消耗巨大,进而影响整体运行环境,这里我为大家介绍如何利用SQL Server中的”类MapReduce”方式,在特定的统计情形中 ...

  2. 网页、php脚本的编码问题

    对于程序的编码问题,做一次总结,我们清楚,从对象来说,编码可能涉及到三到四个对象 一.首先是请求终端: 这个请求终端有可能是浏览器端,从浏览器端发起网页请求:Ajax请求:也有可能是程序内部的Api调 ...

  3. C#操作AD及Exchange Server总结

    C#操作AD及Exchange Server总结 这篇博客的目的:根据亲身项目经历,总结对AD及Exchange Server的操作,包括新建AD用户,设置密码,为AD用户创建邮箱等. 本文完全原创, ...

  4. python 一篇搞定所有的异常处理

    一:什么是异常? 异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行. 一般情况下,在python无法正常处理程序时就会发生一个异常(异常是python对象,表示一个错误) 异常就是 ...

  5. C#操作AD及Exchange Server总结(一)

    这篇博客的目的:根据亲身项目经历,总结对AD及Exchange Server的操作,包括新建AD用户,设置密码,为AD用户创建邮箱等. 本文完全原创,转载请说明出处,希望对大家有用. 文档目录: 测试 ...

  6. SAP Business One对象清单

    中文描述 对象号 表名 主键 英文描述 总账科目 1 OACT AcctCode G/L Accounts 业务伙伴 2 OCRD CardCode Business Partner 银行代码 3 O ...

  7. 一个好用的多方隐私求交算法库JasonCeng/MultipartyPSI-Pro

    Github链接传送:JasonCeng/MultipartyPSI-Pro 大家好,我是阿创,这是我的第29篇原创文章. 今天是一篇纯技术性文章,希望对工程狮们有所帮助. 向大家推荐一个我最近改造的 ...

  8. APSI - 2

    上一篇 APSI-1 其实就是对开源库README文件的一个翻译加上自己的一点点理解,因为篇幅过大,导致继续编辑有些卡顿,所以新开一篇继续. 前面介绍了APSI的大致技术.优化方法.以及举例说明了主要 ...

  9. Simple, Fast Malicious Multiparty Private Set Intersection-解读

    文本记录阅读该论文的笔记. 这是文章框架,来自视频. 介绍 本文主要解决恶意攻击下安全的多方PSI,主要用到两大技术OPPRF和OKVS,构造合谋和不合谋的协议. 基础知识 OPPRF 这部分在OPR ...

随机推荐

  1. 什么是 Spring 配置文件?

    Spring 配置文件是 XML 文件.该文件主要包含类信息.它描述了这些类是如何 配置以及相互引入的.但是,XML 配置文件冗长且更加干净.如果没有正确规划 和编写,那么在大项目中管理变得非常困难.

  2. WEB架构深度优化之PHP

    一.PHP引擎缓存加速优化(4种) 1.eAccelerator 2.XCache 3.APC 4.Zend 二.使用tmpfs作为缓存加速缓存的目录(可用rc.local或fstab来自动挂载) m ...

  3. PIC16F877A.H头文件详细注释

    /* * Header file for the Microchip  * PIC 16F873A chip * PIC 16F874A chip * PIC 16F876A chip * PIC 1 ...

  4. 深入解析 float

    0.前言 float属性在css2中是一个热门的属性,被广泛应用于布局之中,同时由于不当使用float带来的问题也非常多,本文结合自己对float的理解以及实际项目中碰到float的相关问题,做一个详 ...

  5. 关于小程序websocket全套解决方案,Nginx代理wss

    需求对话 提问 我在本地web能够使用ws协议去链接websocket,但是小程序不能使用. 回答 由于小程序使用的是SSL加密协议,所以需要使用wss.这里wss与ws的关系就相当于https于ht ...

  6. Codepen 每日精选(2018-3-24)

    按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以打开原始页面. 纯 css 画的抽象小鸟https://codepen.io/gregoryb/f... 纯 css 制作 ...

  7. IDEA中Tomcat找不到war包导出按钮解决办法

    解决办法 (1) 打开Idea,点击File,然后点击Project Structure-,进入项目结构 (2) 具体步骤看下图: (3) 具体步骤如下图: (4) 具体步骤如下图: (5) 问题解决 ...

  8. JavaScript一些重要知识点结合题目的表现!

    function Foo() { //① 声明一个Foo的函数 getName = function () { alert (1); }; return this; } Foo.getName = f ...

  9. 帝国CMS灵动标签调用包含指定短语关键词关键字文章的语法

    [e:loop={"select * from phome_ecms_news where title like '%这里是关键词%' and checked=1 order by news ...

  10. 第十三届蓝桥杯省赛C/C++ B组

    @(第十三届蓝桥杯省赛C/C++B组) A顺子日期 答案是1478 B顺子日期 答案14(如果012算的话) C刷题统计 数据范围1e18,所以不能直接暴力,先取余,再暴力剩下的 #include&l ...