为啥DES解密出错,求大佬解答

import java.util.Scanner;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.xml.bind.DatatypeConverter;

import org.apache.commons.codec.binary.Hex;

public class DES2 {

public static void main(String[] args) {

    DESEncryption();
    DESDecryption();
}

public static void DESEncryption() {

    try {

        Scanner sc = new Scanner(System.in);
        System.out.println("请输入需要加密内容:");
        String src = sc.nextLine();

        System.out.println("请输入密钥:");
        String str1 = sc.nextLine();
        byte[] bytesKey = str1.getBytes();

        DESKeySpec desKeySpec = new DESKeySpec(bytesKey);
        SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
        SecretKey secretKey = factory.generateSecret(desKeySpec);

        // DES加密
        Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, secretKey);
        byte[] result = cipher.doFinal(src.getBytes());
        String hex = DatatypeConverter.printHexBinary(result);
        System.out.println("Hex:" + hex.toLowerCase());
        System.out.println("DES加密:" + Hex.encodeHexString(result));

    } catch (Exception e) {
        // TODO: handle exception
    }
}

    public static void DESDecryption() {

        try {

            Scanner sc = new Scanner(System.in);
            System.out.println("请输入需要解密内容:");
            String str1 = sc.nextLine();

            System.out.println("请输入密钥:");
            String str2 = sc.nextLine();
            byte[] bytesKey = str2.getBytes();

            DESKeySpec desKeySpec = new DESKeySpec(bytesKey);
            SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
            SecretKey secretKey = factory.generateSecret(desKeySpec);

            Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
            cipher.init(Cipher.DECRYPT_MODE, secretKey);
            byte[] result2 = cipher.doFinal(str1.getBytes());

            System.out.println("DES解密:" + new String(result2));
        } catch (Exception e) {
            System.out.println("解密异常");
        }
    }

}

2个回答

解密过程的入参不应该是输入的,应该直接用你加密后生成的字符数组。解密字符串不是普通的字符,而需要将字节数组转码成 base64 才行。
其次,DES 是对称加密算法,秘钥应该用相同的,
最后一点,异常分支必须打印堆栈信息,否则不知道异常更不能查错。
还有一点,跟 JDK 的加密套件有关系。
参考这个 demo 重试看看。

