RSA 密钥2048位 如何解决密文长度不同 5C

下面是加密的代码,对于输入的字符,每个字符单独进行加密,但是加密之后的位数不一样,是因为没有填充的关系吗,那要如何解决呢

 void RSA::Encrypt(const char *filename, const char *output, const char *pub_key_file)
{
    char in[1024];
    CStringA strN, strE;
    FILE *old_file,*new_file,*pub;     //源文件、目标文件、公钥文件

    __int64 pub_key,len,i,total;      
    unsigned char cleartext[10005];  

    pub=fopen(pub_key_file,"rb");         //公钥文件加载公钥
    if(pub==NULL)
        return;
    fscanf(pub, "%s\n", in);
    strE = in;                           //读入e
    strcpy(in, "");
    fscanf(pub, "%s\n,", in);
    strN = in;                           //读入n

    old_file=fopen(filename,"rb");
    if(old_file==NULL)
        return;
    total=0;

    len=fread(cleartext,1,10000,old_file);    
    total = len;

    fclose(old_file);

    old_file=fopen(filename,"rb");
    if(old_file==NULL)
        return;
    new_file=fopen(output,"wb");
    if(new_file==NULL)
        return;
    fwrite(&total,sizeof(__int64),1,new_file);
    CBigInt m, e, n, c;                        //构造大数对象并初始化为零
    CStringA strC;
    e.Get(strE, 10);
    n.Get(strN, 10);

    memset(cleartext,0x0000,sizeof(cleartext));//清零
    len=fread(cleartext,1,10000,old_file);
    for (i = 0; i < len; i++)
    {
        m.Mov(cleartext[i]);
        c.Mov(m.RsaTrans(e, n));      //c=m^e mod n
        c.Put(strC, 10);
        char out[1024] = "";
        strncpy(out, strC, strC.GetLength());
        out[strC.GetLength()] = '\0';
        fprintf(new_file, "%s\n", out);
    }

    fclose(old_file);
    fclose(new_file);
}

1个回答

明文长度小于等于密钥长度(Bytes)-11,这说法本身不太准确,会给人感觉RSA 1024只能加密117字节长度明文。实际上,RSA算法本身要求加密内容也就是明文长度m必须0n,运算就会出错?!那怎么办?且听下文分解。
所以,RSA实际可加密的明文长度最大也是1024bits,但问题就来了:
如果小于这个长度怎么办?就需要进行padding,因为如果没有padding,用户无法确分解密后内容的真实长度,字符串之类的内容问题还不大,以0作为结束符,但对二进制数据就很难理解,因为不确定后面的0是内容还是内容结束符。
只要用到padding,那么就要占用实际的明文长度,于是才有117字节的说法。我们一般使用的padding标准有NoPPadding、OAEPPadding、PKCS1Padding等,其中PKCS#1建议的padding就占用了11个字节。
如果大于这个长度怎么办?很多算法的padding往往是在后边的,但PKCS的padding则是在前面的,此为有意设计,有意的把第一个字节置0以确保m的值小于n。
这样,128字节(1024bits)-减去11字节正好是117字节,但对于RSA加密来讲,padding也是参与加密的,所以,依然按照1024bits去理解,但实际的明文只有117字节了。
关于PKCS#1 padding规范可参考:RFC2313 chapter 8.1,我们在把明文送给RSA加密器前,要确认这个值是不是大于n,也就是如果接近n位长,那么需要先padding再分段加密。除非我们是“定长定量自己可控可理解”的加密不需要padding。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
RSA密钥生成的源码(密钥长度可控)

哪位大神可以提供RSA密钥生成的源码(密钥长度可控)C或者C++

用RSA加密方式加密后的密文太长

最近在搞License,用RSA对其加密后感觉加密后的字符串太长 如果想让其长度固定8位 或16位 怎么做?请各位前辈指导指导,谢谢啦

加密后密文长度有时等于公钥长度128,有时候不等于,什么原因啊,加密代码如下:

