MySQL 和 php 中独特的文本字段

2023-12-23

我使用以下方法创建了盐; md5(兰特(0,10000000)); (可能有更好的方法吗?)

MYSQL 中似乎无法使文本字段唯一。那么如何检查盐是否已经被以前的用户使用过呢?

或者我应该根据当前日期/时间生成盐?因为 2 个用户不可能同时注册,对吗?


对于盐来说,独特性比长度和可预测性更重要。你假设攻击者有盐。

通用唯一标识符(UUID)将是最好的,并且有一些示例可以在 php 的文档页面上生成通用唯一标识符唯一身份() http://php.net/manual/en/function.uniqid.php功能。 UUID 优于随机字符串,因为它是人类可读的且长度固定,因此您可以将其存储在 varchar 字段中并使用唯一索引来确保不重复。

使用 MD5 对时间进行哈希处理是生成唯一值的常用方法,因为它具有固定长度并且易于人类读取。然而,生成固定长度的随机字符串并自己将其编码为十六进制更有意义。哈希值的设计目的与其说是为了唯一性,不如说是为了不可逆而设计的。使用散列函数可以保证冲突,尽管 SHA1 的冲突比 MD5 少。

盐的长度实际上只是一个因素,因为盐越长,它就越有可能是普遍独特的。

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

MySQL 和 php 中独特的文本字段 的相关文章

  • TCPDF / FPDI 可以接受 PDF 作为字符串吗?

    是否可以将 TCPDF 或 FPDI PDF 作为字符串提供 我有一个传入的 PDF 数组作为字符串 但无法写入磁盘 我在文档中找不到与此相关的任何内容 如果没有 是否有一种有效的方法来从内存或作为对象存储 读取这些 PDF 将它们喂给 F
  • 如何在 PHP 中将默认日期设置为波斯日期?

    如何在 PHP 中将默认日期设置为波斯日期 说吧 如果我echo这个功能date Y m d 然后它会显示2018 03 05但我想要1396 12 14波斯日期 请检查 http php net manual en intldatefor
  • php递归合并

    我需要以某种不同的方式合并一些数组 我使用 array merge recursive 然而 有一些事情我需要改变 但我不知道如何改变 这是来自 php net 的引用 但是 如果数组具有相同的数字键 则后面的值 不会覆盖原始值 但会追加
  • PHP 从日志事件中获取行号

    好的 我还有一个问题HERE https stackoverflow com questions 3213423 php how could i make this class better suggestions feedback wel
  • 删除、截断或删除以清理 MySQL 中的表

    我正在尝试清理表格 但没有摆脱表格的实际结构 我有一个id自动递增的列 我不需要保留ID号 但我确实需要它来保持其自动递增的特性 我发现了删除和截断 但我担心其中之一会完全删除整个表 从而使未来的插入命令变得无用 如何从表中删除所有记录以便
  • filter_input() 何时删除 POST 变量的斜杠?

    我创建了一个小型 PHP 脚本 它在 PHP 5 2 17 的服务器上运行magic quotes gpc指令已启用 我没有对 php ini 文件的写访问权限 并且我想从用户输入中删除所有斜杠 即使magic quotes gpc指令被关
  • 同一路由组的多个前缀

    我正在为一所学校编写一个相当简单的网站 该网站有新闻 文章 视频剪辑 等 它的工作方式是在主页中我们向访问者展示一些课程 例如 gt math gt geography gt chemistry 用户在其中选择 1 网站内容会根据用户的选择
  • PHP 中的抽象类是什么?

    PHP 中的抽象类是什么 如何使用 抽象类是至少包含一个抽象方法的类 该方法中没有任何实际代码 只有名称和参数 并且已被标记为 抽象 这样做的目的是提供一种模板来继承并强制继承类实现抽象方法 因此 抽象类是介于常规类和纯接口之间的东西 此外
  • MySQL 中布尔值的 TINYINT 与 ENUM(0, 1)

    MyISAM 表和 MySQL 5 1 中具有 0 和 1 值的 Tinyint 或 ENUM 0 1 哪个更好 您可以使用BIT 1 如中提到的MySQL 5 1 参考 http dev mysql com doc refman 5 1
  • 无法在 PHPUnit 中使用数据提供程序运行单个测试

    使用命令行运行测试时遇到问题 如果我像这样运行 phpunit phpunit no configuration filter testAdd DataTest DataProviderTest php 效果很好 但是我们使用正则表达式来准
  • 在 BIRT 中输入参数后更新数据集查询

    在 BIRT 报告设计中传递参数后 如何更改或更新数据集的查询 详细说明 我有一个如下所示的查询 WHERE 该参数标记可以保存不同的值 在用户输入参数后 它看起来像这样 例如 WHERE column name 1 or WHERE co
  • 在 PHP 中使用数组来比较用户名/密码

    我有以下 php 脚本 其中有一个用户名和密码 Username user1 Password pass1 if isset POST submitform Clean up the input values foreach POST as
  • 连接 3 三张表

    我有这个图表应该可以解释我的情况 我需要一些关于连接 3 个表的帮助 我不知道如何做这种事情 因此 我可以通过执行以下操作来经历一段检索记录的 while 循环 img src alt Album AlbumID 使用内部联接 http w
  • Heredoc:常用的“EOT”实际上是什么意思?

    PHP s 定界例子 http www php net manual en language types string php language types string syntax heredoc似乎总是使用 EOT 有时是 EOD 作
  • 表单提交后显示 $_FILES['image']

    提交表单后如何显示上传的图片 提交表单后 它将是一个预览页面 因此我不会在 MySQLet 中存储图像类型 BLOB 如何显示 FILES image
  • 如何在 PHP >= 5.3 严格模式下向对象添加属性而不产生错误

    这必须很简单 但我似乎找不到答案 我有一个通用的 stdClass 对象 foo没有属性 我想添加一个新属性 bar尚未定义 如果我这样做 foo new StdClass foo gt bar 1234 严格模式下的 PHP 会抱怨 将属
  • PHP 中的坏词过滤器?

    我正在用 PHP 编写一个坏词过滤器 我在数组中有一个坏词列表 方法 clean text 的写法如下 public static function cleanse text originalstring if self is sorted
  • 如何更改phpmyadmin MySQL的IP地址?

    我在 xampp 中更改了 apache 的 IP 地址 但无法连接到 MySQL 我认为问题是我的 apache 不在我的数据库的同一网络上 我的 apache 位于 192 168 1 10 而我的 MySQL 位于 127 0 0 1
  • Innodb页面大小设置

    在innodb中 页面大小默认为16kb 如何将页面大小设置为 8kb 是否有在源编译步骤中设置的选项 您不需要在源编译步骤中指定页面大小 MySQL 5 6 及更高版本支持不同的页面大小 无需重新编译 但是 您必须在初始化 InnoDB
  • 在 Django 查询中使用 .extra(select={...}) 引入的值上使用 .aggregate() ?

    我正在尝试计算玩家每周玩游戏的次数 如下所示 player game objects extra select week WEEK games game date aggregate count Count week 但姜戈抱怨说 Fiel