解密是加密的逆运算,需要保证算法步骤一致,比如加密后调用了Hex.encodeHexString(result),这个方法是做了编码,解密时需要先decode解码,依次类推。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
DES解密问题:通过密钥、偏移量加密正常,解密出错?
DES解密问题:通过密钥、偏移量加密正常,解密出错:Given final block not properly padded.那位大神遇到过这种问题。在线等。 # 问题 ``` package com.whiteink.pms.util; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import javax.crypto.spec.IvParameterSpec; import java.security.Key; import java.util.Base64; public class DESUtil { static String key = "693207DB8148FBC9D8410179"; static String iv = "20190225"; static String encoding = "gb2312"; static String data = "{\"parkCode\":\"1\",\"plateNo\":\"京A11113\"}"; /** * <一句话功能描述>:加密 * <功能详细描述>: 将明文加密 * * @Param: key 密钥 * @Param keyiv 自定义偏移量(8字节) * @Param data 明文 * @Return: byte[] */ public static String des3EncodeCBC(byte[] key, byte[] keyiv, byte[] data) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(keyiv); cipher.init(Cipher.ENCRYPT_MODE, deskey, ips); return Base64.getEncoder().encodeToString(cipher.doFinal(data)); } /** * <一句话功能描述>:解密 * <功能详细描述>: 将密文转成明文 * * @Param: key 密钥 * @Param keyiv 偏移量 * @Param data 明文 * @Return: byte[] */ public static String des3DecodeCBC(byte[] key, byte[] keyiv, byte[] data) throws Exception { System.out.println(new String(data)); DESedeKeySpec dks = new DESedeKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("desede"); SecretKey securekey = keyFactory.generateSecret(dks); // 解密 Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding"); IvParameterSpec ivp = new IvParameterSpec(keyiv); cipher.init(Cipher.DECRYPT_MODE, securekey, ivp); return Base64.getEncoder().encodeToString(cipher.doFinal(data)); } public static void main(String[] args) throws Exception{ String data = "{\"parkCode\":\"1\",\"plateNo\":\"京A11113\"}"; String mw = des3EncodeCBC(key.getBytes(), iv.getBytes(), data.getBytes("GB2312")); System.out.println(des3DecodeCBC(key.getBytes(), iv.getBytes(), mw.getBytes())); } } ``` # 解决方案 ===============解决方案=============== ``` package com.whiteink.pms.util; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import java.util.Base64; public class DESUtil { private static String encoding = "gb2312"; private static String data = "{\"parkCode\":\"1\",\"plateNo\":\"京A11113\"}"; public static String encrypt(String key, String iv, String data) throws Exception { SecretKey secretKey = new SecretKeySpec(key.getBytes(), "desede"); Cipher cipher = Cipher.getInstance("desede/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.ENCRYPT_MODE, secretKey, ips); byte[] encryptData = cipher.doFinal(data.getBytes(encoding)); return Base64.getEncoder().encodeToString(encryptData); } public static void main(String[] args) throws Exception { String key = "693207DB8148FBC9D8410179"; String iv = "20190225"; String encryption = encrypt(key, iv, data); System.out.println(encryption); String decryption = decrypt(key, iv, encryption); System.out.println(decryption); } public static String decrypt(String key, String iv, String data) throws Exception { SecretKey secretKey = new SecretKeySpec(key.getBytes(), "desede"); Cipher cipher = Cipher.getInstance("desede/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.DECRYPT_MODE, secretKey, ips); byte[] decryptData = cipher.doFinal(Base64.getDecoder().decode(data.getBytes(encoding))); return new String(decryptData, "GB2312"); } } ```
关于.net des解密报错的问题。
调用对方得接口,接口返回的字符串是用des加密的,我现在接收放回的加密字符串后,用.net的des解密算法解密,调试报错:要解密的数据的长度无效。 不知道是哪里的问题。我看给的例子用java的这几句就解开了, String str = new String(DesUtil.decrypt(DesUtil .hexStr2ByteArr(bodyData)), "UTF-8"); String parameters = URLDecoder.decode(str, "UTF-8"); 但是我使用.net des解密就报错,请大神指点一下 。
java 3DES 解密时部分乱码
3DES 解密时,出现部分乱码,byte数组里有负值,不知道如何解决 ,求大神指导,代码如下: ``` import java.io.UnsupportedEncodingException; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import javax.crypto.spec.IvParameterSpec; /*字符串 DESede(3DES) 加密 * ECB模式/使用PKCS7方式填充不足位,目前给的密钥是192位 * 3DES(即Triple DES)是DES向AES过渡的加密算法(1999年,NIST将3-DES指定为过渡的 * 加密标准),是DES的一个更安全的变形。它以DES为基本模块,通过组合分组方法设计出分组加 * 密算法,其具体实现如下:设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的 * 密钥,P代表明文,C代表密表,这样, * 3DES加密过程为:C=Ek3(Dk2(Ek1(P))) * 3DES解密过程为:P=Dk1((EK2(Dk3(C))) * */ public class url { private static final String Algorithm = "DESede/CBC/NoPadding"; //定义加密算法,可用 DES,DESede,Blowfish private static final String key="CCBJF2014cowell20151118Y"; private static final String vi = "KW2015rj"; //keybyte为加密密钥,长度为24字节 //src为加密后的缓冲区 public static String decryptMode(String strMi){ try { //szSrc.getBytes("UTF-8"); byte[] src = com.sun.org.apache.xml.internal.security.utils.Base64.decode(strMi); //src = it.sauronsoftware.base64.Base64.encode(src); DESedeKeySpec dks = new DESedeKeySpec(key.getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede"); SecretKey securekey = keyFactory.generateSecret(dks); IvParameterSpec iv = new IvParameterSpec(vi.getBytes()); Cipher cipher = Cipher.getInstance(Algorithm); cipher.init(Cipher.DECRYPT_MODE, securekey,iv ); byte[] encoded = cipher.doFinal(src);//在单一方面的加密或解密 //Base64.encode(encoded); return new String(encoded); } catch (java.security.NoSuchAlgorithmException e1) { // TODO: handle exception e1.printStackTrace(); }catch(javax.crypto.NoSuchPaddingException e2){ e2.printStackTrace(); }catch(java.lang.Exception e3){ e3.printStackTrace(); } return null; } public static void main(String[] args) throws UnsupportedEncodingException { // TODO Auto-generated method stub //添加新安全算法,如果用JCE就要把它添加进去 String szSrc = "G6ZT+GxPq7JkGuLjVQ4TUAUyTcp+UnNpsoKGzy5FudtRNn6v9tSyWmxpcnFu01Rk8Th0NoV0E8TIhffliYQ4xQicG8ciVYWP2s+jk192tJrF6x6WV0ej2w=="; szSrc.getBytes("UTF-8"); System.out.println("jie密前的字符串:" + szSrc); System.out.println("jie密后的字符串:" + decryptMode(szSrc)); //byte[] srcBytes = decryptMode(keyBytes,encoded); //System.out.println("解密后的字符串:" + (new String(srcBytes))); } } ```
DES解密,16位key,解密返回nil
本人在开发中遇到一个des加解密的问题。先上代码 #import "DesEncryption.h" #import <CommonCrypto/CommonCryptor.h> #import "GTMBase64.h" @implementation DesEncryption #pragma mark +++++ //8位key解密有效(已验证) +(NSString*) DecryptUseDES:(NSString*)cipherText key:(NSString*)key { // 利用 GTMBase64 解碼 Base64 字串 NSData* cipherData = [GTMBase64 decodeString:cipherText]; unsigned char buffer[1024]; memset(buffer, 0, sizeof(char)); size_t numBytesDecrypted = 0; // IV 偏移量不需使用 CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES, kCCOptionPKCS7Padding| kCCOptionECBMode, [key UTF8String], kCCKeySizeDES, nil, [cipherData bytes], [cipherData length], buffer, 1024, &numBytesDecrypted); NSString* plainText = nil; if (cryptStatus == kCCSuccess) { NSData* data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted]; plainText = [[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] autorelease]; } return plainText; } ////8位key加密有效(已验证) +(NSString *) EncryptUseDES:(NSString *)clearText key:(NSString *)key { NSData *data = [clearText dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:YES]; unsigned char buffer[1024]; memset(buffer, 0, sizeof(char)); size_t numBytesEncrypted = 0; CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES, kCCOptionPKCS7Padding| kCCOptionECBMode, [key UTF8String], kCCKeySizeDES, nil, [data bytes], [data length], buffer, 1024, &numBytesEncrypted); NSString* plainText = nil; if (cryptStatus == kCCSuccess) { NSData *dataTemp = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted]; plainText = [GTMBase64 stringByEncodingData:dataTemp]; }else{ NSLog(@"DES加密失败"); } return plainText; } 例如:秘钥:abcdefgh 明文:123456 密文:sHTd/9exYuk= 如果秘钥换成:abcdefghabcdefgh 明文:123456 密文:WcbWa42yxuo= 不做任何改动,依旧用上面的解密方法 ,返回的plainText 是nil 期间试图改变kCCKeySizeDES为kCCKeySizeAES128(因为考虑到秘钥长度变为16位),可是结果还是徒劳, 本人尝试改变CCCryptorStatus里面的各种参数,一无所获,特发此贴求助
【JAVA】如何判断输入字符是否DES加密过?
在对输入字符做DES解密时,是否可以先判断下是否加密?如何判断输入字符是否有DES加密?
关于DES算法解密的问题
每次运行代码生成的key值都是不一样的,所以第二次运行不进行加密部分的代码而去解密第一次生成的加密后的文件,是不可行的,这样怎么解决呢?可不可以手动给key赋值,怎么赋值? public class Locker { Key key; public Locker(String str) { getKey(str);//生成密匙 } /** * 根据参数生成KEY */ public void getKey(String strKey) { try { KeyGenerator _generator = KeyGenerator.getInstance("DES"); _generator.init(new SecureRandom(strKey.getBytes())); this.key = _generator.generateKey(); _generator = null; } catch (Exception e) { throw new RuntimeException("Error initializing SqlMap class. Cause: " + e); } } /** * 文件file进行加密并保存目标文件destFile中 * * @param file 要加密的文件 如mnt/sdcard/PateokeyNormal.txt * @param destFile 加密后存放的文件名 如mnt/sdcard/Pateokey.txt */ public void encrypt(String file, String destFile) throws Exception { Cipher cipher = Cipher.getInstance("DES"); // cipher.init(Cipher.ENCRYPT_MODE, getKey()); cipher.init(Cipher.ENCRYPT_MODE, this.key); InputStream is = new FileInputStream(file); OutputStream out = new FileOutputStream(destFile); CipherInputStream cis = new CipherInputStream(is, cipher); byte[] buffer = new byte[1024]; int r; while ((r = cis.read(buffer)) > 0) { out.write(buffer, 0, r); } System.out.println("KEY加密="+key); cis.close(); is.close(); out.close(); } /** * 文件采用DES算法解密文件 * * @param file 已加密的文件 如auth/Pateokey.txt * */ public String decrypt(String file) throws Exception { System.out.println("KEY解密="+key); Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.DECRYPT_MODE, this.key); InputStream is = new FileInputStream(file); String PateoMessage = ""; OutputStream out =System.out; // start ByteArrayOutputStream baos = new ByteArrayOutputStream(); CipherOutputStream cos = new CipherOutputStream(baos, cipher); // end // CipherOutputStream cos = new CipherOutputStream(out, cipher); byte[] buffer = new byte[1024]; int r; while ((r = is.read(buffer)) >= 0) { System.out.println("正在解密"); cos.write(buffer, 0, r); } cos.close(); //out.close(); is.close(); PateoMessage=baos.toString(); baos.close(); System.out.println("正在解密PateoMessage="+PateoMessage); return PateoMessage; } }
求问有什么安全性比较高的加解密算法? des, 3des这种用的很多了吧应该
求问有什么安全性比较高的加解密算法? des, 3des这种用的很多了吧应该
用java对des解密,知道密钥和密文的了
已经知道密文为D6E54EE0CCD748C4E05C38197A020E02B1F206BB8BA8C6EA 密钥为:DF323TGR 想问下怎么弄它的明文 还有就是密钥为DF323TGR和DF323TGR34YR后者是可以的吗? 求大神解答下
使用3des加解密xml文件
新手C#开发,公司要求用3des加密xml文件,打算取用pkcs#7的填充方式对文件内容每10240个字节地进行加密,加密后得出密文长度就是10248,因此解密即每10248个字节进行解密,求大神帮忙
关于DES算法解密,为了安全,不想留下解密后的文件怎么操作?
关于DES算法解密,为了安全,不想留下解密后的文件,只要在代码里面正常读取出来就可以了。这样怎么操作? /** * 文件采用DES算法解密文件 * @param file 已加密的文件 如/mnt/以加密.txt * @param destFile 解密后存放的文件名 如/mnt/解密后文件.txt */ public void decrypt(String file, String dest) throws Exception { Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.DECRYPT_MODE, this.key); InputStream is = new FileInputStream(file); OutputStream out = new FileOutputStream(dest); CipherOutputStream cos = new CipherOutputStream(out, cipher); byte[] buffer = new byte[1024]; int r; while ((r = is.read(buffer)) >= 0) { System.out.println("r="+r); System.out.println("buffer="+buffer); cos.write(buffer, 0, r); } cos.close(); out.close(); is.close(); }
关于java解密的问题,C#DES加密过的数据,用java解密
C#加密解密代码如下 ``` public static String sKey = "xxxxxx"; /// <summary> /// 加密 /// </summary> /// <param name="Text"></param> /// <returns></returns> public static String Encrypt(String EncryptText) { return Encrypt(EncryptText, sKey); } /// <summary> /// 加密数据 /// </summary> /// <param name="Text"></param> /// <param name="sKey"></param> /// <returns></returns> public static String Encrypt(String Text, String sKey) { DESCryptoServiceProvider des = new DESCryptoServiceProvider(); // DESKeySpec k = new DESKeySpec(sKey.getBytes("UTF-8")); byte[] inputByteArray; inputByteArray = Encoding.Default.GetBytes(Text); des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); System.IO.MemoryStream ms = new System.IO.MemoryStream(); CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write); cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); StringBuilder ret = new StringBuilder(); foreach (byte b in ms.ToArray()) { ret.AppendFormat("{0:X2}", b); } return ret.ToString(); } /// <summary> /// 解密 /// </summary> /// <param name="Text"></param> /// <returns></returns> public static String Decrypt(String MD5Text) { return Decrypt(MD5Text, sKey); } /// <summary> /// 解密数据 /// </summary> /// <param name="Text"></param> /// <param name="sKey"></param> /// <returns></returns> public static String Decrypt(String Text, String sKey) { DESCryptoServiceProvider des = new DESCryptoServiceProvider(); int len; len = Text.Length / 2; byte[] inputByteArray = new byte[len]; int x, i; for (x = 0; x < len; x++) { i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); inputByteArray[x] = (byte)i; } des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); System.IO.MemoryStream ms = new System.IO.MemoryStream(); CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write); cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); return Encoding.Default.GetString(ms.ToArray()); } ``` 我写的解密java代码如下 ``` private final byte[] DESkey = DigestUtils.md5Hex("xxxxxx").substring(0, 8).getBytes("UTF-8");// 设置密钥 private final byte[] DESIV = DigestUtils.md5Hex("xxxxxx").substring(0, 8).getBytes("UTF-8");// 设置向量 private AlgorithmParameterSpec iv = null;// 加密算法的参数接口,IvParameterSpec是它的一个实现 private Key key = null; public CryptoTools() throws Exception { DESKeySpec keySpec = new DESKeySpec(DESkey);// 设置密钥参数 iv = new IvParameterSpec(DESIV);// 设置向量 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");// 获得密钥工厂 key = keyFactory.generateSecret(keySpec);// 得到密钥对象 } public String decode(String data) throws Exception { Cipher deCipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); deCipher.init(Cipher.DECRYPT_MODE, key, iv); BASE64Decoder base64Decoder = new BASE64Decoder(); byte[] inputByteArray = base64Decoder.decodeBuffer(data); byte[] pasByte = deCipher.doFinal(inputByteArray); return new String(pasByte, "UTF-8"); } public static void main(String[] args) { try { String test = "0608E27EC1E8A308A84E87D1A6FBC3B0"; CryptoTools des = new CryptoTools();//自定义密钥 System.out.println("加密前的字符:"+test); System.out.println("解密后的字符:"+des.decode(test)); } catch (Exception e) { e.printStackTrace(); } } ``` 测试运行一直报错,求大神解答 ``` javax.crypto.BadPaddingException: Given final block not properly padded at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:966) at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:824) at com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314) at javax.crypto.Cipher.doFinal(Cipher.java:2165) at com.walch.wx.util.md5.util.CryptoTools.decode(CryptoTools.java:59) at com.walch.wx.util.md5.util.CryptoTools.main(CryptoTools.java:69) ERROR: JDWP Unable to get JNI 1.2 environment, jvm->GetEnv() return code = -2 JDWP exit error AGENT_ERROR_NO_JNI_ENV(183): [util.c:840] ```
DES加解密,Java和C里面的填充内容的问题
DES加解密的时候遇到一个问题:C语言中不足八位填充的是‘\0’,我在Java中也是填的这个,但是加密后传给C程序解密失败,两边加密出来的内容不一致!!求教,怎么解决啊!!!C币用完了 求好心人
asp.net DES加密和解密实现方法
asp.net DES加密和解密实现方法,需要代码,加密和解密结果和这个网址一样就可以了http://e-file.arkoo.com/tools/des3.htm
基于EEE3模式的3DES算法加密和解密实现
**实现3DES算法EEE3。其中EEE3表示3个密钥.** _(1)实现3DES算法的加密和解密,完成DES加密过程,输入明文,能加密得到正确密文(密文以十六进制显示)。完成DES解密过程,输入密文(十六进制),能解密得到正确明文(字符形式)。 (2)明文加密之后密文,必须能正确解密出相应明文 (3)明文尾部必须进行填充。例如ECB模式下,DES算法8个字符一组,若输入10个字符“1111111111”,则需要分为2组,第1组8个字符,第2组2个字符,则需要填充。若输入8个字符“11111111”,刚好1组,则需要填充增加1组明文。 (4)尾部填充方法为除最后一个字符填充字符数,其余全填充为“0”字符。例如输入明文“1111111111”,第1组明文输入“11111111”,第二组填充之后明文“11000006”。如输入明文“11111111”,第1组明文输入“11111111”,第二组填充之后明文“00000008”。 (5)DES算法加密和解密,调用变换函数完成。 (6)操作简单,界面美观。 输出要求: (1)用函数实现把字符与二进制相互转换过程,并输出转换后的结果;用函数实现十六进制与二进制相互转换过程。 (2)中间结果包括:3DES算法中,3次调用加密或解密的输出(十六进制)。 编程要求:PHP 可参考: > https://www.oschina.net/code/snippet_221804_20525
各位大神,请问:我手上有一套DES的加解密代码,请问如何把他扩展成3DES的代码呢?
代码形式如下: jiami(before,key,after) jiemi(before,key,after) 要怎么组合成3DES的加解密呢??? 我知道3DES的流程是:加密 解密 加密,但是具体一点是这样的吗: 1 先用key1加密明文,生成密文1 2 再用key2解密密文1,生成一个解密后的文件 3 最后用key3加密步骤2解密后的文件 是这样的步骤吗? 谢谢!!
PHP 3DES 如何兼容 JAVA?
``` package com.test.utils; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import java.security.SecureRandom; import java.security.spec.KeySpec; /** * Des3工具类 */ public class Des3Utils { /** * @Description: DES3 解密 * @param key * @param src * @return String */ public static String decryptEde(String key, String src) { String plainText = null; try { byte[] keyBytes = new byte[24]; asciiToBcdBytes(key, keyBytes, Math.min(32, key.length()) / 2); for (int i = 0; i < 8; ++i) keyBytes[16 + i] = keyBytes[i]; // 从原始密匙数据创建一个DESKeySpec对象 KeySpec dks = new DESedeKeySpec(keyBytes); // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成 // 一个SecretKey对象 SecretKey secKey = SecretKeyFactory.getInstance("DESede").generateSecret(dks); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance("DESede/ECB/NoPadding"); // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); // 用密匙初始化Cipher对象 cipher.init(Cipher.DECRYPT_MODE, secKey, sr); int count = (src.length() + 1) / 2; byte[] inputBytes = new byte[count]; asciiToBcdBytes(src, inputBytes, count); // 正式执行解密操作 byte[] decryptBytes = cipher.doFinal(inputBytes); int olen = decryptBytes.length - 1; for (; decryptBytes[olen] == 0 && olen >= 0; --olen) { } plainText = new String(decryptBytes, 0, olen + 1); } catch (Exception e) { e.printStackTrace(); } return plainText; } private static void asciiToBcdBytes(String str, byte[] hex, int count) { byte[] inputBytes = str.getBytes(); for (int i = 0, j = 0; j < inputBytes.length && i < count; ++i) { byte v = inputBytes[j]; ++j; if (v <= 0x39){ hex[i] = (byte) (v - 0x30); } else { hex[i] = (byte) (v - 0x41 + 10); } hex[i] <<= 4; if (j >= inputBytes.length) { break; } v = inputBytes[j]; ++j; if (v <= 0x39) { hex[i] += (byte) (v - 0x30); } else { hex[i] += (byte) (v - 0x41 + 10); } } } /** * @Description: DES3 加密 * @param key * @param src * @return String */ public static String encryptEde(String key, String src) { String plainText = null; try { byte[] keyBytes = new byte[24]; asciiToBcdBytes(key, keyBytes, Math.min(32, key.length()) / 2); for (int i = 0; i < 8; ++i) keyBytes[16 + i] = keyBytes[i]; // 从原始密匙数据创建一个DESKeySpec对象 KeySpec dks = new DESedeKeySpec(keyBytes); // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成 // 一个SecretKey对象 SecretKey secKey = SecretKeyFactory.getInstance("DESede").generateSecret(dks); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance("DESede/ECB/NoPadding"); // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); // 用密匙初始化Cipher对象 cipher.init(Cipher.ENCRYPT_MODE, secKey, sr); byte[] srcBytes = src.getBytes("UTF-8"); int srcLen = srcBytes.length; int encLen = ((srcLen % 8) == 0) ? srcLen : ((srcLen / 8 + 1) * 8); byte[] encBytes = new byte[encLen]; System.arraycopy(srcBytes, 0, encBytes, 0, srcLen); // 正式执行解密操作 byte[] encryptBytes = cipher.doFinal(encBytes); plainText = bcdBytesToAscii(encryptBytes, encLen); } catch (Exception e) { e.printStackTrace(); } return plainText; } private static String bcdBytesToAscii(byte[] hex, int count) { byte[] ascii = new byte[2 * count]; int t; for (int i = 0; i < count; i++) { t = hex[i] & 0xf0; t = t >> 4; if (t <= 9) t += '0'; else if (t >= 10 && t <= 15) t += 'A' - 10; else t = '0'; ascii[2 * i] = (byte) t; t = hex[i] & 0x0f; if (t <= 9) t += '0'; else if (t >= 10 && t <= 15) t += 'A' - 10; else t = '0'; ascii[2 * i + 1] = (byte) t; } return (new String(ascii)); } } ``` 本人目前 php 使用的是 [3DES加密如何兼容Java](https://segmentfault.com/q/1010000007199868 "") 中的代码。
用combat 去除批次效应,报错:Error in solve.default(crossprod(des), crossprod(des, y1)) : Lapack routine dgesv: system is exactly singular: U[1,1] = 0,如何解决?
一个GSE数据集,但是它有两个批次,我想去除批次效应 代码如下: 1. G24807=as.matrix(GSE24807) 1. rownames(G24807)=G24807[,1] 1. exp=G24807[,2:ncol(G24807)] 1. dimnames=list(rownames(exp),colnames(exp)) 1. data=matrix(as.numeric(as.matrix(exp)),nrow = nrow(exp),dimnames = dimnames) 1. batchtype=c(rep(1,9),rep(2,8)) 1. modtype=c(rep("HC",2),rep("NASH",7),rep("HC",3),rep("NASH",5)) 1. mod=model.matrix(~as.factor(modtype)) 1. outtable=ComBat(data,batchtype,mod,par.prior=TRUE) 运行outtable=......这一步时报错信息如下: _>outtable=ComBat(data,batchtype,mod,par.prior=TRUE)_ 1. Found2batches 1. Adjusting for1covariate(s) or covariate level(s) 1. Found1716Missing Data Values 1. Standardizing Data across genes 1. **Error in solve.default(crossprod(des), crossprod(des, y1)) : 1. Lapack routine dgesv: system is exactly singular: U[1,1] = 0** 不知道为什么出现这个错误,以及如何解决呢?
java中的 DES 加密与解密
DES类 ---------------- package dao; import java.security.Security; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; public class DES { public static String ALGORITHM_DES="DES"; //加密算法的名称 public static KeyGenerator keygen; //密钥生成器 public static SecretKey secretKey; //密钥 public static Cipher cipher; //密码器 public byte[] bytes; static{ Security.addProvider(new com.sun.crypto.provider.SunJCE()); try{ keygen=KeyGenerator.getInstance(ALGORITHM_DES); secretKey=keygen.generateKey(); cipher=Cipher.getInstance(ALGORITHM_DES); }catch(Exception e){ e.printStackTrace(); } } //加密 public byte[] encryptor(String str){ try { cipher.init(Cipher.ENCRYPT_MODE, secretKey); //初始化密码器,用密钥 secretKey 进入加密模式 bytes=cipher.doFinal(str.getBytes()); //加密 } catch (Exception e) { e.printStackTrace(); } return bytes; } //解密 public String decryptor(byte[] buff){ try { cipher.init(Cipher.DECRYPT_MODE, secretKey); //初始化密码器,用密钥 secretKey 进入解密模式 bytes=cipher.doFinal(buff); } catch (Exception e) { e.printStackTrace(); } return (new String(bytes)); } } index.jsp ----------- ![index.jsp](https://img-ask.csdn.net/upload/201602/23/1456203162_827018.png) %> <a href="productAction-query?product_id=<%=des.encryptor(test) %>" target="_blank">Demo</a> Action类 ----------------------- ![Action类](https://img-ask.csdn.net/upload/201602/23/1456203135_614689.png) 我的问题:在 index.jsp 页面里提交的超链接 Demo 提交到 Action ,但是一点击,后台就报错: javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:750) at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:676) at com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314) at javax.crypto.Cipher.doFinal(Cipher.java:2087) at dao.DES.decryptor(DES.java:44) at filter.MyFilter.doFilter(MyFilter.java:36) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:212) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:141) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:521) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1096) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:674) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1500) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1456) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Unknown Source) java.lang.NullPointerException at java.lang.String.<init>(Unknown Source) at dao.DES.decryptor(DES.java:48) at filter.MyFilter.doFilter(MyFilter.java:36) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:212) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:141) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:521) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1096) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:674) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1500) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1456) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Unknown Source) 解密前:product_id=[B@3242ef 是哪里写的不对,请高手指点,我的目的是从 index.jsp 把值(product_id)进行加密,在 Action 里面取出 加密后的字符串,进行解密,但解密那一块有问题,可能是 DES 类写的有问题,请高手帮忙在原有的代码基础上修改。成分感激!!
DES加密不一致问题,求大神解决
各位大神 小弟在做一个文件传输项目 对方系统用的是c#写的des加解密算法 密钥:Bank2014 加密偏移量:Bank2014 加密模式:CipherMode.CBC、PaddingMode.PKCS5 块长度:64 文件编码:GBK 小弟这边用的是c写的加解密算法我就只设置了密钥:Bank2014 代码是参照大赛写的 位置在:http://www.iteye.com/topic/478024 目前的问题就是对方公司加密出来的文件跟我加密出来的文件不一样 我的代码是否需要设置加密偏移量呢 还是代码本身就有问题 求大神指点 先跪谢了
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了无数
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
MyBatis研习录(01)——MyBatis概述与入门
C语言自学完备手册(33篇) Android多分辨率适配框架 JavaWeb核心技术系列教程 HTML5前端开发实战系列教程 MySQL数据库实操教程(35篇图文版) 推翻自己和过往——自定义View系列教程(10篇) 走出思维困境,踏上精进之路——Android开发进阶精华录 讲给Android程序员看的前端系列教程(40集免费视频教程+源码) 版权声明 本文原创作者:谷哥的小弟 作者博客
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
你知道的越多,你不知道的越多 点赞再看,养成习惯 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试点思维导图,也整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。 前前言 为啥今天有个前前言呢? 因为你们的丙丙啊,昨天有牌面了哟,直接被微信官方推荐,知乎推荐,也就仅仅是还行吧(心里乐开花)
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
Python爬虫精简步骤1 获取数据
爬虫的工作分为四步: 1.获取数据。爬虫程序会根据我们提供的网址,向服务器发起请求,然后返回数据。 2.解析数据。爬虫程序会把服务器返回的数据解析成我们能读懂的格式。 3.提取数据。爬虫程序再从中提取出我们需要的数据。 4.储存数据。爬虫程序把这些有用的数据保存起来,便于你日后的使用和分析。 这一篇的内容就是:获取数据。 首先,我们将会利用一个强大的库——requests来获取数据。 在电脑上安装
Python绘图,圣诞树,花,爱心 | Turtle篇
1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle() circle.shape('circle') circle.color('red') circle.speed('fastest') circle.up() square = turtle.Turtle()
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 更多有趣分析教程,扫描下方二维码关注vx公号「裸睡的猪」 即可查看! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布
web前端javascript+jquery知识点总结
Javascript javascript 在前端网页中占有非常重要的地位,可以用于验证表单,制作特效等功能,它是一种描述语言,也是一种基于对象(Object)和事件驱动并具有安全性的脚本语言 ,语法同java类似,是一种解释性语言,边执行边解释。 JavaScript的组成: ECMAScipt 用于描述: 语法,变量和数据类型,运算符,逻辑控制语句,关键字保留字,对象。 浏览器对象模型(Br
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
文章目录1. 前言2. 数据下载3. 数据处理4. 数据可视化 1. 前言 今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。 2月6日追记:本文发布后,腾讯的数据源多次变更u
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
渗透测试-灰鸽子远控木马
木马概述 灰鸽子( Huigezi),原本该软件适用于公司和家庭管理,其功能十分强大,不但能监视摄像头、键盘记录、监控桌面、文件操作等。还提供了黑客专用功能,如:伪装系统图标、随意更换启动项名称和表述、随意更换端口、运行后自删除、毫无提示安装等,并采用反弹链接这种缺陷设计,使得使用者拥有最高权限,一经破解即无法控制。最终导致被黑客恶意使用。原作者的灰鸽子被定义为是一款集多种控制方式于一体的木马程序
Python:爬取疫情每日数据
前言 有部分同学留言说为什么412,这是因为我代码里全国的cookies需要你自己打开浏览器更新好后替换,而且这个cookies大概只能持续20秒左右! 另外全国卫健委的数据格式一直在变,也有可能会导致爬取失败! 我现在已根据2月14日最新通报稿的格式修正了! 目前每天各大平台,如腾讯、今日头条都会更新疫情每日数据,他们的数据源都是一样的,主要都是通过各地的卫健委官网通报。 为什么已经有大量平台做
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。   再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。   下文是原回答,希望能对你能有所启发。   如果我说,这个世界上人真的分三六九等,
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计
Python新型冠状病毒疫情数据自动爬取+统计+发送报告+数据屏幕(三)发送篇
今天介绍的项目是使用 Itchat 发送统计报告 项目功能设计: 定时爬取疫情数据存入Mysql 进行数据分析制作疫情报告 使用itchat给亲人朋友发送分析报告(本文) 基于Django做数据屏幕 使用Tableau做数据分析 来看看最终效果 目前已经完成,预计2月12日前更新 使用 itchat 发送数据统计报告 itchat 是一个基于 web微信的一个框架,但微信官方并不允
作为程序员的我,大学四年一直自学,全靠这些实用工具和学习网站!
我本人因为高中沉迷于爱情,导致学业荒废,后来高考,毫无疑问进入了一所普普通通的大学,实在惭愧...... 我又是那么好强,现在学历不行,没办法改变的事情了,所以,进入大学开始,我就下定决心,一定要让自己掌握更多的技能,尤其选择了计算机这个行业,一定要多学习技术。 在进入大学学习不久后,我就认清了一个现实:我这个大学的整体教学质量和学习风气,真的一言难尽,懂的人自然知道怎么回事? 怎么办?我该如何更好的提升
粒子群算法求解物流配送路线问题(python)
粒子群算法求解物流配送路线问题(python) 1.查找论文文献 找一篇物流配送路径优化+粒子群算法求解的论文 参考文献:基于混沌粒子群算法的物流配送路径优化 2.了解粒子群算法的原理 讲解通俗易懂,有数学实例的博文:https://blog.csdn.net/daaikuaichuan/article/details/81382794 3.确定编码方式和解码策略 3.1编码方式 物流配送路线的
教你如何编写第一个简单的爬虫
很多人知道爬虫,也很想利用爬虫去爬取自己想要的数据,那么爬虫到底怎么用呢?今天就教大家编写一个简单的爬虫。 下面以爬取笔者的个人博客网站为例获取第一篇文章的标题名称,教大家学会一个简单的爬虫。 第一步:获取页面 #!/usr/bin/python # coding: utf-8 import requests #引入包requests link = "http://www.santostang.
前端JS初级面试题二 (。•ˇ‸ˇ•。)老铁们!快来瞧瞧自己都会了么
1. 传统事件绑定和符合W3C标准的事件绑定有什么区别? 传统事件绑定 &lt;div onclick=""&gt;123&lt;/div&gt; div1.onclick = function(){}; &lt;button onmouseover=""&gt;&lt;/button&gt; 注意: 如果给同一个元素绑定了两次或多次相同类型的事件,那么后面的绑定会覆盖前面的绑定 (不支持DOM事...
相关热词 c#如何定义数组列表 c#倒序读取txt文件 java代码生成c# c# tcp发送数据 c#解决时间格式带星期 c#类似hashmap c#设置istbox的值 c#获取多线程返回值 c# 包含数字 枚举 c# timespan
立即提问

相似问题

13
结构体里面包含结构体变量,用scanf赋值
2
java.security.InvalidKeyException: Wrong key size
0
求 .NET AES解密方法对应的JAVA代码
2
xshell执行脚本,spool打印输出信息,如何去除所有提示信息(包括查找到的数据)
1
使用lr11录制的app代码用户名和密码使用guthub上的开源框架框架des加密怎样解密进行参数化
3
sonar 配置mysql 连接报错
2
小程序开发之搭建WebSocket的WSS环境(Nginx+WorkerMan框架+PHP)
2
.net core如何解密.net framework System.Web.Security.MachineKey.Protect()加密的密文?
2
【球球大家了】VS2017出现error C2062: 意外的类型“char”怎么解决?
3
python+appium+夜神运行程序报错:Could not find a connected Android device.
0
这段js的16进制des加解密代码 怎么转换成php?
1
微信小程序关于多张图片上传之后,路径却存不到数据库中的问题
1
几行python代码消耗将近20g内存,电脑跑崩了?pydev debugger: process 15180 is connecting
0
C++ opencv对图像使用硬拼接如何解决无缝融合问题
0
des加解密,密文不一致
0
有大神能给份des加解密的java代码没,最好是16进制密文的,找了不少都是base64的
1
Qt 要求根据一个节点的某一属性查找出该节点的其他属性,
1
新手求教 用sift处理后的图片得到的特征矩阵大小为什么不相同?
1
关于C++异常抛出常量字符串无法被char*捕获
1
微信小程序调用企业付款时报错(nodejs搭建后台)