方案設計:

1.第三方機構申請一個appId,通過appId去獲取accessToken,每次請求獲取accessToken都要把老的accessToken刪掉

2.第三方機構請求數據需要加上accessToken參數,每次業務處理中心執行業務前,先去dba持久層查看accessToken是否存在(可以把accessToken放到redis中,這樣有個過期時間的效果),存在就說明這個機構是合法,無需要登錄就可以請求業務數據。不存在說明這個機構是非法的,不返回業務數據。

3.好處:無狀態設計,每次請求保證都是在我們持久層保存的機構的請求,如果有人盜用我們accessToken,可以重新申請一個新的taken。另外,關注公號“終碼一生”,回復關鍵詞“資料”,獲取視頻教程和最新的面試資料!

2. 基于OAuth2.0協議方式

原理

第三方授權,原理和1的令牌方式一樣

1.假設我是服務提供者A,我有開發接口,外部機構B請求A的接口必須申請自己的appid(B機構id)

2.當B要調用A接口查某個用戶信息的時候,需要對應用戶授權,告訴A,我愿同意把我的信息告訴B,A生產一個授權token給B。

3.B使用token獲取某個用戶的信息。

聯合微信登錄總體處理流程

  1. 用戶同意授權,獲取code
  2. 通過code換取網頁授權access_token
  3. 通過access_token獲取用戶openId
  4. 通過openId獲取用戶信息

3. 信息加密與密鑰管理

1.單向散列加密

散列是信息的提煉,通常其長度要比信息小得多,且為一個固定長度。加密性強的散列一定是不可逆的,這就意味著通過散列結果,無法推出任何部分的原始信息。任何輸入信息的變化,哪怕僅一位,都將導致散列結果的明顯變化,這稱之為雪崩效應。

散列還應該是防沖突的,即找不出具有相同散列結果的兩條信息。具有這些特性的散列結果就可以用于驗證信息是否被修改。

單向散列函數一般用于產生消息摘要,密鑰加密等,常見的有:

MD5(Message Digest Algorithm 5):是RSA數據安全公司開發的一種單向散列算法,非可逆,相同的明文產生相同的密文。

SHA(Secure Hash Algorithm):可以對任意長度的數據運算生成一個160位的數值;

SHA-1與MD5的比較

因為二者均由MD4導出,SHA-1和MD5彼此很相似。相應的,他們的強度和其他特性也是相似,但還有以下幾點不同:

對強行供給的安全性:最顯著和最重要的區別是SHA-1摘要比MD5摘要長32 位。使用強行技術,產生任何一個報文使其摘要等于給定報摘要的難度對MD5是2128數量級的操作,而對SHA-1則是2160數量級的操作。這樣,SHA-1對強行攻擊有更大的強度。

對密碼分析的安全性:由于MD5的設計,易受密碼分析的攻擊,SHA-1顯得不易受這樣的攻擊。

速度:在相同的硬件上,SHA-1的運行速度比MD5慢。

1、特征:雪崩效應、定長輸出和不可逆。

2、作用是:確保數據的完整性。

3、加密算法:md5(標準密鑰長度128位)、sha1(標準密鑰長度160位)、md4、CRC-32

4、加密工具:md5sum、sha1sum、openssl dgst。

5、計算某個文件的hash值,例如:md5sum/shalsum FileName,openssl dgst –md5/-sha

2.對稱加密

秘鑰:加密解密使用同一個密鑰、數據的機密性雙向保證、加密效率高、適合加密于大數據大文件、加密強度不高(相對于非對稱加密)

對稱加密優缺點

優點:與公鑰加密相比運算速度快。

缺點:不能作為身份驗證,密鑰發放困難

DES是一種對稱加密算法,加密和解密過程中,密鑰長度都必須是8的倍數