随机推荐

  • Yii2 Email 如何设置发件人姓名

    我使用 Mailer 发送电子邮件 所以我对发件人姓名有疑问 这是我的配置 mailer gt class gt yii swiftmailer Mailer useFileTransport gt false messageConfig
  • 如何从标准 ServiceStack 错误响应中删除堆栈跟踪

    我刚刚开始使用 ServiceStack 我想了解是否可以从标准错误响应中删除堆栈跟踪 我尝试关闭调试模式但没有任何运气 public override void Configure Funq Container container Set
  • Pandas 图,vars() 参数必须具有 __dict__ 属性?

    它之前工作得很好 但由于某种原因 现在我遇到了奇怪的错误 熊猫版本 1 2 3 matplotlib 版本 3 7 0 示例数据框 df cap Date 0 1 2022 01 04 1 2 2022 01 06 2 3 2022 01
  • 在链接点击的另一个网站上使用相同的 php 会话

    我有个问题 假设我在网站上域名1 com我点击一个链接域名1 com这让我想到域名2 com 但我想用同样的session id 设置为session start in 域名1 com on 域名2 com 我如何在 PHP 中实现这一点
  • 处理 nls - R 脚本中的 0 错误

    有什么方法可以让我的 nls 在进行非线性拟合时具有 0 残差误差吗 我的数据中有一些情况 其中拟合应该有 0 错误 但 nls 总是失败并吐出错误 谁能告诉我 如何测试这是否是 nls 吐出的错误 如何允许 0 错误情况 完美契合 这是我
  • React Native XCode 项目产品存档因架构 arm64 的重复符号而失败

    奇怪的是 我似乎无法让 Archive 在 XCode 中工作 但如果我不尝试 Archive 而只是构建发布版本 则构建会成功 并且不会出现重复符号的错误 该项目也可以在设备上正确构建 我已经搜索了这个主题并尝试禁用可测试性 并将项目设置
  • 此环境中不提供编译器。也许您正在 JRE 而不是 JDK 上运行?

    我正在使用 m2eclipse 在 Eclipse 中编译一个项目 我在Eclipse中设置JDK路径如下 Windows gt preferences gt installed jres gt jdk1 7 xx path 但这显示错误
  • MongoDB 与 Grails Scaffolding 的问题(在 MySQL 中不会发生)

    我尝试使用 MongoDB 2 0 6 替换 MySQL 5 5 25 来测试 Grails 2 1 应用程序 但遇到了一些奇怪的问题 使用 MongoDB 但不使用 MySQL 时出现的问题 使用脚手架时 我无法使用静态约束对字段进行排序
  • 为什么要使用 CGRectMake 这样的函数?

    我很好奇为什么像 CGRectMake 和 CGPointMake 这样的函数存在并被广泛使用 相反 您可以执行以下操作 CGRect x y width height 由于没有函数调用 这肯定更有效 尽管我猜效率不是很高 您还可以设置原点
  • 西纳特拉与费加罗宝石

    我正在尝试将 Figaro gem 与 Sinatra 一起使用 我已经安装 Figaro 并创建了以下文件 文件夹 config application yml 在此文件中我添加了一些环境变量 ENV GMAIL USERNAME ENV
  • TypeScript - 输入 'number | undefined' 不能分配给类型 'number'

    这是我的代码 var a number a 4 var myArr number myArr 1 2 3 myArr push 1 a myArr pop 当我将 module 在我的 tsconfig json 文件中 设置为 syste
  • Java 1.7:Iterable 之和

    我需要创建一个辅助方法 它允许创建任何 Iterable extends Number gt 因为我们有很多向量并且需要一个快速的方法来确定总和 所以我创建了以下方法 static Integer sum Iterable
  • Internet Explorer 保护模式错误

    我在 Visual Studio 中的代码使用 selenium webdriver 2 24 0 我使用的测试框架是 Nunit 我的代码工作得很好 加载不同的浏览器 驱动网站 直到 2 24 0 版本发布 我将新的 IE 独立服务器添加
  • 在 C# 中将 SVG 字符串转换为位图(理想情况下在内存中)

    我使用下面的代码将 SVG 字符串 svgString 转换为位图 myBitmap 理想情况下 我想避免往返硬盘 你认为这可能吗 没有找到太多 SVG nuget 包的文档 顺便说一句 我知道我也可以将 bmp 写入硬盘 但我选择了 pn
  • 如何控制 Chart.JS 饼图图例的位置及其外观?

    我可以使用 Chart JS 和以下代码创建饼图 HTML div div
  • EGit 的兼容性 - 还是有替代方案?

    我正在使用 Eclipse 进行开发 并使用 git 和 gitorious 管理我的存储库 到目前为止 我在命令行上使用 git 我四处寻找将 git 集成到 Eclipse 中的方法 并找到了 EGit 两年前也有人问过这个问题 htt
  • 相当于 Java 的 AtomicMarkableReference 的 C++ 11 原子库是什么

    需要这个调用来实现无锁链表 AtomicMarkableReference 是 java util concurrent atomic 包中的一个对象 它封装了对 T 类型对象的引用和布尔标记 这些字段可以一起或单独原子更新 谢谢 假设对象
  • 缩放不适用于包含驾驶路线的谷歌API地图[重复]

    这个问题在这里已经有答案了 我有一个 html 页面 其中包含一张地图 显示从教堂到婚宴的路线 地图上还有 六个标记 每个标记都有一个信息窗口 显示附近的酒店 路线的起点和终点标记已替换为自定义图标 这一切都工作得非常好 除了无论我将缩放设
  • 在 php 中读取然后覆盖文件内容的最佳方法是什么?

    php 中打开文件 读取内容并随后使用基于原始内容的一些输出覆盖文件内容的最干净方法是什么 具体来说 我试图打开一个填充有项目列表 以换行符分隔 的文件 处理 添加项目到列表中 从列表中删除最旧的 N 个条目 最后将列表写回到文件中 fop
  • MySQL 和 php 中独特的文本字段

    我使用以下方法创建了盐 md5 兰特 0 10000000 可能有更好的方法吗 MYSQL 中似乎无法使文本字段唯一 那么如何检查盐是否已经被以前的用户使用过呢 或者我应该根据当前日期 时间生成盐 因为 2 个用户不可能同时注册 对吗 对于