草庐IT

Java SHA256 输出不同的散列到 PHP SHA256?

PHP代码:echohash('sha256','jake');PHP输出:cdf30c6b345276278bedc7bcedd9d5582f5b8e0c1dd858f46ef4ea231f92731dJava代码:Strings="jake";MessageDigestmd=MessageDigest.getInstance("SHA-256");md.update(s.getBytes(Charset.forName("UTF-8")));byte[]hashed=md.digest();Strings2="";for(byteb:hashed){s2+=b;}System.ou

c# - Rijndael 256 在 c# 和 php 之间加密/解密?

已更新我已经对C#代码进行了更改,因此它使用的block大小为256。但是现在HelloWorld看起来像这样的http://pastebin.com/5sXhMV11,我无法弄清楚我应该使用rtrim()来摆脱困惑结束。此外,当您说IV应该是随机的时,您的意思是不要多次使用相同的IV,还是我的编码方式有误?再次感谢!你好,我正在尝试使用PHP解密在C#中加密的字符串。我似乎无法让PHP使用mcrypt对其进行解密,请提供一些帮助。我在使用php时遇到以下错误,所以我猜我没有正确设置IV。错误:IV参数必须与block大小一样长这两个函数使用相同的密码、key、IV并设置为CBC模式:

java - SHA256withRSA 签名从 PHP 验证从 JAVA

对于我当前的项目,我必须将签名从PHP发送到Java应用程序。我现在正在使用Crypt/RSA来签署我的数据。为了测试,我只使用以下代码签署“abc”:$rsa=newCrypt_RSA();$plaintext='abc';$rsa->loadKey("MIICXgIBAAKBgQDjh+hNsqJe566JO0Sg7Iq5H1AdkauACdd8QMLp9YNY0HPslVH0rXaOFo0zgH0Ktu/Ku3lS1lfxbFQAY8b6ywZKvu4eoxlnEwuBwy09CG+3ZiVLBjCjTZHA/KOkpVLa+tA6KsoP6zv/xI/ACkSCxPGR0q3S

php - Android中的加密相当于php的MCRYPT_RIJNDAEL_256

我正在使用下面的php代码进行加密:$enc_request=base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256,$this->_app_key,json_encode($request_params),MCRYPT_MODE_ECB));现在尝试在android中加密并获取不同的加密字符串。下面是安卓代码:publicvoidenc(){byte[]rawKey=getRawKey("my_key".getBytes());SecretKeySpecskeySpec=newSecretKeySpec(rawKey,"AES");Ciphe

java - 如何像在 PHP 中一样制作 Android Java HMAC SHA256?

我有一段PHP代码:$str=base64_encode('1234');$key='1234';print(base64_encode(hash_hmac('sha256',$str,$key,true)));AndroidJava(AndroidStudio)的代码是什么?这段代码给出了与PHP不同的结果:importandroid.support.v7.app.AppCompatActivity;importandroid.os.Bundle;importandroid.util.Base64;importandroid.util.Log;importjavax.crypto.M

android - Android 是否支持 AES256/CTR/NoPadding?

Ciphercipher=Cipher.getInstance("AES256/CTR/NoPadding")以上代码抛出如下异常:Stacktrace:java.security.NoSuchAlgorithmException:AES256/CTR/NoPaddingatjavax.crypto.Cipher.getCipher(Cipher.java:296)atjavax.crypto.Cipher.getInstance(Cipher.java:174)Android是否支持“AES256/CTR/NoPadding”?这个设备依赖吗?我正在测试的Android设备具有以下提

java - 如何使用 spongy caSTLe 为比特币曲线 (secp256k1) 创建 ECDSA key 对(256 位)?

目前,我正在使用这种方法创建key对privateKeyPairgetKeyPair()throwsNoSuchAlgorithmException,NoSuchProviderException,InvalidAlgorithmParameterException{KeyPairGeneratorkeyGen=KeyPairGenerator.getInstance("ECDsA","SC");ECGenParameterSpececSpec=newECGenParameterSpec("secp256k1");keyGen.initialize(ecSpec,newSecureRa

java - Android Studio 2.0 - NoSuchAlgorithmException : SHA256WITHDSA Signature not available

我正在运行AndroidStudio2.0Preview3b并尝试从Build菜单中使用“GenerateSignedAPK...”。我收到以下错误消息Pane::wear:packageReleaseFAILEDFAILURE:Buildfailedwithanexception.*Exceptionis:org.gradle.api.tasks.TaskExecutionException:Executionfailedfortask':wear:packageRelease'.atorg.gradle.api.internal.tasks.execution.ExecuteAct

java - 具有 RSA 签名的 SHA256 在各种 Android 设备上返回不同的输出

我正在开发一个Android应用程序,我需要使用javaSignatureclass用于数据认证。在每台Android设备上,我都可以签署数据并验证其签名。但是,给定要签名的确定数据block、确定的模数、确定的私有(private)指数和确定的公共(public)指数,我的签名输出会有所不同,具体取决于设备。我确实尝试了一堆设备,并且我获得了适用于Android3.2和3.2.1的相同签名,但获得了适用于Android2.2.x设备的不同签名。我根据之前在java项目中使用带有RSA的KeyFactory生成的常量字段计算这些签名。key大小为2048位。这是我用来调用签名和验证的代

android - AES 加密 : InvalidKeyException: Key length not 128/192/256 bits

我正在尝试使用AES加密Android上的字符串。对称key是之前用Diffie-Hellman算法确定的,似乎没问题(key长度是128位,见下文)。然而,我得到一个InvalidKeyException:"Keylengthnot128/192/256bits."代码:KeyAgreementkeyAgree=KeyAgreement.getInstance("DH","BC");keyAgree.init(this.smartphonePrivKey);keyAgree.doPhase(serverPubKey,true);SecretKeykey=keyAgree.genera