一、python

1、 des3

python平台的DES3 + base64 加密解密, 有两个常用的库pycrypto和pyDes

1)pycrypto

des3.py

#coding=utf-8
from Crypto.Cipher import _DES3
import base64
import json
BS = _DES3.block_size def pad(s):
return s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
#定义 padding 即 填充 为PKCS7 def unpad(s):
return s[0:-ord(s[-1])] class prpcrypt(): def __init__(self, key):
self.key = key
self.mode = _DES3.MODE_CBC #模式为CBC
self.iv = IV #self.iv 为 IV 即偏移量,ECB模式不使用IV # DES3的加密模式为CBC
def encrypt(self, text):
text = pad(text)
cryptor = _DES3.new(self.key, self.mode, self.iv) x = len(text) % 8
if x != 0:
text = text + '\0' * (8 - x) # 不满16,32,64位补0
# print(text)
self.ciphertext = cryptor.encrypt(text)
return base64.standard_b64encode(self.ciphertext).decode("utf-8") # DES3的解密模式为CBC
def decrypt(self, text):
cryptor = _DES3.new(self.key, self.mode, self.iv)
de_text = base64.standard_b64decode(text)
plain_text = cryptor.decrypt(de_text)
# st = str(plain_text.decode("utf-8")).rstrip('\0')
# out = unpad(st)
# return out
#上面注释内容解密如果运行报错,就注释掉试试
return plain_text if __name__ == '__main__':
#ECB模式不使用IV
IV=b'00000000'
des3 = prpcrypt('123456789012345678901234') # 自己设定的密钥
tick = {
"protocolHead": "gis_fl",
"protocolType": 1000000
}
js = json.dumps(tick) #字典转str,再加密
#js = str(tick)
print type(js)
e = des3.encrypt(js) # 加密内容
d = des3.decrypt(e) #解密内容
print e #加密后
print d #解密后

参考https://www.cnblogs.com/qq405921147/p/9176691.html

2)pyDes

参考

pyDes库

https://www.cnblogs.com/txw1958/archive/2012/07/20/python-des-3des.html
https://blog.csdn.net/sbdxxcjh/article/details/38460409

des3 + base64

https://www.jb51.net/article/112549.htm

aes+base64+pcks5

pip install crypto

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time    : 2017/5/17 17:23

# @Author  : tangjiale

# @Site    :

# @File    : AESUtil.py

from Crypto.Cipher import AES

import base64

class AESUtil:

    @staticmethod

    def _pad(s):

        return s + (AES.block_size - len(s) % AES.block_size) * chr(AES.block_size - len(s) % AES.block_size)

    #初始化AES配置参数

    @staticmethod

    def _cipher(key):

        iv = 'w2wJCnctEG09danP'

        #AES/ECB/PKCS5Padding

        return AES.new(key=key, mode=AES.MODE_CBC, IV=iv)

    #AES加密

    def encrypt(self,key,data):

        encryptd = self._cipher(key).encrypt(self._pad(data))

        return base64.encodestring(encryptd)

    #AES解密

    def decrypt(slef,key,data):

        base64Data = base64.decodestring(data)

        decryptd = slef._cipher(key).decrypt(base64Data)

        return (decryptd)

if __name__ == '__main__':
key = 'xxxxxxxxxxxxxxxx' aesUtil =AESUtil() encStr = aesUtil.encrypt(key,'{"abc":"a123456","kis":"kisCloud2018","name":"金蝶20118蝶金"}') print('Python encrypt: ' + encStr) print('Python decrypt: ' + aesUtil.decrypt(key,'dUFWEbRsKTWPwHHrJLu/vJJhQIbcfjas6TMaMEG+seOhmsdbm0mkxxxxVl01bAgppvScbQ2paGfZYma6tBv7hXfKSA+ntwRaAYAPhxIe3aA='))

二、nodejs

1、 des3加密

在线工具 http://tool.chacuo.net/crypt3des

感谢这位哥,轻轻一百度就有现成的

http://mygo.iteye.com/blog/2018882

