草庐IT

java - 使用 java (SHA-512) 创建与 symfony2 相同的哈希值

我这里有一个旧的基于Symfony2的应用程序,我正在用Java中的Dropwizard开发一个替代品。我将所有用户记录从旧数据库迁移到我的新数据模型中。我还添加了新的密码字段,并导入了旧密码和盐字段。现在我想制作众所周知的程序。让用户登录,尝试对新的密码字段。如果失败尝试迁移的那些,如果它们有效,则使用新算法对明文密码进行编码并将新哈希存储在新密码字段中。这样用户就可以将密码哈希值从旧程序移植到新程序。听起来很简单,正常情况下它像往常一样工作,但是这个Symfony和PHP让我发疯。我坚持的地方是用java创建与symfony相同的散列。旧应用程序使用带有“sha512”、base6

php - 经典 ASP 中的各种 HMAC_SHA256 函数给出不同的结果

我需要以某种方式在经典ASP中生成一个散列,它等效于PHP的以下函数的输出:$hash=hash_hmac('SHA256',$message,pack('H*',$secret));哪里$message='stackoverflow';$secret='1234567890ABCDEF';.我在网上尝试了很多方法,但没有一个符合PHP结果:bcb3452cd48c0f9048e64258ca24d0f3399563971d4a5dcdc531a7806b059e36方法一:在线使用dvim_brix_crypto-js-master_VB.asp(使用CrytoJS)Function

php - 为什么 Javascript sha1 和 PHP5 sha1 为 utf-8 字符串生成不同的结果?

我有一个包含一些utf-8字符的字符串,比如“abc艾”,我发现php5sha1生成的代码与Javascriptsha1不同,谁能帮我解决这个问题?提前致谢。PHP代码:$str="abc艾";$result=sha1($str);结果是5345129746e444693aa1111c5840e4b57236f002javascript代码:varstr="abc艾"varresult=sha1(str)结果是8a2aa0fed185dcffb922b1c4d67a49105525bd6a 最佳答案 对于编码为GB18030(616

php - 如何最好地从散列 ('sha512' ,'salt' 升级到 password_* 函数)

我渴望将我的代码迁移到新的password_*PHP原生提供的函数。数据库中现有的哈希已经生成如下:hash('sha512',''.$email.$password);我想将这些移动为由现在推荐的创建的哈希:password_hash($password,PASSWORD_DEFAULT);显然,当用户登录时,我可以借此机会根据他们刚刚提供的密码创建新的哈希值,并将其保存在数据库中。但是,我想避免数据库中必须有两个字段,即一个用于已弃用的哈希,一个用于现代password_hash。相反,我宁愿在每个用户登录时替换旧的。因此,是否可以保留单个数据库字段,并让用户空间代码确定哈希是否旧

php - 具有 PKCS7 填充编码数据的 AES 256 具有一半 ECB 和一半 CBC block

我正在尝试解码从服务器返回的php中的数据:我知道数据已解码AES256并具有PKCS7填充但无法弄清楚它使用哪种block模式这是我的php函数:publicfunctiondecode($data){//AESdecode$iv=mcrypt_create_iv(GEServerConnection::FBENCRYPT_BLOCK_SIZE,MCRYPT_RAND);$data=mcrypt_decrypt(MCRYPT_RIJNDAEL_128,$this->cryptKey,base64_decode($data),MCRYPT_MODE_ECB,$iv);//return$

php - 哪个更好 : sha1_file(f) or sha1(file_get_contents(f))?

我想创建一个文件的哈希值,该文件的大小最小为5Mb,并且可以扩展到1-2Gb。现在在这两种方法之间做出艰难的选择,尽管它们的工作原理完全相同。Method1:sha1_file($file)Method2:sha1(file_get_contents($file))我试过10Mb,但性能没有太大差异。但在更高的数据规模上。有什么更好的方法? 最佳答案 除非有令人信服的理由,否则请使用所提供的最高级别的表格。在这种情况下,正确的选择是sha1_file。因为sha1_file是一个只对文件起作用的高级函数。这种“限制”允许它利用文件/

php - 不能在类定义中使用 sha1 吗?

我正在使用PHP编写登录类。我在类定义中有以下行:private$salty=sha1('salty');...这给了我以下错误:“解析错误:解析错误,期待',''or';''inC:\xampp\htdocs\test\includes\jaLogin.phponline26"我已经尝试在类定义之外使用这一行并且它工作正常,只有当我在类定义中使用它时才会出现问题。如果我删除“private”这个词,我会得到一个稍微不同的错误:解析错误:解析错误,在第26行的C:\xampp\htdocs\test\includes\jaLogin.php中期待“T_FUNCTION”我觉得我错过了一

java - 你能在 PHP 中获得同样的 Java SHA-1 吗?

我发现自己需要将网站平台从Java更改为PHP,但我想保留所有用户的密码...在将散列值作为网站密码写入之前,我让这段代码对密码进行散列处理:MessageDigestmd=null;md=MessageDigest.getInstance("SHA");md.update(plaintext.getBytes("UTF-8"));byteraw[]=md.digest();hash=newBase64().encodeToString(raw).replaceAll("\n","").replaceAll("\r","");我认为Java代码对密码进行了SHA-1哈希处理,但在此之前

java - Java 中的散列与 PHP 中的盐完全相同吗? (SHA-256)

我可以简单地在PHP中加盐:$orig_pw="abcd";$salt=5f8f041b75042e56;$password=hash('sha256',$orig_pw.$salt);(我不是这样实现的,这只是一个例子,盐因人而异)有了这个,存储的密码是:bc20a09bc9b3d3e1fecf0ed5742769726c93573d4133dbd91e2d309155fa9929但是如果我尝试在Java中做同样的事情,我会得到不同的结果。我试过Stringpassword="abcd";byte[]salt=hexStringToByteArray("5f8f041b75042e5

PHP:PEAR:使用 Crypt_CBC 加密,使用 Perl 的 CBC 解密

我必须完成的任务之一需要我从PHP端加密某些内容,然后使用Perl对其进行解密。PEAR我发现似乎适合我需要的模块是Crypt_CBC。但是,一定有我做错了或不明白的地方,因为到目前为止我一直无法获得正确的结果。下面的代码摘录专门用于测试目的,因为我想在将其应用到我的实际项目代码之前全部尝试一下。首先,这是我的PHP代码,我用它加密传递给$text参数的任何内容(即cryptTest.php?text=hello)require_once('Crypt/CBC.php');$key="8326554161EB30EFBC6BF34CC3C832E7CF8135C1999603D4022