Java簽名校驗(yàn)

1、簽名代碼

/** 
 * 簽名算法 
 */
public static final String SIGN_ALGORITHMS = "SHA1WithRSA";
/** 
 * RSA簽名 
 * @param content   待簽名數(shù)據(jù) 
 * @param privateKey 私鑰 
 * @param encode 字符集編碼 
 * @return 簽名值 
 */  
  public static String sign(String content, String privateKey, String encode)   {  
    try{  
          PKCS8EncodedKeySpec priPKCS8    = new PKCS8EncodedKeySpec( Base64.decode(privateKey) );                   
          KeyFactory keyf = KeyFactory.getInstance("RSA");  
          PrivateKey priKey  = keyf.generatePrivate(priPKCS8);  
     
          java.security.Signature signature = java.security.Signature.getInstance(SIGN_ALGORITHMS);  
          signature.initSign(priKey);  
          signature.update( content.getBytes(encode));  
     
          byte[] signed = signature.sign();                   
          return Base64.encode(signed);  
      } catch (Exception e)  {  
           e.printStackTrace();  
      }  
             
      return null;  
  }

2、驗(yàn)簽代碼

    /** 
     * 校驗(yàn)緩存控制文件的簽名是否合法 
     * @param content  待簽名數(shù)據(jù)
     * @param sign 簽名值
     * @param publicKey 公鑰
     * @return 失敗時(shí),返回false。
     */
     public static boolean verifySignature(String content,String sign,String publicKey){
         if(null == fileText || null == signText || "".equals(fileText) || "".equals(signText)){
             return false;
          }
          try {   
               byte[] pubKeyText = publicKey.getBytes();  
               byte[] signTextByte = signText.getBytes();    
               X509EncodedKeySpec bobPubKeySpec = new X509EncodedKeySpec(Base64.decode(pubKeyText, Base64.DEFAULT));  
               KeyFactory keyFactory = KeyFactory.getInstance("RSA");    
               PublicKey pubKey = keyFactory.generatePublic(bobPubKeySpec);   
               byte[] signed = Base64.decode(signTextByte, Base64.DEFAULT);  
               Signature signatureChecker = Signature.getInstance("SHA1WithRSA");  
               signatureChecker.initVerify(pubKey);   
               signatureChecker.update(content.getBytes());   
               // 驗(yàn)證簽名是否正常   
               return signatureChecker.verify(signed);
           } catch (Exception e) {
               MuLog.error(TAG, e);    
               return false;
           }
     }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容