public class DES {
public DES() {
}

// 測試
public static void main(String args[]) throws Exception {
// 待加密內容
String str = "123456";
// 密碼,長度要是8的倍數 密鑰隨意定
String password = "12345678";
byte[] encrypt = encrypt(str.getBytes(), password);
System.out.println("加密前:" +str);
System.out.println("加密后:" + new String(encrypt));
// 解密
byte[] decrypt = decrypt(encrypt, password);
System.out.println("解密后:" + new String(decrypt));
}

/**
* 加密
*
* @param datasource
* byte[]
* @param password
* String
* @return byte[]
*/
public static byte[] encrypt(byte[] datasource, String password) {
try {
SecureRandom random = new SecureRandom();
DESKeySpec desKey = new DESKeySpec(password.getBytes());
// 創建一個密匙工廠,然后用它把DESKeySpec轉換成
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey securekey = keyFactory.generateSecret(desKey);
// Cipher對象實際完成加密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher對象,ENCRYPT_MODE用于將 Cipher 初始化為加密模式的常量
cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
// 現在,獲取數據并加密
// 正式執行加密操作
return cipher.doFinal(datasource); // 按單部分操作加密或解密數據,或者結束一個多部分操作
} catch (Throwable e) {
e.printStackTrace();
}
return null;
}

/**
* 解密
*
* @param src
* byte[]
* @param password
* String
* @return byte[]
* @throws Exception
*/
public static byte[] decrypt(byte[] src, String password) throws Exception {
// DES算法要求有一個可信任的隨機數源
SecureRandom random = new SecureRandom();
// 創建一個DESKeySpec對象
DESKeySpec desKey = new DESKeySpec(password.getBytes());
// 創建一個密匙工廠
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");// 返回實現指定轉換的
// Cipher
// 對象
// 將DESKeySpec對象轉換成SecretKey對象
SecretKey securekey = keyFactory.generateSecret(desKey);
// Cipher對象實際完成解密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher對象
cipher.init(Cipher.DECRYPT_MODE, securekey, random);
// 真正開始解密操作
return cipher.doFinal(src);
}
}

輸出

加密前:123456
加密后:>p.72|
解密后:123456

3.非對稱加密

非對稱加密算法需要兩個密鑰:公開密鑰(publickey:簡稱公鑰)和私有密鑰(privatekey:簡稱私鑰)。另外,關注公號“終碼一生”,回復關鍵詞“資料”,獲取視頻教程和最新的面試資料!

公鑰與私鑰是一對

過程:

甲方只能用其私鑰解密由其公鑰加密后的任何信息。

特點:

RSA加密是一種非對稱加密

/**
* RSA加解密工具類
*/
public class RSAUtil {

public static String publicKey; // 公鑰
public static String privateKey; // 私鑰

/**
* 生成公鑰和私鑰
*/
public static void generateKey() {
// 1.初始化秘鑰
KeyPairGenerator keyPairGenerator;
try {
keyPairGenerator = KeyPairGenerator.getInstance("RSA");
SecureRandom sr = new SecureRandom(); // 隨機數生成器
keyPairGenerator.initialize(512, sr); // 設置512位長的秘鑰
KeyPair keyPair = keyPairGenerator.generateKeyPair(); // 開始創建
RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic();
RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate();
// 進行轉碼
publicKey = Base64.encodeBase64String(rsaPublicKey.getEncoded());
// 進行轉碼
privateKey = Base64.encodeBase64String(rsaPrivateKey.getEncoded());
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

/**
* 私鑰匙加密或解密
*
* @param content
* @param privateKeyStr
* @return
*/
public static String encryptByprivateKey(String content, String privateKeyStr, int opmode) {
// 私鑰要用PKCS8進行處理
PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyStr));
KeyFactory keyFactory;
PrivateKey privateKey;
Cipher cipher;
byte[] result;
String text = null;
try {
keyFactory = KeyFactory.getInstance("RSA");
// 還原Key對象
privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
cipher = Cipher.getInstance("RSA");
cipher.init(opmode, privateKey);
if (opmode == Cipher.ENCRYPT_MODE) { // 加密
result = cipher.doFinal(content.getBytes());
text = Base64.encodeBase64String(result);
} else if (opmode == Cipher.DECRYPT_MODE) { // 解密
result = cipher.doFinal(Base64.decodeBase64(content));
text = new String(result, "UTF-8");
}

} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return text;
}

/**
* 公鑰匙加密或解密
*
* @param content
* @param privateKeyStr
* @return
*/
public static String encryptByPublicKey(String content, String publicKeyStr, int opmode) {
// 公鑰要用X509進行處理
X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyStr));
KeyFactory keyFactory;
PublicKey publicKey;
Cipher cipher;
byte[] result;
String text = null;
try {
keyFactory = KeyFactory.getInstance("RSA");
// 還原Key對象
publicKey = keyFactory.generatePublic(x509EncodedKeySpec);
cipher = Cipher.getInstance("RSA");
cipher.init(opmode, publicKey);
if (opmode == Cipher.ENCRYPT_MODE) { // 加密
result = cipher.doFinal(content.getBytes());
text = Base64.encodeBase64String(result);
} else if (opmode == Cipher.DECRYPT_MODE) { // 解密
result = cipher.doFinal(Base64.decodeBase64(content));
text = new String(result, "UTF-8");
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return text;
}

// 測試方法
public static void main(String[] args) {
/**
* 注意:私鑰加密必須公鑰解密 公鑰加密必須私鑰解密
* // 正常在開發中的時候,后端開發人員生成好密鑰對,服務器端保存私鑰 客戶端保存公鑰
*/
System.out.println("-------------生成兩對秘鑰,分別發送方和接收方保管-------------");
RSAUtil.generateKey();
System.out.println("公鑰:" + RSAUtil.publicKey);
System.out.println("私鑰:" + RSAUtil.privateKey);

System.out.println("-------------私鑰加密公鑰解密-------------");
String textsr = "11111111";
// 私鑰加密
String cipherText = RSAUtil.encryptByprivateKey(textsr,
RSAUtil.privateKey, Cipher.ENCRYPT_MODE);
System.out.println("私鑰加密后:" + cipherText);
// 公鑰解密
String text = RSAUtil.encryptByPublicKey(cipherText,
RSAUtil.publicKey, Cipher.DECRYPT_MODE);
System.out.println("公鑰解密后:" + text);

System.out.println("-------------公鑰加密私鑰解密-------------");
// 公鑰加密
String textsr2 = "222222";

String cipherText2 = RSAUtil.encryptByPublicKey(textsr2, RSAUtil.publicKey, Cipher.ENCRYPT_MODE);
System.out.println("公鑰加密后:" + cipherText2);
// 私鑰解密
String text2 = RSAUtil.encryptByprivateKey(cipherText2, RSAUtil.privateKey, Cipher.DECRYPT_MODE);
System.out.print("私鑰解密后:" + text2 );
}

}