char my_encrypt(char *str, char *pubkey_path) { // 打开公钥文件 FILE pub_fp=fopen(PUBKEY,"r"); if(pub_fp==NULL){ printf("failed to open PUBKEY file %s!\n", PUBKEY); return ; } // 从文件中读取公钥 RSA* rsa1=PEM_read_RSA_PUBKEY(pub_fp, NULL, NULL, NULL); if(rsa1==NULL) { printf("unable to read public key!\n"); return ; } fclose(pub_fp); printf("strlen(str): %d\n",strlen(str)); printf("RSA_size(rsa1): %d\n",RSA_size(rsa1)); char *encrypted=NULL; encrypted = (char *)malloc(1024); memset(encrypted, 0, 1024); // 用公钥加密 int len=RSA_public_encrypt(strlen(str), str, encrypted, rsa1, RSA_PKCS1_PADDING); if(len==-1 ) { printf("failed to encrypt\n"); return ; } return encrypted; }

RSA算法如何生成一个长度较短的秘钥

正在使用RSA算法生成秘钥,但是生成的秘钥是在太长,有知道如何生成短一些的秘钥的吗

JAVA里的rsa公钥加密128位的明文加出来的结果一定是512位的密文吗?可以加出来256位的密文么?

1.明文:[1111111111111111 ] 补空格至128位,rsa公钥加密后: 公钥为:-----BEGIN PUBLIC KEY----- MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDZWHcxw/xXAB/8bquCnLrQ6QYafG9bcZZ4mq+A6GBn3QtW5Sia3JPERW0qD62/4PuNOXqKTj3cw4RnYYr29gZXv/F8DfmY1UpfQkJxLC9az4f9eEiuEm5axMzpl5V4BNpnVgnmDTRAv45ZKj+V6k9TZ8rVVSQqTEGLTQkpU38QIDAQAB -----END PUBLIC KEY----- 密文为:B4671AABC963BAEFED0B43E0704090F018EE19CB09172E74DAC27130A44AFF6060C118B79369E682C05B88404882B39374A0BB2ECEB8DAAA53C3F3F51B51D796540316BC2D89DD320DADBFD74B62A27C30BC162B936DFE16894E0F825CD6337D1E3F550685C901422355AB94EB5152DB305617155BF463D8CE98162D2A456351 试了各种方法,只有填充方式为RSA/ECB/nopadding时,每次加密的结果才保持一致,其他情况,每次加密的结果都不同; 由于rsa加密在明文大小超过117时会分段加密,所以我现在128加出来的密文是512位的, 请问各位大佬,怎么才能加出来上述miwen

rsa加密的出来的密文乱码 如何,怎么解决

需求是将随机数加密 ,获得密文以后 在后台输入 。通过密文跟私钥进行解密, 然而这个密文乱码了,怎么破?如图 ![图片说明](https://img-ask.csdn.net/upload/201805/26/1527334052_208683.jpg) 在线等立马。给分

java加密,密文长度可以小于等于明文长度吗?

目前遇到一个问题,需要把数据库中所有涉及到身份证号的表的字段从明文变成密文,但是表设计的时候身份证号码字段长度只有18位,有没有办法可以在不改变表接口(需要改动的表太多了)然后储存密文,并且密文是可以反解的

RSA加密,解密,密钥位数2048,X509编码

-----BEGIN PUBLIC KEY----- MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwZTyBfhXgoNBG0D8U+UR tbSPldrPy/WhxS9oBgjm6CvSynalPPFWuhSqwQA7tUmfBCwAehSoJ3e8P8HTlQd4 D7XPSkopd3Zl4SqYIKq4RzgwInhIujN72ttkdSYBqfPvKU8ckgZrcWz8NXC6e4FT VH2fdIBMfaBmTuHUf45zsQoAaBXtnraKbBjwmKKfhi1/FuvLzTmb15URd6RkPH8r 3qclf3uemn2CYbzME2RoS/yY5CHnRwoCFMb58HH/Mpt4PcygdMUwxKWIlzTv5s9E FPfMvjwspM0KkGyDer+J3dh5Hp8lLbbpn5JEUJH9u1me1LpEScPvkko9bo3O5e6/ VQIDAQAB -----END PUBLIC KEY----- -----BEGIN PRIVATE KEY----- MIIEuwIBADANBgkqhkiG9w0BAQEFAASCBKUwggShAgEAAoIBAQDBlPIF+FeCg0Eb QPxT5RG1tI+V2s/L9aHFL2gGCOboK9LKdqU88Va6FKrBADu1SZ8ELAB6FKgnd7w/ wdOVB3gPtc9KSil3dmXhKpggqrhHODAieEi6M3va22R1JgGp8+8pTxySBmtxbPw1 cLp7gVNUfZ90gEx9oGZO4dR/jnOxCgBoFe2etopsGPCYop+GLX8W68vNOZvXlRF3 pGQ8fyvepyV/e56afYJhvMwTZGhL/JjkIedHCgIUxvnwcf8ym3g9zKB0xTDEpYiX NO/mz0QU98y+PCykzQqQbIN6v4nd2HkenyUttumfkkRQkf27WZ7UukRJw++SSj1u jc7l7r9VAgMBAAECggEAQxJLRPxFvceiYEIE60B8AVwdP8u/oahqs3p4bVbaQmkk sNeo6tOnu/N7MkHVbjui5/wi8imEFaCrzd9nYsRiufbBarkFYwnXxMtQSEk+bhau vtK0SCecazkGtnxDqVIGdGafvIyS34rmW9HCGxa0+5pHDEODvSc9K2mdidCejyEQ vGEBt0oi0T2b0YS733qORF3uqGg4kJS3OVF0H72BgfWqbOXuAN3MDVTsWErkvjjJ 86SscZsH3EbLdS/uuSTpyLNB2cDjZQM9HXGZohVTRe5CbQh7FinSHmZoONIxehQ3 g6R2q+i5gt6Qs9/mzpNHGSzExaCn9PH20A6ZXiO5pQKBgQDgZrKdESd3cHMgAO4/ rEOkZiL7CSChX6hCJBCic4radRLWVWFpZeurQLK65mxE+mBwbxw0XWcmvvBB0HSF UGkeYJFIxO9iiYaFTaR6NVdQZOMWhDpRviZ5XYlAp7PJDPcyplzPVSqEb4iNTn4P 64BFI/zlGTijiXdZu+UofM83lwKBgQDc10J7yR8Tk4bpdjQA69h+vX/TtGfLrvB0 HnUb7h4qHfk68ZfBwAJsiuzwRolB2P5/6pej+456s7AY6bZiBt0wB9A+elqfouoL vxl711atmvssDGedBY3LfpNpQU0vOD51vlPfzWTXVK2CWnLH+2k45nwStpZ8TZ50 36kBirI98wKBgQCsuqBWAnRMncQgKFc7r8/JZc0bSqVRUh5j+vrK8QE6ss8zKDl5 Nbi3828gKmnAlrFRGlWtgQ/7ZRHutxRZ4dFoTpDGYMCbKpzfUyp93z08Zsvd8x4o +aMH3JXfrLbY1SAaXrAl77pwgqGrk3W5r17m2ZK6jjVovFGgQt9b0OZ4NQKBgEuW 4oq8LIbm2CbQ7rvh/hhjhH1SIrT1DBiy1CLbPjfsSoKCbw9CSZIdezxC6HhBbdsa 0Qyv7fTRzFS6qlKjRtJJ2l2IQ7ygZrvejTp2WpTRl2dcV5rHa+FbUdmVIHYpKjfj DZJtGzcZJMqZavBIfZucSJufI6MobjRS2eZNMvVBAn9aN8f3nAZHCegxbXpWZ5r6 ajwEDXeVlApRZZQGbxTEvxEo/6KaMDe+t7tnxewVlf/P5metsHeII/iA6m8dZg3d BpsARGz5Xcv79k2CAO6NJDrywoAo4AQ2hPgEneDd6zyYPbtaP/7xjZuoFoOequqZ U51GPPuY2UdFG6Bjjxoe -----END PRIVATE KEY----- **密钥的位数: 2048** 现在是密钥长度太长了然后加密的时候直接异常, 我现在用的是BigInteger 怎么弄都不行,求代码,

如何从文件读取RSA密钥

<div class="post-text" itemprop="text"> <p>I need to read in an RSA private key from a file to sign a JWT. I have found some examples on how to save a generated RSA key to disk but nothing showing how to build a key struct based on a pre-generated key from a file.</p> <p>The key is generated like this:</p> <pre> openssl genrsa 2048 | openssl pkcs8 -topk8 -nocrypt </pre> <p>Example key:</p> <pre> -----BEGIN PRIVATE KEY----- MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQClHYNDPVSF‌​FmWF oKGTqd/n7Dt2+tGXh97KJjVLAqCBZZHlQJ534v2OzFjTgzuMNehD9Y6HnkYF‌​dkRb QzYi2YDROOzRl1bhyyWPA35OGf50r7LiNvSvNPNtswsCuK7ywOcH0yEMKSiW‌​4q5R GKYi42w961EcTQQPrfihavY+c2FYPv4+pXymzaIz9hGBPLHwaHq/QTAyHxPC‌​fkOo s/x3mxUVd7Ni2bz1VJGlyqcNEeU88wTAYMmv8oQ3y2NfKExtYn+W6TCDiq/+‌​ZkOp wacuAU0J7tCNgcXvkq39KH5uza2uSiTniye6uhlkvYWD3s9riIIiekTEiHk/‌​kkc6 jMg8HN/7AgMBAAECggEBAJ12u8vQHV6esUrymaTdCG+BVmRtZpyA ... -----END RSA PRIVATE KEY----- </pre> </div>

关于RSA 密钥文件结构的问题

最近在做一个小项目,其中的数字签名部分采用RSA算法,但有一个要求是要使用指定的密钥对,从网上找了些代码,都是自己用KeyPairGenerator生成密钥对,然手再使用,代码如下: KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA"); keyPairGen.initialize(512); KeyPair keyPair = keyPairGen.generateKeyPair(); RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate(); RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic(); 请问各位大侠,如何使用指定的密钥对来生成RSAPrivateKey 和 RSAPublicKey呢?,或者不采用以上该类,有其他的解决办法没?

RSA密钥导出和导入

<div class="post-text" itemprop="text"> <p>I'm currently trying to export my created keys and than importing them to use them.</p> <p>But if I run my code I get the following error:</p> <pre><code>panic: x509: only RSA and ECDSA public keys supported goroutine 1 [running]: main.main() /path/to/project/src/main.go:19 +0x3bd </code></pre> <p>This is my current code:</p> <pre><code>// Create key key, _ := rsa.GenerateKey(rand.Reader, 2048) // Message to encrypt message := "hi stackoverflow" priv := x509.MarshalPKCS1PrivateKey(key) pub, err := x509.MarshalPKIXPublicKey(key.PublicKey) if err != nil { panic(err) } private, err := x509.ParsePKCS1PrivateKey(priv) if err != nil { panic(err) return } public, err := x509.ParsePKIXPublicKey(pub) if err != nil { return } encrypted, err := rsa.EncryptPKCS1v15(rand.Reader, public.(*rsa.PublicKey), []byte(message)) if err != nil { panic(err) } dencrypted, err := rsa.DecryptPKCS1v15(rand.Reader, private, encrypted) if err != nil { panic(err) } fmt.Println(string(dencrypted)) </code></pre> <p>(I researched like the hole internet but didn't found something, maybe I used a wrong search term.)</p> </div>

使用正则表达式检测私有和公共RSA密钥

<div class="post-text" itemprop="text"> <p>I've searched over the internet but with no results, There is any pattern (to be implemented in regex) to detect RSA private or public keys ?</p> <p>(not included strings such as ---- Public RSA key-- or "ssh rsa")</p> <p>I'm stuck after create base64 regex </p> <pre><code>var re = regexp.MustCompile(`(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3})=`) </code></pre> <p>Thanks</p> </div>

1024位rsa算法c++实现

我们会再使用RSA(1024位)算法加密, 要求使用C/C++,封装为DLL文件。加密时,输入string,输入string PASS(1024位),输出byte[];解密时,输入byte[],输入PASS该DLL模块调用格式为: RSA_Encode(string 原文,byte密文,string 密钥) RSA_Decode(byte 密文,string 原文,string 密钥)

RSA加密时有填充,如何在已知明文范围,填充方法和密文时,找到明文?

问题的具体描述如下: RSA加密 (c = (PIN)^e mod N)。假设PIN是一个小于2^16正整数,在直接加密前,先把PIN转化为二进制,然后在最右边加上2048个1。比如,十六进制整数abcd变成二进制整数x=1010101111001101 1...1(2048个1),然后再将x代入求出密文。已知N,e,c和填充方法,就是说全部都知道,就是不知道密钥d和明文m,现在需要寻找一种有效的攻击方法来找出明文。本人对这方面是刚入门的级别,想了两天只想出穷举法作为最有效的攻击因为PIN是一个小于2^16正整数。但是题目的要求是要具体算出明文的数值,在给定了N,e和c具体数值的前提下。若有大神能给我解答,必将感激不尽!找不到RSA的标签。。只好随便选了一个

如何在Golang中使用rsa密钥对进行AES加密和解密

<div class="post-text" itemprop="text"> <p>I want to generate rsa key pair(public and private), and then use them for AES encryption and decryption.e.g. Public key for Encryption and private key for Decryption.I wrote a simple code for this, but the problem is that when i run this code i get this error:</p> <pre><code>crypto/aes: invalid key size 1639 </code></pre> <p>How can i resove this problem ?? My Encryption code is given bellow:</p> <pre><code>//genrarting private key privateKey, err := rsa.GenerateKey(rand.Reader, 2014) if err != nil { return } privateKeyDer := x509.MarshalPKCS1PrivateKey(privateKey) privateKeyBlock := pem.Block{ Type: "RSA PRIVATE KEY", Headers: nil, Bytes: privateKeyDer, } privateKeyPem := string(pem.EncodeToMemory(&amp;privateKeyBlock)) //using privateKeyPem for encryption text := []byte("My name is Astaxie") ciphertext, err := encrypt(text, []byte(privateKeyPem)) if err != nil { // TODO: Properly handle error log.Fatal(err) } fmt.Printf("%s =&gt; %x ", text, ciphertext) //Definition of encrypt() func encrypt(plaintext []byte, key []byte) ([]byte, error) { c, err := aes.NewCipher(key) if err != nil { return nil, err } gcm, err := cipher.NewGCM(c) if err != nil { return nil, err } nonce := make([]byte, gcm.NonceSize()) if _, err = io.ReadFull(rand.Reader, nonce); err != nil { return nil, err } return gcm.Seal(nonce, nonce, plaintext, nil), nil } </code></pre> </div>

银联支付接口使用rsa 数据加密。明文,密钥,都是16进制的字符串

银联支付接口使用rsa 数据加密。明文,密钥,都是16进制的字符串,加密结果和对方给的小工具加密的结果不一样 小工具rsatools.exe 求大神指导 代码如下 import java.io.ByteArrayOutputStream; import java.math.BigInteger; import java.security.Key; import java.security.KeyFactory; import java.security.interfaces.RSAPublicKey; import java.security.spec.RSAPublicKeySpec; import javax.crypto.Cipher; import org.apache.commons.codec.binary.Hex; import org.bouncycastle.jce.provider.BouncyCastleProvider; public class test { /** * 加密 * * @param key * 加密的密钥 * @param data * 待加密的明文数据 * @return 加密后的数据 * @throws Exception */ public byte[] encrypt(Key key, byte[] data) throws Exception { try { Cipher cipher = Cipher.getInstance("RSA", new BouncyCastleProvider()); cipher.init(Cipher.ENCRYPT_MODE, key); // 获得加密块大小,如:加密前数据为128个byte,而key_size=1024 加密块大小为127 // byte,加密后为128个byte; // 因此共有2个加密块,第一个127 byte第二个为1个byte int blockSize = cipher.getBlockSize(); int outputSize = cipher.getOutputSize(data.length);// 获得加密块加密后块大小 int leavedSize = data.length % blockSize; int blocksSize = leavedSize != 0 ? data.length / blockSize + 1 : data.length / blockSize; byte[] raw = new byte[outputSize * blocksSize]; int i = 0; while (data.length - i * blockSize > 0) { if (data.length - i * blockSize > blockSize) cipher.doFinal(data, i * blockSize, blockSize, raw, i * outputSize); else cipher.doFinal(data, i * blockSize, data.length - i * blockSize, raw, i * outputSize); // 这里面doUpdate方法不可用,查看源代码后发现每次doUpdate后并没有什么实际动作除了把byte[]放到ByteArrayOutputStream中 // ,而最后doFinal的时候才将所有的byte[]进行加密,可是到了此时加密块大小很可能已经超出了OutputSize所以只好用dofinal方法。 i++; } return raw; } catch (Exception e) { throw new Exception(e.getMessage()); } } /** * 解密 * * @param key * 解密的密钥 * @param raw * 已经加密的数据 * @return 解密后的明文 * @throws Exception */ public byte[] decrypt(Key key, byte[] raw) throws Exception { try { Cipher cipher = Cipher.getInstance("RSA", new org.bouncycastle.jce.provider.BouncyCastleProvider()); cipher.init(cipher.DECRYPT_MODE, key); int blockSize = cipher.getBlockSize(); ByteArrayOutputStream bout = new ByteArrayOutputStream(64); int j = 0; while (raw.length - j * blockSize > 0) { bout.write(cipher.doFinal(raw, j * blockSize, blockSize)); j++; } return bout.toByteArray(); } catch (Exception e) { throw new Exception(e.getMessage()); } } /** * 测试 * * @param args * @throws Exception */ public static void main(String[] args) throws Exception { RSAUtil rsa = new RSAUtil(); String modeHex = "BB83CB428FF41B61762FB8A34041EF8B897301DC4DB84CBD60FEBFC244260B7CC3D57925591970028BB466E13C5A51650213DB7566A78453EA55D725A9B78884A99FD8B1530499D08F3D8CF078CDA4346395CCCA8379E814559E3F6A7DB851C9FCA1FC5A0D3983C637E33B02DA65DF139428C19D9EE2AD8F9A15663E984B166B"; String messageg = "06111111FFFFFFFFA1D93F0C1C682F1836B7E97CC0A8D37363237EA630383632323235383030303030303030303030303120202020202020202036323232353830303030303030303030303032202020202020202020303531323234363536343836352020343231303333202020202020202020202020202020202020202020"; String exponentHex = "010001"; KeyFactory factory = KeyFactory.getInstance("RSA", new BouncyCastleProvider()); BigInteger n = new BigInteger(modeHex, 16); BigInteger e = new BigInteger(exponentHex, 16); RSAPublicKeySpec spec = new RSAPublicKeySpec(n, e); RSAPublicKey pub = (RSAPublicKey) factory.generatePublic(spec); byte[] mi = rsa.encrypt(pub, messageg.getBytes("GB2312")); String result1 = new String(Hex.encodeHex(mi)); System.out.println("加密后==" + result1); } }

iOS在RSA加密解密和签名的时候已经生成密钥、摘要和密文。向服务器请求为何后台没有反应

![图片说明](https://img-ask.csdn.net/upload/201512/24/1450949322_580072.jpg)是RSA加密签名这里的问题吗

已知RSA密码中,公钥n=33685247,b=8829979,密文c=2,则明文m=?

已知RSA密码中,公钥n=33685247,b=8829979,密文c=2,则明文m=?

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

相关热词 aero c# c#压缩图片 c# udp服务器 100线程 c# c# fidller请求 c# 参数 调用exe c# 打字母小游戏 c#显示未能加载文件 c# 右击菜单加快捷键 c#将重复的数据保留一条
立即提问