当前位置: 首页 > news >正文

服务器怎么直接用ip做网站网站站群怎么做

服务器怎么直接用ip做网站,网站站群怎么做,对百度竞价排名的看法,怎样开公众号目录 一、MD5加密二、RSA加解密(公加私解,私加公解)三、RSA私钥加密四、RSA私钥加密PKCS1Padding模式 一、MD5加密 密文形式:5eb63bbbe01eeed093cb22bb8f5acdc3 import java.math.BigInteger; import java.security.MessageDigest; import java.security…

目录

    • 一、MD5加密
    • 二、RSA加解密(公加私解,私加公解)
    • 三、RSA私钥加密
    • 四、RSA私钥加密`PKCS1Padding`模式

一、MD5加密

密文形式:5eb63bbbe01eeed093cb22bb8f5acdc3

import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;public class MD5 {public static String stringToMD5(String plainText) {byte[] secretBytes = null;try {secretBytes = MessageDigest.getInstance("md5").digest(plainText.getBytes());} catch (NoSuchAlgorithmException e) {throw new RuntimeException("没有这个md5算法!");}String md5code = new BigInteger(1, secretBytes).toString(16);for (int i = 0; i < 32 - md5code.length(); i++) {md5code = "0" + md5code;}return md5code;}public static void main(String[] args) {System.out.println(stringToMD5("hello world"));}
}

二、RSA加解密(公加私解,私加公解)

密文形式:W1WTmVo870wB9t6/kGxTV4b2wuI7iHGLNDP+24SyD45==