4. 使用加簽名方式,防止數據篡改

文章轉自微信公眾號@21CTO

熱門推薦
一個賬號試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊
3000+提示詞助力AI大模型
和專業工程師共享工作效率翻倍的秘密
返回頂部
上一篇
為什么需要隱藏您的 API Key 密鑰
下一篇
為什么API清單是PCI?DSS?4.0合規的關鍵
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
91污片在线观看| 99久久综合色| 美国三级日本三级久久99| 国产成人在线免费| 国产亚洲欧美日韩在线一区| 国产真实乱偷精品视频免| 日韩欧美国产一区二区在线播放| 五月激情综合网| 在线播放一区二区三区| 日本视频中文字幕一区二区三区| 在线播放欧美女士性生活| 日韩电影免费在线看| 91精品国产91久久久久久一区二区 | 国产精品麻豆欧美日韩ww| 国产一区二区不卡在线| 中文字幕精品—区二区四季| 91亚洲国产成人精品一区二区三 | 国产精品亚洲一区二区三区在线 | 三级欧美韩日大片在线看| 欧美伊人久久大香线蕉综合69| 婷婷久久综合九色综合绿巨人 | 亚洲免费av网站| 欧美美女bb生活片| 国产成人av电影在线播放| 一区二区三区在线播| 日韩欧美国产综合| 91成人国产精品| 久久99精品网久久| 国产人久久人人人人爽| 欧美日韩精品一区视频| 成人久久久精品乱码一区二区三区| 一区二区国产视频| 国产日产欧产精品推荐色| 欧美另类久久久品| 99久久免费精品| 国模娜娜一区二区三区| 亚洲va天堂va国产va久| 亚洲欧洲精品成人久久奇米网| 26uuu久久天堂性欧美| 欧美日韩国产免费| 日本精品一区二区三区高清| 国产a级毛片一区| 久久狠狠亚洲综合| 香港成人在线视频| 亚洲福利视频三区| 亚洲免费伊人电影| 亚洲欧洲三级电影| 国产精品美女视频| 国产亚洲综合在线| 久久久久久久电影| 精品99999| 26uuu国产在线精品一区二区| 日韩视频免费观看高清完整版在线观看| 99re亚洲国产精品| 成人福利电影精品一区二区在线观看| 国产一区二区网址| 国产成人精品1024| 99国产精品国产精品毛片| 91污在线观看| 在线免费观看日本一区| 欧洲av在线精品| 这里只有精品99re| 精品精品国产高清a毛片牛牛| 欧美电影免费观看高清完整版在线观看 | 狠狠色丁香久久婷婷综| 极品尤物av久久免费看| 国产在线精品一区二区夜色 | 欧美无人高清视频在线观看| 欧美色图第一页| 日韩一区二区免费在线电影| 亚洲精品一区二区三区福利| 国产日韩欧美制服另类| 亚洲精品v日韩精品| 午夜精品福利一区二区蜜股av| 青青草国产精品亚洲专区无| 国产一区不卡在线| 91日韩在线专区| 91精品国产高清一区二区三区| 久久夜色精品国产欧美乱极品| 国产精品视频你懂的| 亚洲福利电影网| 国产在线不卡一区| 91极品美女在线| 国产色产综合产在线视频| 午夜伦理一区二区| 国产成人精品一区二| 欧美日韩mp4| 国产精品视频你懂的| 蜜桃av一区二区三区| 粗大黑人巨茎大战欧美成人| 欧美电影在哪看比较好| 亚洲你懂的在线视频| 韩国av一区二区三区四区| 欧美日韩在线直播| 国产精品女主播在线观看| 日韩精品一二三区| 99re66热这里只有精品3直播| 久久综合九色综合久久久精品综合 | 91视频观看免费| 欧美精品一区二区三| 视频一区视频二区在线观看| 91捆绑美女网站| 中文字幕在线一区| 国产精品一区二区91| 精品国产制服丝袜高跟| 午夜精品123| 欧美日韩精品欧美日韩精品一| 国产精品久久精品日日| 国产精品99久久久久久久女警| 日韩欧美激情四射| 蜜臀91精品一区二区三区 | 国产亚洲综合在线| 国产在线一区观看| 日韩免费看的电影| 性做久久久久久久免费看| 91久久久免费一区二区| 亚洲男人都懂的| 国产xxx精品视频大全| 国产欧美日韩精品在线| 国产91精品一区二区| 久久免费看少妇高潮| 国产传媒一区在线| 国产精品免费视频一区| 91在线码无精品| 亚洲精品写真福利| 91精品国产黑色紧身裤美女| 男人的天堂久久精品| 久久久不卡影院| av在线不卡电影| 夜夜揉揉日日人人青青一国产精品| 欧美亚洲国产一区在线观看网站 | 欧美日韩精品欧美日韩精品| 日韩 欧美一区二区三区| 日韩精品一区国产麻豆| 福利一区二区在线| 亚洲国产视频在线| 久久久亚洲午夜电影| 97精品视频在线观看自产线路二| 亚洲综合成人在线| 精品久久久网站| 91麻豆精东视频| 日韩av电影一区| 国产精品电影一区二区| 欧美日韩aaaaaa| 国产+成+人+亚洲欧洲自线| 亚洲国产精品视频| 国产精品区一区二区三区 | 欧美性受xxxx黑人xyx性爽| 国产一区二区毛片| 亚洲国产中文字幕| 国产精品白丝在线| 精品欧美黑人一区二区三区| 色哟哟国产精品免费观看| 精品亚洲免费视频| 亚洲福利一区二区| 中文字幕一区av| 久久久99精品久久| 在线电影院国产精品| 色哟哟在线观看一区二区三区| 国产一二三精品| 欧美aaaaa成人免费观看视频| 亚洲欧美日韩国产成人精品影院| 久久影院视频免费| www一区二区| 欧美一区二区免费观在线| 欧美亚洲一区二区在线| 色综合中文字幕国产| 国产自产视频一区二区三区| 午夜久久久影院| 亚洲综合在线电影| 亚洲最快最全在线视频| 一区二区三区在线视频免费| 亚洲三级免费电影| 成人欧美一区二区三区在线播放| 国产精品免费av| 亚洲视频免费在线| 一区二区三区在线观看视频| 18欧美亚洲精品| 国产精品高清亚洲| 亚洲精品免费一二三区| 亚洲在线视频免费观看| 亚洲国产欧美在线| 日韩av中文字幕一区二区三区| 日韩高清电影一区| 经典三级一区二区| 成人性生交大片免费看视频在线 | 国产高清精品网站| 白白色 亚洲乱淫| 91麻豆.com| 日韩一区二区麻豆国产| 久久网这里都是精品| 国产精品传媒在线| 一区二区三区精品在线观看| 日本午夜一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 成人性生交大片免费看中文| 一本久道久久综合中文字幕| 91精品国产综合久久精品app| 日本一区二区视频在线| 亚洲一二三四在线观看|