关于3DES加密,直接上代码求指点
  1. public static byte[] encryptMode(byte[] keybyte, byte[] src){

        try {
           // SecretKey deskey = new SecretKeySpec(keybyte, Algorithm);;
            String deskey = "abcdabcd";
            Cipher c1 = Cipher.getInstance(Algorithm);
            c1.init(Cipher.ENCRYPT_MODE, deskey);
           c1.init(ENCRYPT_MODE, deskey);
            return c1.doFinal(src);
        } catch (java.security.NoSuchAlgorithmException e1) {
            e1.printStackTrace();
        }catch(javax.crypto.NoSuchPaddingException e2){
            e2.printStackTrace();
        }catch(java.lang.Exception e3){
            e3.printStackTrace();
        }
        return null;
    }
    
            没注释掉的是网上的代码,现在想自己定义一个密钥进行加密,要怎样修改?求指点。。。。
    

0个回答

3des加密代码
3des 加密
3DES 加密算法
----------------------同志你好,我是CSDN问答机器人小N,奉组织之命为你提供参考答案,编程尚未成功,同志仍需努力!

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
JAVA.C#关于3DES加密的代码转化
现在需要一份Java版的3DES加密。 但是对方给的是一份C#版本的。 求哪个大神帮忙转化一下。 或者告知C#代码的思路。 key是9762D45A7F5F49FDA284FB686A4F99B9 向量是01,02,03,04,05,06,07,08 ``` public static string EncryptSP(string toEncryptStr, string key, string iv) { string ErrorDesc = ""; if (toEncryptStr == "") return ""; try { if (key.Length < 24) { key = key.PadRight(24, '1'); } byte[] Encrypted, ivArray, keyArray; // 获取加密向量和CP密钥 ivArray = CryptographyUtility.HexStringToByteArray(iv); keyArray = Encoding.Default.GetBytes(key); if (EncryptSP(keyArray, ivArray, ConvertStringToByteArray(toEncryptStr), out Encrypted)) { return ByteArrayToHexString(Encrypted); } else return ""; } catch (Exception e) { ErrorDesc = e.Message; throw new Exception("CommonEncrypt(使用固定Key对字符串进行加密)-》" + ErrorDesc); } catch { ErrorDesc = CryptogramErrorDefinition.E_Cryptogram_SYSTEM_ERROR_DESC; throw new Exception("CommonEncrypt(使用固定Key对字符串进行加密)-》" + ErrorDesc); } } /// <summary> /// 将16进制字符串转换成byte数组 /// </summary> /// <param name="s"></param> /// <returns></returns> public static byte[] HexStringToByteArray(string s) { Byte[] buf = new byte[s.Length / 2]; for (int i = 0; i < buf.Length; i++) { buf[i] = (byte)(chr2hex(s.Substring(i * 2, 1)) * 0x10 + chr2hex(s.Substring(i * 2 + 1, 1))); } return buf; } /// <summary> /// 字符转换成16显示 /// </summary> /// <param name="chr"></param> /// <returns></returns> private static byte chr2hex(string chr) { switch (chr) { case "0": return 0x00; case "1": return 0x01; case "2": return 0x02; case "3": return 0x03; case "4": return 0x04; case "5": return 0x05; case "6": return 0x06; case "7": return 0x07; case "8": return 0x08; case "9": return 0x09; case "A": return 0x0a; case "B": return 0x0b; case "C": return 0x0c; case "D": return 0x0d; case "E": return 0x0e; case "F": return 0x0f; } return 0x00; } /// <summary> /// 加密(3DES) /// </summary> /// <param name="KEY">加密密钥</param> /// <param name="IV">加密向量</param> /// <param name="TobeEncrypted">加密字符串</param> /// <param name="Encrypted">加密后Byte数组</param> /// <returns></returns> public static bool EncryptSP(byte[] KEY, byte[] IV, byte[] TobeEncrypted, out byte[] Encrypted) { string ErrorDesc = ""; if (KEY == null || IV == null) throw new Exception("Encrypt(加密)-》" + ErrorDesc); Encrypted = null; try { byte[] tmpiv = { 0, 1, 2, 3, 4, 5, 6, 7 }; for (int ii = 0; ii < 8; ii++) { tmpiv[ii] = IV[ii]; } byte[] tmpkey = { 0, 1, 2, 3, 4, 5, 6, 7, 0, 1, 2, 3, 4, 5, 6, 7, 0, 1, 2, 3, 4, 5, 6, 7 }; for (int ii = 0; ii < 24; ii++) { tmpkey[ii] = KEY[ii]; } //tridesencrypt.Dispose(); des3.Mode = CipherMode.ECB; ICryptoTransform tridesencrypt = des3.CreateEncryptor(tmpkey, tmpiv); //tridesencrypt = des.CreateEncryptor(KEY,tmpiv); Encrypted = tridesencrypt.TransformFinalBlock(TobeEncrypted, 0, TobeEncrypted.Length); //tridesencrypt.Dispose(); des3.Clear(); return true; } catch (Exception e) { ErrorDesc = e.Message; throw new Exception("Encrypt(加密)-》" + ErrorDesc); } catch { ErrorDesc = CryptogramErrorDefinition.E_Cryptogram_SYSTEM_ERROR_DESC; throw new Exception("Encrypt(加密)-》" + ErrorDesc); } } public static byte[] ConvertStringToByteArray(String s) { return System.Text.Encoding.GetEncoding("utf-8").GetBytes(s);//gb2312 } public static string ByteArrayToHexString(byte[] buf) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < buf.Length; i++) { sb.Append(buf[i].ToString("X").Length == 2 ? buf[i].ToString("X") : "0" + buf[i].ToString("X")); } return sb.ToString(); } ```
关于C++ 的3DES加密问题
求各位大神提供一份des/3des加密的源码!希望有调用接口比较简单一点的。。。就是输入密钥和明文就可以得到密文的。。。先谢谢大家了哈
DES加密问题,DES加密是8位输出的,为什么网上下工具都不是8位输出,在线DES也不是8位输出
DES加密问题,DES加密是8位输出的,为什么网上下工具都不是8位输出,在线DES也不是8位输出
【JAVA】如何判断输入字符是否DES加密过?
在对输入字符做DES解密时,是否可以先判断下是否加密?如何判断输入字符是否有DES加密?
关于C# DES加密时密钥问题 求解答
为什么有些des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); 是这样写 而有一些是这样写 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.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8) 我想知道为什么? 加密函数 Encrypt(string Text, string sKey) //其中Text表示要加密的字符串,sKey表示密钥 还有在我把一串字符加密之后,假如这个密钥为"Key",我想知道这个密钥保存在哪儿呢?
关于CBC 3DES 加密问题,IOS 与 andorid加密不一致
找了相关资料还是没有解出 GTMBase64 用于 encode //CCCrypt函数 加密/解密 ccStatus = CCCrypt(encryptOperation,// 加密/解密 kCCAlgorithm3DES,// 加密根据哪个标准(des,3des,aes。。。。) kCCOptionPKCS7Padding,// 选项分组密码算法(des:对每块分组加一次密 3DES:对每块分组加三个不同的密) vkey, //密钥 加密和解密的密钥必须一致 kCCKeySize3DES,// DES 密钥的大小(kCCKeySizeDES=8) iv, // 可选的初始矢量 dataIn, // 数据的存储单元 dataInLength,// 数据的大小 (void *)dataOut,// 用于返回数据 dataOutAvailable, &dataOutMoved);
DES加密不一致问题,求大神解决
各位大神 小弟在做一个文件传输项目 对方系统用的是c#写的des加解密算法 密钥:Bank2014 加密偏移量:Bank2014 加密模式:CipherMode.CBC、PaddingMode.PKCS5 块长度:64 文件编码:GBK 小弟这边用的是c写的加解密算法我就只设置了密钥:Bank2014 代码是参照大赛写的 位置在:http://www.iteye.com/topic/478024 目前的问题就是对方公司加密出来的文件跟我加密出来的文件不一样 我的代码是否需要设置加密偏移量呢 还是代码本身就有问题 求大神指点 先跪谢了
关于DES加密 求帮助!
对接方des加密 是用.net 写的 我用的是php 就大侠把.net的加密程序帮我 转换成 php的 下面是 .NET 的加密程序: ``` public class DESEncryptDecrypt { private string Key; private string IV; private DESCryptoServiceProvider IDes; private byte[] GetKey; private byte[] GetIV; public DESEncryptDecrypt() { this.Key = "%&hj7x89H$yuBI0456FtmaT5&fvHUFCy76*h%(HilJ$lhj!y6&(*jkP87jH7&*^$^&*%&*%$@#@^"; this.IV = "E4ghj*Ghg7!rNIfb&95GUY86GfghUb#er57HBh(u%g6HJ($jhWk7&!hg4ui%$hjk"; this.Init(); } public DESEncryptDecrypt(string Key) { this.Key = Key; this.IV = "E4ghj*Ghg7!rNIfb&95GUY86GfghUb#er57HBh(u%g6HJ($jhWk7&!hg4ui%$hjk"; this.Init(); } public DESEncryptDecrypt(string Key,string IV) { this.Key = Key; this.IV = IV; this.Init(); } private void Init() { this.IDes = new DESCryptoServiceProvider(); this.IDes.GenerateKey(); this.GetKey = this.IDes.Key; this.IDes.GenerateIV(); this.GetIV = this.IDes.IV; } /// <summary> /// 获得密钥 /// </summary> /// <returns>密钥</returns> private byte[] GetLegalKey() { string sTemp = this.Key; byte[] bytTemp = this.GetKey; int KeyLength = bytTemp.Length; if (sTemp.Length > KeyLength) { sTemp = sTemp.Substring(0, KeyLength); } else { if (sTemp.Length < KeyLength) { sTemp = sTemp.PadRight(KeyLength, ' '); } } return ASCIIEncoding.ASCII.GetBytes(sTemp); } /// <summary> /// 获得初始向量IV /// </summary> /// <returns>初试向量IV</returns> private byte[] GetLegalIV() { string sTemp = this.Key; byte[] bytTemp = this.GetIV; int IVLength = bytTemp.Length; if (sTemp.Length > IVLength) { sTemp = sTemp.Substring(0, IVLength); } else { if (sTemp.Length < IVLength) { sTemp = sTemp.PadRight(IVLength, ' '); } } return ASCIIEncoding.ASCII.GetBytes(sTemp); } /// <summary> /// 加密算法 /// </summary> /// <param name="data"></param> /// <returns></returns> public string Encrypt(string data) { //将要加密的数据编码为字节数组 byte[] encrypt_data = System.Text.Encoding.UTF8.GetBytes(data); //如果使用Unicode编码,支持中文加密 //创建流,保存加密后的数据 MemoryStream ms = new MemoryStream(); //创建加密流 CryptoStream cs = new CryptoStream(ms, this.IDes.CreateEncryptor(this.GetLegalKey(), this.GetLegalIV()), CryptoStreamMode.Write); //调用Write方法将加密后的结果写到 流 中 cs.Write(encrypt_data, 0, encrypt_data.Length); //将数据从流写入内存(这句不能少,否则在从内存导出到字符串的时候会出现字符丢失) cs.FlushFinalBlock(); //ms.ToString(); ==>将流写入字节数组中 string result = Convert.ToBase64String(ms.ToArray()); ms.Close(); cs.Close(); return result; } /// <summary> /// 解密算法 /// </summary> /// <param name="data"></param> /// <returns></returns> public string Decrypt(string data) { byte[] decrypt_data = Convert.FromBase64String(data); MemoryStream ms = new MemoryStream(); CryptoStream cs = new CryptoStream(ms, this.IDes.CreateDecryptor(this.GetLegalKey(), this.GetLegalIV()), CryptoStreamMode.Write); cs.Write(decrypt_data, 0, decrypt_data.Length); cs.FlushFinalBlock(); string result = System.Text.Encoding.UTF8.GetString(ms.ToArray()); ms.Close(); cs.Close(); return result; } } ```
如何用给定密钥进行3DES加密
# 最近在研究3DES加密的问题,在网上找了一下基本都是http://www.cnblogs.com/mailingfeng/archive/2011/07/29/2120507.html这样的一段代码,我想问的是如果规定了一个字符串要用给定的密钥如:abcdabcd去加密,要怎么做?能不能贴一点代码参考一下?
话说3DES加密,如何修改成24位密钥,C语言版本
假设密钥:1234567812345678ABCDEFGH -- 24 如果进行3DES加密. 我网上找到的版本全是64位的
php 3des加密.net无法解析
因项目需要,需要与对方的接口对接 ,对方是.net开发的,需要与我们的php对接,但是php 3des加密后,.net的无法解析,且加密后的字符串与.net加密后的字符串,前半部分一样,后半部分就不一样!,也就是说加密后的字符串不相等,有高手吗,高分求解? .net程序: public static string Encrypt3DES(string a_strString, string a_strKey) { TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider(); DES.Key = ASCIIEncoding.ASCII.GetBytes(a_strKey); DES.Mode = CipherMode.ECB; ICryptoTransform DESEncrypt = DES.CreateEncryptor(); byte[] Buffer = ASCIIEncoding.ASCII.GetBytes(a_strString); return Convert.ToBase64String(DESEncrypt.TransformFinalBlock(Buffer, 0, Buffer.Length)); } 我写的php加密程度: function encrypt($string) { $key = "05217c03d7b74fe581fc449b"; $cipher_alg = MCRYPT_TRIPLEDES; $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher_alg,MCRYPT_MODE_ECB), MCRYPT_RAND); $encrypted_string = mcrypt_encrypt($cipher_alg, $key, $string, MCRYPT_MODE_ECB, $iv); return base64_encode($encrypted_string);//转化成16进制 }
求采用DES对称加密算法-JAVA代码
【加密方法】: 采用DES对称加密算法,使用字符串“hnzt”生成加密的密钥 则组合的字符串为:851-2110599902&ZIQI&SONG&HKG&CN&1503560275539&24 加密后为: af5a8b0e4680161606b7a72de89295733e05f8e4aec1866056f2850df1e2578bc6bd35f2003534e15a271a5bb03876d047cc1c5c0c2e1913 加密的JAVA代码如下,为什么会报错 package com.test; import java.math.BigInteger; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import org.junit.Test; /** * 对称加密DES算法 * @author Administrator * */ public class DESTest { /** 算法名称 **/ static final String ALGORITHM = "DES"; /** 算法名称/加密模式/填充方式 **/ static final String CIPHER_ALGORITHM = "DES/ECB/pkcs5Padding"; /** 密钥,getBytes的长度必须大于等于8 **/ // static final String SECRET_KEY = "!@#$%^&*"; static final String SECRET_KEY = "hnzt"; @Test public void test() throws Exception { String data = "851-2110599902&ZIQI&SONG&HKG&CN&1503560275539&24"; //加密 String hex = encryption(data); System.out.println(hex); System.out.println("-----------------------------------------"); // 解密 String origin = decryption(hex); System.out.println(origin); } /** * 加密,返回16进制的字符串 * @param data * @return * @throws Exception */ private static String encryption(String data) throws Exception{ // 创建密钥 DESKeySpec desKeySpec = new DESKeySpec(SECRET_KEY.getBytes("UTF-8")); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM); SecretKey secretKey = keyFactory.generateSecret(desKeySpec); // 加密 Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.ENCRYPT_MODE, secretKey); byte[] bs = cipher.doFinal(data.getBytes("UTF-8")); // 编码成16进制字符串 BigInteger bi = new BigInteger(1, bs); return bi.toString(16); } /** * 解密 * @param hex * @return * @throws Exception */ private static String decryption(String hex) throws Exception { // 解码16进制字符串 BigInteger bi = new BigInteger(hex, 16); byte[] bs = bi.toByteArray();// 该数组包含此 BigInteger 的二进制补码表示形式。 byte[] originBs = new byte[bs.length - 1]; byte[] target = bs; if (bs[0] == 0) { System.out.println("去补码..."); System.arraycopy(bs, 1, originBs, 0, originBs.length); // 去掉补码 target = originBs; } // 创建密钥 DESKeySpec desKeySpec = new DESKeySpec(SECRET_KEY.getBytes("UTF-8")); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM); SecretKey secretKey = keyFactory.generateSecret(desKeySpec); // 解密 Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, secretKey); byte[] decryptionBs = cipher.doFinal(target); return new String(decryptionBs, "UTF-8"); } } ![图片说明](https://img-ask.csdn.net/upload/201801/22/1516614091_339172.png) 而网上却可以,我代码写错了吗? ![图片说明](https://img-ask.csdn.net/upload/201801/22/1516613991_141077.png)
各位大神,请问:我手上有一套DES的加解密代码,请问如何把他扩展成3DES的代码呢?
代码形式如下: jiami(before,key,after) jiemi(before,key,after) 要怎么组合成3DES的加解密呢??? 我知道3DES的流程是:加密 解密 加密,但是具体一点是这样的吗: 1 先用key1加密明文,生成密文1 2 再用key2解密密文1,生成一个解密后的文件 3 最后用key3加密步骤2解密后的文件 是这样的步骤吗? 谢谢!!
24个字节的字符串进行3DES加密后得到的串的长度是多少?
求解答。。JAVA中24个字节的字符串进行3DES加密后得到的串的长度是多少?
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
Android用des加密,为啥UrlEncoder用utf-8编码之后=变%3D了呢?
![![图片说明](https://img-ask.csdn.net/upload/201507/28/1438089280_522457.png)图片说明](https://img-ask.csdn.net/upload/201507/28/1438089327_507911.png) Android用des加密,为啥UrlEncoder用utf-8编码之后=变%3D了呢?
mfc开发中 读取经过des加密的文件时,只能读取一部分加密文件
在mfc中,读取一个经过des加密的文件时只能读取到其中的一部分文件,其他的都读取不到
数据库银行卡号3des加密,但是秘钥需要定期更换,如何根据银行卡号查询到不同秘钥加密的数据
数据库银行卡号3des加密,但是秘钥需要定期更换,秘钥更换后,新入库的银行卡数据格式肯定变了,如何根据银行卡号查询到不同秘钥加密的数据,之前的查询还是分页查询
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
JDK12 Collectors.teeing 你真的需要了解一下
前言在 Java 12 里面有个非常好用但在官方 JEP 没有公布的功能,因为它只是 Collector 中的一个小改动,它的作用是 merge 两个 collector 的结果,这句话
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
【图解经典算法题】如何用一行代码解决约瑟夫环问题
约瑟夫环问题算是很经典的题了,估计大家都听说过,然后我就在一次笔试中遇到了,下面我就用 3 种方法来详细讲解一下这道题,最后一种方法学了之后保证让你可以让你装逼。 问题描述:编号为 1-N 的 N 个士兵围坐在一起形成一个圆圈,从编号为 1 的士兵开始依次报数(1,2,3…这样依次报),数到 m 的 士兵会被杀死出列,之后的士兵再从 1 开始报数。直到最后剩下一士兵,求这个士兵的编号。 1、方
致 Python 初学者
文章目录1. 前言2. 明确学习目标,不急于求成,不好高骛远3. 在开始学习 Python 之前,你需要做一些准备2.1 Python 的各种发行版2.2 安装 Python2.3 选择一款趁手的开发工具3. 习惯使用IDLE,这是学习python最好的方式4. 严格遵从编码规范5. 代码的运行、调试5. 模块管理5.1 同时安装了py2/py35.2 使用Anaconda,或者通过IDE来安装模
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
GitHub标星近1万:只需5秒音源,这个网络就能实时“克隆”你的声音
作者 | Google团队译者 | 凯隐编辑 | Jane出品 | AI科技大本营(ID:rgznai100)本文中,Google 团队提出了一种文本语音合成(text to speech)神经系统,能通过少量样本学习到多个不同说话者(speaker)的语音特征,并合成他们的讲话音频。此外,对于训练时网络没有接触过的说话者,也能在不重新训练的情况下,仅通过未知说话者数秒的音频来合成其讲话音频,即网
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
【管理系统课程设计】美少女手把手教你后台管理
【后台管理系统】URL设计与建模分析+项目源码+运行界面 栏目管理、文章列表、用户管理、角色管理、权限管理模块(文章最后附有源码) 一、这是一个什么系统? 1.1 学习后台管理系统的原因 随着时代的变迁,现如今各大云服务平台横空出世,市面上有许多如学生信息系统、图书阅读系统、停车场管理系统等的管理系统,而本人家里就有人在用烟草销售系统,直接在网上完成挑选、购买与提交收货点,方便又快捷。 试想,
4G EPS 第四代移动通信系统
目录 文章目录目录4G EPSEPS 的架构EPS 的参考模型E-UTRANUEeNodeBEPCMME(移动性控制处理单元)S-GW(E-RAB 无线访问承载接入点)P-GW(PDN 接入点)HSS(用户认证中心)PCRF(计费规则与策略)SPR(用户档案)OCS(在线计费)OFCS(离线计费)接口类型Uu 接口(空中接口,UE 和 AN 之间)S1 接口(AN 和 CN 之间)S1-U 接口和
相关热词 c# 二进制截断字符串 c#实现窗体设计器 c#检测是否为微信 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片
立即提问