var assert = require('assert');
var crypto = require('crypto'); function test_des(param) {
var key = new Buffer(param.key);
var iv = new Buffer(param.iv ? param.iv : 0)
var plaintext = param.plaintext
var alg = param.alg
var autoPad = param.autoPad //encrypt
var cipher = crypto.createCipheriv(alg, key, iv);
cipher.setAutoPadding(autoPad) //default true
var ciph = cipher.update(plaintext, 'utf8', 'hex');
ciph += cipher.final('hex');
console.log(alg, ciph) //decrypt
var decipher = crypto.createDecipheriv(alg, key, iv);
decipher.setAutoPadding(autoPad)
var txt = decipher.update(ciph, 'hex', 'utf8');
txt += decipher.final('utf8');
assert.equal(txt, plaintext, 'fail');
} test_des({
alg: 'des-ecb',
autoPad: true,
key: '01234567',
plaintext: '1234567812345678',
iv: null
}) test_des({
alg: 'des-cbc',
autoPad: true,
key: '01234567',
plaintext: '1234567812345678',
iv: '12345678'
}) test_des({
alg: 'des-ede3', //3des-ecb
autoPad: true,
key: '0123456789abcd0123456789',
plaintext: '1234567812345678',
iv: null
}) test_des({
alg: 'des-ede3-cbc', //3des-cbc
autoPad: true,
key: '0123456789abcd0123456789',
plaintext: '1234567812345678',
iv: '12345678'
})

我只用到了3des-ecb,数据格式是base64, 将加密和解密两个函数的数据格式从hex改成base64就OK了。

封装一下

var crypto = require('crypto');  

var key_qbox10 = '123456789012345678901234';

function des3Encrypt(param) {
var key = new Buffer(param.key);
var iv = new Buffer(param.iv ? param.iv : 0)
var plaintext = param.plaintext
var alg = param.alg
var autoPad = param.autoPad var cipher = crypto.createCipheriv(alg, key, iv);
cipher.setAutoPadding(autoPad)
var ciph = cipher.update(plaintext, 'utf8', 'base64');
ciph += cipher.final('base64');
return ciph;
}; function des3Decrypt(param) {
var key = new Buffer(param.key);
var iv = new Buffer(param.iv ? param.iv : 0)
var plaintext = param.plaintext
var alg = param.alg
var autoPad = param.autoPad var decipher = crypto.createDecipheriv(alg, key, iv);
decipher.setAutoPadding(autoPad)
var txt = decipher.update(plaintext, 'base64', 'utf8');
txt += decipher.final('utf8');
return txt;
}; exports.decode=function(data){
var para = {
alg:'des-ede3',
autoPad:true,
plaintext:data,
iv:null,
key:key_qbox10
};
var decode_str = des3Decrypt(para);
return decode_str;
} exports.encode =function(data){
var para = {
alg:'des-ede3',
autoPad:true,
plaintext:data,
iv:null,
key:key_qbox10
};
var encode_str = des3Encrypt(para);
return encode_str;
}

demo:

decode

function recv_routine(data){

    var obj = JSON.parse(des3.decode(data));
//console.log("<<<<<<<<<<<<<<<<<<<<"+JSON.stringify(obj));
//response tick
if( obj.protocolType === 1000000 ){
console.log("<<<<<<<<<<<<<<<<<<<<"+JSON.stringify(obj));
}
}

encode

client.connection.sendUTF(des3.encode(JSON.stringify(proto.tick)));

三、可以直接用openssl指令来加密解密

https://blog.csdn.net/jasonhwang/article/details/2336049