package com.bytedance.frameworks.core.encrypt;import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import javax.crypto.Cipher;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;public class RSA {public static String RSAEncryptByPublickey(String str, String publicKey) throws Exception {/* RSA通过公钥加密 *///base64编码的公钥byte[] decoded = Base64.decode(publicKey);RSAPublicKey pubKey = (RSAPublicKey) KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decoded));//RSA加密Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.ENCRYPT_MODE, pubKey);String outStr = Base64.encode(cipher.doFinal(str.getBytes("UTF-8")));return outStr;}public static String RSAEncryptByPrivatekey(String content,String private_key) {/* RSA通过私钥加密 */String charset = "utf-8";try {PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(Base64.decode(private_key));KeyFactory keyf = KeyFactory.getInstance("RSA");PrivateKey priKey = keyf.generatePrivate(priPKCS8);java.security.Signature signature = java.security.Signature.getInstance("SHA1WithRSA");signature.initSign(priKey);signature.update(content.getBytes(charset));byte[] signed = signature.sign();return Base64.encode(signed);} catch (Exception e) {e.printStackTrace();}return null;}public static String RSADecryptByPublicKey(String str, String publicKey) throws Exception {/* RSA通过公钥解密 */byte[] inputByte = Base64.decode(str);//base64编码的私钥byte[] decoded = Base64.decode(publicKey);PublicKey pubKey =  KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decoded));//RSA解密Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.DECRYPT_MODE, pubKey);String outStr = new String(cipher.doFinal(inputByte));return outStr;}public static String RSADecryptByPrivateKey(String data, String privateKey) throws Exception {/* RSA通过私钥解密 */byte[] inputByte = Base64.decode(data);//base64编码的私钥byte[] decoded = Base64.decode(privateKey);RSAPrivateKey priKey = (RSAPrivateKey) KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(decoded));//RSA解密Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.DECRYPT_MODE, priKey);String outStr = new String(cipher.doFinal(inputByte));String str1 = outStr.substring(0,32);String hex = base64Tohex(str1);String Des_key = hex.substring(0,16);return Des_key;}public static String byteToHex(byte b){String hexString = Integer.toHexString(b & 0xFF);//由于十六进制是由0~9、A~F来表示1~16,所以如果Byte转换成Hex后如果是<16,就会是一个字符(比如A=10),通常是使用两个字符来表示16进制位的,//假如一个字符的话,遇到字符串11,这到底是1个字节,还是1和1两个字节,容易混淆,如果是补0,那么1和1补充后就是0101,11就表示纯粹的11if (hexString.length() < 2){hexString = new StringBuilder(String.valueOf(0)).append(hexString).toString();}return hexString.toUpperCase();}public static String bytesToHex(byte[] bytes){StringBuffer sb = new StringBuffer();if (bytes != null && bytes.length > 0){for (int i = 0; i < bytes.length; i++) {String hex = byteToHex(bytes[i]);sb.append(hex);}}return sb.toString();}public static String base64Tohex(String bstxt){byte[] bs = Base64.decode(bstxt);String hex = bytesToHex(bs);return hex.toLowerCase();}public static void main(String[] args) {}
}

三、RSA私钥加密

package com.bytedance.frameworks.core.encrypt;import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import sun.misc.BASE64Decoder;import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.Signature;
import java.security.spec.PKCS8EncodedKeySpec;public class RSAEncrypt {public static final String KEY_ALGORTHM = "RSA";public static final String SIGNATURE_ALGORITHM = "SHA256WithRSA";public static String RSAEnByPrivate(String content,String PrivateKey) throws Exception {// BC模式java.security.Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());//解密私钥byte[] keyBytes = decryptBASE64(PrivateKey);// byte[] keyBytes = privateKey.getBytes();//构造PKCS8EncodedKeySpec对象PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(keyBytes);//指定加密算法KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);//取私钥匙对象PrivateKey privateKey2 = keyFactory.generatePrivate(pkcs8EncodedKeySpec);//用私钥对信息生成数字签名Signature signature = Signature.getInstance(SIGNATURE_ALGORITHM);signature.initSign(privateKey2);signature.update(content.getBytes());return Base64.encode(signature.sign());}public static byte[] decryptBASE64(String key) throws Exception {return (new BASE64Decoder()).decodeBuffer(key);}public static void main(String[] args) throws Exception  {String content = "xxx";String PrivateKey = "xxx";System.out.println(RSAEnByPrivate(content,PrivateKey));}}

四、RSA私钥加密PKCS1Padding模式

    public static String encryptByPrivateKey(String content,String privateKey) throws Exception {byte[] keyBytes = Base64.decode(privateKey);PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance("RSA");PrivateKey PrivateKey = keyFactory.generatePrivate(keySpec);Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.ENCRYPT_MODE, PrivateKey);byte[] cipherText = cipher.doFinal(content.getBytes());String cipherStr = Base64.encode(cipherText);return cipherStr;}
http://www.yayakq.cn/news/865032/

相关文章:

  • 网站建设vi设计wordpress大气企业主题
  • 优化网站目录结构免费申请logo
  • 机关门户网站建设管理情况杭州两网建设
  • 一家专门做特卖的网站手机版网站开发费用算无形资产
  • 宁波哪家公司做网站好网站建设js
  • 建网站要多少钱wordpress登录开发
  • 寿光做网站的孟村县网站建设公司
  • 织梦微信网站模板婚恋网站 模板
  • h5网站建设模板下载平面设计外包平台
  • 展厅设计费做网站优化有什么途径
  • 做企业网站的架构图wordpress特效
  • 网站界面设计和ios移动界面设计的区别wordpress 插件报错
  • 建设营销型网站的目的长春网站建设公司怎么样
  • 贵州建设厅考试网站安全员张伟专业团队
  • 织梦怎么制作网站企业网站的建设目的是什么
  • 编辑网站用什么软件成都网站建设交易
  • 2017年网站开发用什么语言遂宁做网站的公司
  • 江苏网站开发建设多少钱广告设计与制作课程
  • 做程序的网站南阳免费网站建设
  • 做效果图的兼职网站wordpress显示文章图片
  • 线上少儿编程网站开发杭州百度代理公司
  • 做网站很麻烦吗宝安电子厂做高端网站
  • 广东企业网站seo报价网络营销有什么新的变化
  • 地产网站建设方案有网站如何做淘宝客
  • 网站备案幕布要求杭州网站建设 乐云践新专家
  • 什么网站做护工网站首页布局
  • 网站建设 合作协议外贸网站后台
  • 网站建设及优化重要性wordpress的函数
  • 上海网站建设官方网站网站左侧导航栏设计
  • 专业摄影网站推荐百度ai入口