des/3des的更多相关文章

  1. DES & 3DES 加密算法

    JAVA坑 跟其他公司java的对接口,一个细节对到吐血,具体: DesUtil.java(别人的反例) //package base_class; import java.io.IOExceptio ...

  2. 使用openssl库实现des,3des加密

    原文地址: 使用openssl库实现des,3des加密 主要是调整了一下格式,以及一些变量的类型,以解决在VC2008下无法编译通过的问题. #include <stdio.h> #in ...

  3. java和c++中的DES\3DES\Base64

    首先来看一段java中对字符串加解密的代码: //密钥 private String key = "123456789012345678901234"; //解密过程,先用Base ...

  4. Java Base64、HMAC、SHA1、MD5、AES DES 3DES加密算法

    ●  BASE64 严格地说,属于编码格式,而非加密算法    ●  MD5(Message Digest algorithm 5,信息摘要算法)    ●  SHA(Secure Hash Algo ...

  5. Java利用DES/3DES/AES这三种算法分别实现对称加密

    转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ...

  6. DES/3DES/AES 三种对称加密算法实现

    1. 简单介绍 3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES ...

  7. 加密算法 DES 3DES RSA AES 简介

    数据加密的基本过程就是对原来为明文的文件或数据按某种算法进行处理,使其成为不可读的一段代码,通常称为[密文],使其只能在输入相应的[密钥]之后才能显示出本来内容,通过这样的途径来达到保护数据不被非法人 ...

  8. C# 加密解密(DES,3DES,MD5,Base64) 类

    public sealed class EncryptUtils     {         #region Base64加密解密         /// <summary>        ...

  9. java-信息安全(二)-对称加密算法DES,3DES,AES,Blowfish,RC2,RC4

    概述 信息安全基本概念: DES(Data Encryption Standard,数据加密标准) 3DES(Triple DES,三重数据加密算法(TDEA,Triple Data Encrypti ...

  10. DES/3DES/AES区别

    公元前400年,古希腊人发明了置换密码.1881年世界上的第一个电话保密专利出现.在第二次世界大战期间,德国军方启用“恩尼格玛”密码机,密码学在战争中起着非常重要的作用. DES 1977年1月,美国 ...

随机推荐

  1. 微信小程序7 - 页面命名规范

    /pages/{module}/{page}/index.js   这个是目录结构 所有单个页面(Page)目录内, 都叫做index,如 index.js  index.wxss  ,不需要起其他名 ...

  2. js入门介绍

    为什么起名叫JavaScript?原因是当时Java语言非常红火,所以网景公司希望借Java的名气来推广,但事实上JavaScript除了语法上有点像Java,其他部分基本上没啥关系. 为了让Java ...

  3. linux查看端口命令和kill

    1.查看  netstat -atunlp 2kill:kill -9 PID

  4. [web开发] php优势 - PHP与ASP.NET的比较

    php 优势 - PHP与ASP.NET的比较 如今当提到 Web 开发时,您有许多选择.这些方法中许多都涉及到预处理 — 即,利用特定的标记将代码嵌入到 HTML 页面中,这些标记告诉预处理器,它们 ...

  5. 什么是Spring Cloud

    Spring Cloud是一系列框架的有序集合.它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册.配置中心.消息总线.负载均衡.断路器.数据监控等,都可以用 ...

  6. 【BZOJ】1042: [HAOI2008]硬币购物(dp+容斥原理)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1042 一开始写了个O(nv)的背包,果断tle... 看了题解,,好神..用了组合数学中的多重集合方 ...

  7. ssh免密码登录的几个注意事项

    1, authorized_keys文件中每个公钥占一行,不能分成多行. 2,文件夹默认权限为600 3,如果遇到奇怪的问题,可以把.ssh/文件全部删掉,重新用ssh-keygen生成.

  8. C语言若干知识点归记

    一.C语言指针学习架构 1.基本数据类型---指针 2.字符串---指针 3.数组---指针 4.函数---指针 5.结构体---指针 6.共用体---指针 7.枚举---指针 8.位域---指针 9 ...

  9. 利用新浪云平台(SAE) 搭建 HUSTOJ 简易教程

    前言: OnlineJudge(OJ)是一种代码在线判定平台,这里有许多的编程题目供你选择,你可以选择题目提交代码,OJ会自动返回你的代码的判定结果.是一种很方便的编程.算法练习平台.详情可见:百度百 ...

  10. MFC WinInetHttp抓取网页代码内容

    Windows Internet编程主要包括两方面: l  服务器端   l  客户端 WinInet编程 Internet客户端主要实现的功能,主要是通过Internet协议(HTTP.FTP等)获 ...