久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Java 自動安裝校驗TLS/SSL證書

瀏覽:4日期:2022-08-22 11:47:11

前言

最近實現Socks5 proxy與HTTP proxy中遇到了SSLSocket隧道的問題,當然,最終問題經過自動證書校驗安裝管理器實現了證書的管理,也解決了SSLSocket,但是目前的問題是瀏覽器對Socks5和HTTP proxy還有很多不足,目前實現的兩個代理工具只能在程序中使用。當然,我們今天的主要話題如下:

Java 實現TLS/SSL證書的自動安裝校驗,主要經過ssl/tls握手,密鑰交換,證書校驗機制實現。我們這里模擬瀏覽器,實現自動校驗和證書的檢測。

主要實現如下功能:

1.自動檢測,校驗根證書,校驗過期時間,校驗簽名的證書是否有效,校驗證書和域名是否匹配

2.實現證書的自動存儲,自動安裝,加載

3.實現普通Socket自動升級為SSLSocket

一.實現配置類

首先,我們先添加2個配置類

package com.ssl.rx.http;import java.security.KeyStore;public class ConnectionConfiguration {/** 證書文件路徑 */private String truststorePath;/** 證書類型 */private String truststoreType;/** 證書文件密碼 */private String truststorePassword;/** 是否驗證證書鏈的簽名有效性 */private boolean verifyChainEnabled = true;/** 是否校驗根證書,注意,自簽名證書沒有根證書 */private boolean verifyRootCAEnabled = true;/** 是否允許通過自簽名證書 */private boolean selfSignedCertificateEnabled = false;/** 是否檢查證書的有效期 */private boolean expiredCertificatesCheckEnabled = true;/** 檢查域名的匹配情況 */private boolean notMatchingDomainCheckEnabled = true;private String server;private int port;public ConnectionConfiguration() {truststorePassword = 'WlZSak5GcFVUbTlsVjJSNg==';truststorePath = 'socket_tls_clientTrust.cert';truststoreType = 'jks';}public int getPort() {return port;}public void setPort(int port) {this.port = port;}public String getServer() {return server;}public void setServer(String server) {this.server = server;}public boolean isExpiredCertificatesCheckEnabled() {return expiredCertificatesCheckEnabled;}public void setSelfSignedCertificateEnabled(boolean selfSignedCertificateEnabled) {this.selfSignedCertificateEnabled = selfSignedCertificateEnabled;}public void setExpiredCertificatesCheckEnabled(boolean expiredCertificatesCheckEnabled) {this.expiredCertificatesCheckEnabled = expiredCertificatesCheckEnabled;}public boolean isSelfSignedCertificateEnabled() {return selfSignedCertificateEnabled;}public boolean isNotMatchingDomainCheckEnabled() {return notMatchingDomainCheckEnabled;}public boolean isVerifyRootCAEnabled() {return verifyRootCAEnabled;}public void setVerifyRootCAEnabled(boolean verifyRootCAEnabled) {this.verifyRootCAEnabled = verifyRootCAEnabled;}public void setVerifyChainEnabled(boolean verifyChainEnabled) {this.verifyChainEnabled = verifyChainEnabled;}public boolean isVerifyChainEnabled() {return verifyChainEnabled;}public String getTruststoreType() {return truststoreType;}public void setTruststoreType(String truststoreType) {this.truststoreType = truststoreType;}public String getTruststorePassword() {return truststorePassword;}public void setTruststorePassword(String truststorePassword) {this.truststorePassword = truststorePassword;}public String getTruststorePath() {return truststorePath;}public void setTruststorePath(String truststorePath) {this.truststorePath = truststorePath;}public void setNotMatchingDomainCheckEnabled(boolean notMatchingDomainCheckEnabled) {this.notMatchingDomainCheckEnabled = notMatchingDomainCheckEnabled;}}然后增加一個用于存儲keystore的javaBeanpackage com.ssl.rx.http;public class KeyStoreOptions {private final String type;private final String path;private final String password;public KeyStoreOptions(String type, String path, String password) {super();this.type = type;this.path = path;this.password = password;}public String getType() {return type;}public String getPath() {return path;}public String getPassword() {return password;}@Overridepublic int hashCode() {final int prime = 31;int result = 1;result = prime * result + ((password == null) ? 0 : password.hashCode());result = prime * result + ((path == null) ? 0 : path.hashCode());result = prime * result + ((type == null) ? 0 : type.hashCode());return result;}@Overridepublic boolean equals(Object obj) {if (this == obj)return true;if (obj == null)return false;if (getClass() != obj.getClass())return false;KeyStoreOptions other = (KeyStoreOptions) obj;if (password == null) {if (other.password != null)return false;} else if (!password.equals(other.password))return false;if (path == null) {if (other.path != null)return false;} else if (!path.equals(other.path))return false;if (type == null) {if (other.type != null)return false;} else if (!type.equals(other.type))return false;return true;}}

最后,我們來實現核心部分,證書管理器

二.實現核心代碼

package com.ssl.rx.http;public class SSLX509CertificateManager {private static final Logger logger = Logger.getLogger('SSLX509CertificateManager');private static final char[] HEXDIGITS = '0123456789abcdef'.toCharArray();private static Pattern cnPattern = Pattern.compile('(?i)(cn=)([^,]*)');private static Map<KeyStoreOptions, KeyStore> stores = new HashMap<KeyStoreOptions, KeyStore>();private static String toHexString(byte[] bytes) {StringBuilder sb = new StringBuilder(bytes.length * 3);for (int b : bytes) {b &= 0xff;sb.append(HEXDIGITS[b >> 4]);sb.append(HEXDIGITS[b & 15]);sb.append(’ ’);}return sb.toString();}/** * 開始握手等一系列密鑰協商 * * @param socket * @return */public static boolean startHandshake(SSLSocket socket) {try {logger.log(Level.INFO, '-開始握手,認證服務器證書-');socket.startHandshake();System.out.println();logger.log(Level.INFO, '-握手結束,結束認證服務器證書-');} catch (SSLException e) {e.printStackTrace();return false;} catch (IOException e) {e.printStackTrace();return false;}return true;}public static SSLSocket createTrustCASocket(String host, int port, ConnectionConfiguration config)throws Exception {if (config == null) {config = new ConnectionConfiguration();}KeyStore ks = getKeyStore(config);SSLContext context = SSLContext.getInstance('TLS');TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());tmf.init(ks);X509TrustManager defaultTrustManager = (X509TrustManager) tmf.getTrustManagers()[0];CAX509TrustManager tm = new CAX509TrustManager(defaultTrustManager, ks, config);context.init(null, new TrustManager[] { tm }, new SecureRandom());SSLSocketFactory factory = context.getSocketFactory();logger.log(Level.INFO, '開始連接: ' + host + ':' + port + '...');SSLSocket socket = (SSLSocket) factory.createSocket(host, port);socket.setSoTimeout(10000);config.setServer(host);config.setPort(port);// config.setTrustKeyStore(ks);X509Certificate certificate = (X509Certificate) ks.getCertificate(host + ':' + port);if (certificate != null && isValid(certificate)) {logger.log(Level.INFO, '-證書文件存在并且有效,無需進行握手-');return socket;}if (!startHandshake(socket)) {logger.log(Level.SEVERE, '-握手失敗-');return null;}X509Certificate[] chain = tm.chain;if (chain == null || chain.length == 0) {logger.log(Level.SEVERE, '-證書鏈為空,認證失敗-');return null;}if (config.isVerifyRootCAEnabled()) {boolean isValidRootCA = checkX509CertificateRootCA(ks, chain, config.isSelfSignedCertificateEnabled());if (!isValidRootCA) {return null;}}return socket;}/** * 獲取keystore,防治多次加載 * * @param config * @return * @throws KeyStoreException * @throws IOException * @throws NoSuchAlgorithmException * @throws CertificateException * @throws FileNotFoundException */private static KeyStore getKeyStore(ConnectionConfiguration config) throws KeyStoreException, IOException,NoSuchAlgorithmException, CertificateException, FileNotFoundException {KeyStore ks;synchronized (stores) {KeyStoreOptions options = new KeyStoreOptions(config.getTruststoreType(), config.getTruststorePath(),config.getTruststorePassword());if (stores.containsKey(options)) {logger.log(Level.INFO, '從緩存中獲取trustKeystore');ks = stores.get(options);} else {File file = new File(config.getTruststorePath());char[] password = config.getTruststorePassword().toCharArray();logger.log(Level.INFO, '加載' + file + '證書文件');ks = KeyStore.getInstance(KeyStore.getDefaultType());if (!file.exists()) {logger.log(Level.INFO, '證書文件不存在,選擇自動創建');ks.load(null, password);} else {logger.log(Level.INFO, '證書文件存在,開始加載');InputStream in = new FileInputStream(file);ks.load(in, password);in.close();}stores.put(options, ks);}}return ks;}public static SSLSocket createTrustCASocket(String host, int port) throws Exception {return createTrustCASocket(host, port, null);}public static SSLSocket createTrustCASocket(Socket s, ConnectionConfiguration config) throws Exception {if (config == null) {config = new ConnectionConfiguration();}KeyStore ks = getKeyStore(config);SSLContext context = SSLContext.getInstance('TLS');TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());tmf.init(ks);X509TrustManager defaultTrustManager = (X509TrustManager) tmf.getTrustManagers()[0];CAX509TrustManager tm = new CAX509TrustManager(defaultTrustManager, ks, config);context.init(null, new TrustManager[] { tm }, new SecureRandom());SSLSocketFactory factory = context.getSocketFactory();String host = s.getInetAddress().getHostName();int port = s.getPort();logger.log(Level.INFO, '開始連接: ' + host + ':' + port + '...');SSLSocket socket = (SSLSocket) factory.createSocket(s, host, port, true);socket.setSoTimeout(10000);config.setServer(s.getInetAddress().getHostName());config.setPort(s.getPort());X509Certificate certificate = (X509Certificate) ks.getCertificate(host + ':' + s.getPort());if (certificate != null && isValid(certificate)) {logger.log(Level.INFO, '-證書文件存在并且有效,無需進行握手-');return socket;}if (!startHandshake(socket)) {return null;}X509Certificate[] chain = tm.chain;if (chain == null || chain.length == 0) {logger.log(Level.SEVERE, '-證書鏈為空,認證失敗-');return null;}if (config.isVerifyRootCAEnabled()) {boolean isValidRootCA = checkX509CertificateRootCA(ks, chain, config.isSelfSignedCertificateEnabled());if (!isValidRootCA) {logger.log(Level.SEVERE, '根證書校驗無效');return null;}}return socket;}public static SSLSocket createTrustCASocket(Socket s) throws Exception {return createTrustCASocket(s, null);}public static class CAX509TrustManager implements X509TrustManager {private final X509TrustManager tm;private X509Certificate[] chain;private KeyStore keyStore;private ConnectionConfiguration config;public MessageDigest sha1 = null;public MessageDigest md5 = null;public CAX509TrustManager(X509TrustManager tm, KeyStore ks, ConnectionConfiguration config)throws NoSuchAlgorithmException {this.tm = tm;this.keyStore = ks;sha1 = MessageDigest.getInstance('SHA1');md5 = MessageDigest.getInstance('MD5');this.config = config;}public X509Certificate[] getAcceptedIssuers() {return tm.getAcceptedIssuers(); // 生成證書數組,用于存儲新證書}public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {tm.checkClientTrusted(chain, authType); // 檢查客戶端}public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {if (this.chain == null) {this.chain = getAcceptedIssuers();}if (chain != null && chain.length > 0) {if (!checkX509CertificateValid(chain, config)) {logger.log(Level.SEVERE, '證書校驗未通過');return;}for (int i = 0; i < chain.length; i++) {X509Certificate certificate = chain[i];if (i == 0) {saveCAToKeyStore(certificate, config.getServer() + ':' + config.getPort());} else {saveCAToKeyStore(certificate, null);}}}}public void saveCAToKeyStore(X509Certificate certificate, String aliasKey) throws CertificateEncodingException {try {X509Certificate cert = certificate;System.out.println(' Subject ' + cert.getSubjectDN());System.out.println(' Issuer ' + cert.getIssuerDN());sha1.update(cert.getEncoded());System.out.println(' sha1 ' + toHexString(sha1.digest()));md5.update(cert.getEncoded());System.out.println(' md5 ' + toHexString(md5.digest()));String alias = keyStore.getCertificateAlias(cert);if (alias == null || alias != null && !isValid(certificate)) {if (aliasKey == null || aliasKey.length() == 0) {alias = cert.getSubjectDN().getName();} else {alias = aliasKey;logger.log(Level.INFO, '設定指定證書別名:' + alias);}keyStore.setCertificateEntry(alias, certificate);OutputStream out = new FileOutputStream(config.getTruststorePath());keyStore.store(out, config.getTruststorePassword().toCharArray());out.close();chain = Arrays.copyOf(chain, chain.length + 1);chain[chain.length - 1] = certificate;logger.fine(certificate.toString());}} catch (KeyStoreException e) {e.printStackTrace();} catch (FileNotFoundException e) {e.printStackTrace();} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (CertificateException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}}public static boolean isValid(X509Certificate cert) {if (cert == null) {return false;}try {cert.checkValidity();} catch (CertificateExpiredException e) {e.printStackTrace();return false;} catch (CertificateNotYetValidException e) {e.printStackTrace();return false;}return true;}/** * 校驗證書的有效性 * * @param chain * @param config * @return */private static boolean checkX509CertificateValid(X509Certificate[] chain, ConnectionConfiguration config) {boolean result = true;if (config.isExpiredCertificatesCheckEnabled()) {result = result && checkX509CertificateExpired(chain);}if (config.isVerifyChainEnabled()) {result = result && checkX509CertificateChain(chain);}if (config.isNotMatchingDomainCheckEnabled()) {result = result && checkIsMatchDomain(chain, config.getServer());}return result;}/** * 檢查是否匹配域名 * * @param x509Certificates * @param server * @return */public static boolean checkIsMatchDomain(X509Certificate[] x509Certificates, String server) {server = server.toLowerCase();List<String> peerIdentities = getPeerIdentity(x509Certificates[0]);if (peerIdentities.size() == 1 && peerIdentities.get(0).startsWith('*.')) {String peerIdentity = peerIdentities.get(0).replace('*.', '');if (!server.endsWith(peerIdentity)) {return false;}} else {for (int i = 0; i < peerIdentities.size(); i++) {String peerIdentity = peerIdentities.get(i).replace('*.', '');if (server.endsWith(peerIdentity)) {return true;}}}return false;}/** * 校驗根證書 * * @param trustStore * @param x509Certificates * @param isSelfSignedCertificate * 是否自簽名證書 * @return */public static boolean checkX509CertificateRootCA(KeyStore trustStore, X509Certificate[] x509Certificates,boolean isSelfSignedCertificate) {List<String> peerIdentities = getPeerIdentity(x509Certificates[0]);boolean trusted = false;try {int size = x509Certificates.length;trusted = trustStore.getCertificateAlias(x509Certificates[size - 1]) != null;if (!trusted && size == 1 && isSelfSignedCertificate) {logger.log(Level.WARNING, '-強制認可自簽名證書-');trusted = true;}} catch (KeyStoreException e) {e.printStackTrace();}if (!trusted) {logger.log(Level.SEVERE, '-根證書簽名的網站:' + peerIdentities + '不能被信任');}return trusted;}/** * 檢查證書是否過期 * * @param x509Certificates * @return */public static boolean checkX509CertificateExpired(X509Certificate[] x509Certificates) {Date date = new Date();for (int i = 0; i < x509Certificates.length; i++) {try {x509Certificates[i].checkValidity(date);} catch (GeneralSecurityException generalsecurityexception) {logger.log(Level.SEVERE, '-證書已經過期-');return false;}}return true;}/** * 校驗證書鏈的完整性 * * @param x509Certificates * @return */public static boolean checkX509CertificateChain(X509Certificate[] x509Certificates) {Principal principalLast = null;List<String> peerIdentities = getPeerIdentity(x509Certificates[0]);for (int i = x509Certificates.length - 1; i >= 0; i--) {X509Certificate x509certificate = x509Certificates[i];Principal principalIssuer = x509certificate.getIssuerDN();Principal principalSubject = x509certificate.getSubjectDN();if (principalLast != null) {if (principalIssuer.equals(principalLast)) {try {PublicKey publickey = x509Certificates[i + 1].getPublicKey();x509Certificates[i].verify(publickey);} catch (GeneralSecurityException generalsecurityexception) {logger.log(Level.SEVERE, '-無效的證書簽名-' + peerIdentities);return false;}} else {logger.log(Level.SEVERE, '-無效的證書簽名-' + peerIdentities);return false;}}principalLast = principalSubject;}return true;}/** * 返回所有可用的簽名方式 鍵值對 如CN=VeriSignMPKI-2-6 * * @param certificate * @return */private static List<String> getSubjectAlternativeNames(X509Certificate certificate) {List<String> identities = new ArrayList<String>();try {Collection<List<?>> altNames = certificate.getSubjectAlternativeNames();if (altNames == null) {return Collections.emptyList();}Iterator<List<?>> iterator = altNames.iterator();do {if (!iterator.hasNext())break;List<?> altName = iterator.next();int size = altName.size();if (size >= 2) {identities.add((String) altName.get(1));}} while (true);} catch (CertificateParsingException e) {e.printStackTrace();}return identities;}/** * 返回所有可用的簽名方式的值 * * @param certificate * @return */public static List<String> getPeerIdentity(X509Certificate x509Certificate) {List<String> names = getSubjectAlternativeNames(x509Certificate);if (names.isEmpty()) {String name = x509Certificate.getSubjectDN().getName();Matcher matcher = cnPattern.matcher(name);if (matcher.find()) {name = matcher.group(2);}names = new ArrayList<String>();names.add(name);}return names;}}

三.測試代碼

public class TestX509CertManager { public static void main(String[] args) {try {SSLSocket baiduSocket = SSLX509CertificateManager.createTrustCASocket('www.baidu.com', 443);SSLSocket taobaoSocket = SSLX509CertificateManager.createTrustCASocket('www.taobao.com', 443);SSLSocket imququSocket = SSLX509CertificateManager.createTrustCASocket('imququ.com', 443);} catch (Exception e) {e.printStackTrace();}}}

四.附加測試代碼

我們這里附加一個工具類,專門來實現Server-Side與Client-Side的SSLSocket 連接,也可以用于測試我們的上述代碼,只不過需要稍加改造。

package com.tianwt.rx.http;public class SSLTrustManager implements javax.net.ssl.TrustManager, javax.net.ssl.X509TrustManager ,HostnameVerifier { public java.security.cert.X509Certificate[] getAcceptedIssuers() { return new X509Certificate[]{}; } public boolean isServerTrusted(java.security.cert.X509Certificate[] certs) { return true; } public boolean isClientTrusted(java.security.cert.X509Certificate[] certs) { return true; } public void checkServerTrusted(java.security.cert.X509Certificate[] certs, String authType)throws java.security.cert.CertificateException { return; } public void checkClientTrusted(java.security.cert.X509Certificate[] certs, String authType)throws java.security.cert.CertificateException { return; } @Override public boolean verify(String urlHostName, SSLSession session) { //允許所有主機 return true; } /** * 客戶端使用 */ public static HttpURLConnection connectTrustAllServer(String strUrl) throws Exception { return connectTrustAllServer(strUrl,null); } /** * 客戶端使用 * * @param strUrl 要訪問的地址 * @param proxy 需要經過的代理 * @return * @throws Exception */ public static HttpURLConnection connectTrustAllServer(String strUrl,Proxy proxy) throws Exception { javax.net.ssl.TrustManager[] trustCertsmanager = new javax.net.ssl.TrustManager[1]; javax.net.ssl.TrustManager tm = new SSLTrustManager(); trustCertsmanager[0] = tm; javax.net.ssl.SSLContext sc = javax.net.ssl.SSLContext .getInstance('TLS'); sc.init(null, trustCertsmanager, null); javax.net.ssl.HttpsURLConnection.setDefaultSSLSocketFactory(sc .getSocketFactory()); HttpsURLConnection.setDefaultHostnameVerifier((HostnameVerifier) tm); URL url = new URL(strUrl); HttpURLConnection urlConn = null; if(proxy==null) { urlConn = (HttpURLConnection) url.openConnection(); }else{ urlConn = (HttpURLConnection) url.openConnection(proxy); } urlConn.setRequestProperty('User-Agent', 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.112 Safari/537.36'); return urlConn; } /** * 用于雙向認證,客戶端使用 * * @param strUrl * @param proxy * @return * @throws KeyStoreException * @throws NoSuchAlgorithmException * @throws CertificateException * @throws FileNotFoundException * @throws IOException * @throws UnrecoverableKeyException * @throws KeyManagementException */ public static HttpURLConnection connectProxyTrustCA(String strUrl,Proxy proxy) throws KeyStoreException, NoSuchAlgorithmException, CertificateException, FileNotFoundException, IOException, UnrecoverableKeyException, KeyManagementException { HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {@Overridepublic boolean verify(String s, SSLSession sslsession) {return true;}}); String clientKeyStoreFile = 'D:/JDK8Home/tianwt/sslClientKeys'; String clientKeyStorePwd = '123456'; String catServerKeyPwd = '123456'; String serverTrustKeyStoreFile = 'D:/JDK8Home/tianwt/sslClientTrust'; String serverTrustKeyStorePwd = '123456'; KeyStore serverKeyStore = KeyStore.getInstance('JKS'); serverKeyStore.load(new FileInputStream(clientKeyStoreFile), clientKeyStorePwd.toCharArray()); KeyStore serverTrustKeyStore = KeyStore.getInstance('JKS'); serverTrustKeyStore.load(new FileInputStream(serverTrustKeyStoreFile), serverTrustKeyStorePwd.toCharArray()); KeyManagerFactory kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm()); kmf.init(serverKeyStore, catServerKeyPwd.toCharArray()); TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); tmf.init(serverTrustKeyStore); SSLContext sslContext = SSLContext.getInstance('TLS'); sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), new SecureRandom()); HttpsURLConnection.setDefaultSSLSocketFactory(sslContext.getSocketFactory()); URL url = new URL(strUrl); HttpURLConnection httpURLConnection = null; if(proxy==null) { httpURLConnection = (HttpURLConnection) url.openConnection(); }else{ httpURLConnection = (HttpURLConnection) url.openConnection(proxy); } httpURLConnection.setRequestProperty('User-Agent', 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.112 Safari/537.36'); return httpURLConnection; } /** * 用于單向認證,客戶端使用 * * server側只需要自己的keystore文件,不需要truststore文件* client側不需要自己的keystore文件,只需要truststore文件(其中包含server的公鑰)。 * 此外server側需要在創建SSLServerSocket之后設定不需要客戶端證書:setNeedClientAuth(false) * @param strUrl * @param proxy * @return * @throws KeyStoreException * @throws NoSuchAlgorithmException * @throws CertificateException * @throws FileNotFoundException * @throws IOException * @throws UnrecoverableKeyException * @throws KeyManagementException */ public static HttpURLConnection connectProxyTrustCA2(String strUrl,Proxy proxy) throws KeyStoreException, NoSuchAlgorithmException, CertificateException, FileNotFoundException, IOException, UnrecoverableKeyException, KeyManagementException { HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {@Overridepublic boolean verify(String s, SSLSession sslsession) {return true;}});String serverTrustKeyStoreFile = 'D:/JDK8Home/tianwt/sslClientTrust'; String serverTrustKeyStorePwd = '123456'; KeyStore serverTrustKeyStore = KeyStore.getInstance('JKS'); serverTrustKeyStore.load(new FileInputStream(serverTrustKeyStoreFile), serverTrustKeyStorePwd.toCharArray()); TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); tmf.init(serverTrustKeyStore); SSLContext sslContext = SSLContext.getInstance('TLS'); sslContext.init(null, tmf.getTrustManagers(), null); HttpsURLConnection.setDefaultSSLSocketFactory(sslContext.getSocketFactory()); URL url = new URL(strUrl); HttpURLConnection httpURLConnection = null; if(proxy==null) { httpURLConnection = (HttpURLConnection) url.openConnection(); }else{ httpURLConnection = (HttpURLConnection) url.openConnection(proxy); } httpURLConnection.setRequestProperty('User-Agent', 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.112 Safari/537.36'); return httpURLConnection; } /** * 用于雙向認證 * @param socketClient 是否產生socket * @return * @throws KeyStoreException * @throws NoSuchAlgorithmException * @throws CertificateException * @throws FileNotFoundException * @throws IOException * @throws UnrecoverableKeyException * @throws KeyManagementException */ public SSLSocket createTlsConnect(Socket socketClient) throws KeyStoreException, NoSuchAlgorithmException, CertificateException, FileNotFoundException, IOException, UnrecoverableKeyException, KeyManagementException{ String protocol = 'TLS'; String serverKey = 'D:/JDK8Home/tianwt/sslServerKeys'; String serverTrust = 'D:/JDK8Home/tianwt/sslServerTrust'; String serverKeyPwd = '123456'; //私鑰密碼 String serverTrustPwd = '123456'; //信任證書密碼 String serverKeyStorePwd = '123456'; // keystore存儲密碼 KeyStore keyStore = KeyStore.getInstance('JKS'); keyStore.load(new FileInputStream(serverKey),serverKeyPwd.toCharArray()); KeyStore tks = KeyStore.getInstance('JKS'); tks.load(new FileInputStream(serverTrust), serverTrustPwd.toCharArray());KeyManagerFactory km = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm()); km.init(keyStore, serverKeyStorePwd.toCharArray());TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); tmf.init(tks);SSLContext sslContext = SSLContext.getInstance(protocol); sslContext.init(km.getKeyManagers(), tmf.getTrustManagers(), new SecureRandom()); //第一項是用來做服務器驗證的SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory(); SSLSocket clientSSLSocket = (SSLSocket) sslSocketFactory.createSocket(socketClient,socketClient.getInetAddress().getHostAddress(),socketClient.getPort(), true); clientSSLSocket.setNeedClientAuth(false); clientSSLSocket.setUseClientMode(false);return clientSSLSocket;} /** * 用于單向認證 * server側只需要自己的keystore文件,不需要truststore文件* client側不需要自己的keystore文件,只需要truststore文件(其中包含server的公鑰)。 * 此外server側需要在創建SSLServerSocket之后設定不需要客戶端證書:setNeedClientAuth(false) * @param socketClient * @return * @throws KeyStoreException * @throws NoSuchAlgorithmException * @throws CertificateException * @throws FileNotFoundException * @throws IOException * @throws UnrecoverableKeyException * @throws KeyManagementException */ public static SSLSocket createTlsConnect2(Socket socketClient) throws KeyStoreException, NoSuchAlgorithmException, CertificateException, FileNotFoundException, IOException, UnrecoverableKeyException, KeyManagementException { String protocol = 'TLS'; String serverKey = 'D:/JDK8Home/tianwt/sslServerKeys'; String serverKeyPwd = '123456'; //私鑰密碼 String serverKeyStorePwd = '123456'; // keystore存儲密碼 KeyStore keyStore = KeyStore.getInstance('JKS'); keyStore.load(new FileInputStream(serverKey),serverKeyPwd.toCharArray()); KeyManagerFactory km = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm()); km.init(keyStore, serverKeyStorePwd.toCharArray()); SSLContext sslContext = SSLContext.getInstance(protocol); sslContext.init(km.getKeyManagers(), null, new SecureRandom()); //第一項是用來做服務器驗證的 SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory(); SSLSocket clientSSLSocket = (SSLSocket) sslSocketFactory.createSocket(socketClient,socketClient.getInetAddress().getHostAddress(),socketClient.getPort(), true); clientSSLSocket.setNeedClientAuth(false); clientSSLSocket.setUseClientMode(false); return clientSSLSocket; } /** * 將普通的socket轉為sslsocket,客戶端和服務端均可使用 * * 服務端使用的時候是把普通的socket轉為sslsocket,并且作為服務器套接字(注意:指的不是ServerSocket,當然ServerSocket的本質也是普通socket) * * @param remoteHost * @param isClient * @return */public static SSLSocket getTlsTrustAllSocket(Socket remoteHost,boolean isClient){SSLSocket remoteSSLSocket = null;SSLContext context = SSLTrustManager.getTrustAllSSLContext(isClient);try {remoteSSLSocket = (SSLSocket) context.getSocketFactory().createSocket(remoteHost, remoteHost.getInetAddress().getHostName(),remoteHost.getPort(), true);remoteSSLSocket.setTcpNoDelay(true);remoteSSLSocket.setSoTimeout(5000);remoteSSLSocket.setNeedClientAuth(false); //這里設置為true時會強制握手remoteSSLSocket.setUseClientMode(isClient); //注意服務器和客戶的角色選擇 } catch (IOException e) {e.printStackTrace();}return remoteSSLSocket;}/** * 用于客戶端,通過所有證書驗證 * @param isClient 是否生成客戶端SSLContext,否則生成服務端SSLContext * @return */ public static SSLContext getTrustAllSSLContext(boolean isClient) { String protocol = 'TLS'; javax.net.ssl.SSLContext sc = null; try {javax.net.ssl.TrustManager[] trustAllCerts = new javax.net.ssl.TrustManager[1]; javax.net.ssl.TrustManager tm = new SSLTrustManager(); trustAllCerts[0] = tm; sc = javax.net.ssl.SSLContext .getInstance(protocol); if(isClient) { sc.init(null, trustAllCerts, null); //作為客戶端使用 } else { String serverKeyPath = 'D:/JDK8Home/tianwt/sslServerKeys'; String serverKeyPwd = '123456'; //私鑰密碼 String serverKeyStorePwd = '123456'; // keystore存儲密碼 KeyStore keyStore = KeyStore.getInstance('JKS'); keyStore.load(new FileInputStream(serverKeyPath),serverKeyPwd.toCharArray());KeyManagerFactory km = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm()); km.init(keyStore, serverKeyStorePwd.toCharArray()); KeyManager[] keyManagers = km.getKeyManagers(); keyManagers = Arrays.copyOf(keyManagers, keyManagers.length+1); sc.init(keyManagers, null, new SecureRandom()); }} catch (KeyManagementException e) {e.printStackTrace();} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (UnrecoverableKeyException e) {e.printStackTrace();} catch (KeyStoreException e) {e.printStackTrace();} catch (CertificateException e) {e.printStackTrace();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} return sc; } }

以上就是Java 自動安裝校驗TLS/SSL證書的詳細內容,更多關于Java TLS/SSL證書的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产成人精品免高潮在线观看 | 亚洲福利一区 | 新99热| 午夜欧美精品久久久久 | 黄色网在线看 | 国产2区 | 91亚洲国产精品 | 色婷婷综合在线 | 91偷拍精品一区二区三区 | 成人在线小视频 | 欧美一区二区三区视频 | 日韩在线无 | 日韩成人精品 | 日韩成人免费电影 | 成人精品网 | 亚洲视频免费在线 | 成人欧美一区二区三区 | 久热亚洲 | 精品国产999 | 色综合成人 | 久久精品国产99国产 | 久久99国产精品久久99大师 | 成人不卡在线观看 | 三级黄色片在线 | 亚洲人成在线播放 | 欧美日在线 | 午夜精品视频 | 久久视频在线 | 欧美最猛性xxxxx亚洲精品 | 久久久久国产精品午夜一区 | 99亚洲国产 | 在线观看免费av的网址 | 色婷婷导航 | ririsao久久精品一区 | 韩日av在线 | 国产精品久久久久久久久久 | 日韩精品一91爱爱 | www.se天堂 | 亚洲系列 | 日韩天堂 | 精久久久 | 天天干国产 | 杏导航aⅴ福利网站 | 国产一区久久久 | 在线视频91| 人人草人人| 在线久| 欧美区国产 | 欧美激情第二页 | 成人福利网 | 一级黄色片子看看 | 91视视频在线观看入口直接观看 | 日韩www| 九九免费视频 | 91aiai | 日韩欧美在线综合 | 国产乡下妇女做爰视频 | 99久久日韩精品视频免费在线观看 | 亚洲在线一区二区 | 天天草天天干 | 国产精品国色综合久久 | 另类五月 | 天天看天天操 | 精品国产免费久久久久久尖叫 | 草比网站| 久久久久a | 欧美成在线视频 | 国产精品美女久久久久久久久久久 | 亚洲视频一区二区 | 中文字幕一区在线观看视频 | 在线视频日韩 | 国产精品久久久久久婷婷天堂 | 亚洲福利一区二区 | 成人在线看片 | 久草久草久草 | 91中文在线观看 | 国产欧美日韩综合精品一区二区 | 国产999精品久久久影片官网 | 天天看天天爽 | 日韩欧美一级二级 | 久久一精品| 亚洲av毛片一级二级在线 | 久久精品免费一区二区 | 狠狠操夜夜操 | 亚洲国产成人久久综合一区,久久久国产99 | 日韩精品一区二区三区四区视频 | 99热在线观看免费 | 超碰c | 国产精品久久久久久久久久久杏吧 | 亚洲欧洲精品成人久久奇米网 | 国产在线一 | 国产精品网站在线看 | 天天久久| 精品国偷自产在线 | 国产综合久久久久久鬼色 | 欧美日韩中文国产一区发布 | 久久久久久国产精品高清 | 日韩欧美一级二级 | 国产精品久久久久久久浪潮网站 | 成人av免费在线观看 | 精品欧美黑人一区二区三区 | 婷婷久久综合九色综合绿巨人 | 国产精品极品美女在线观看免费 | 伊人激情网 | 亚洲精品一区二区三区四区高清 | 久久精品一区二区三区四区 | 午夜影院在线 | 国精品产品区三区 | 久久久久久麻豆 | 97av在线 | 欧美日韩亚洲另类 | 久久综合激情 | 九九亚洲视频 | 免费三片在线观看网站 | 欧美精品www | 中文字幕日韩一区二区不卡 | 久久精品网 | 亚洲伦理一区 | www国产一区 | 国产亚洲一区二区三区在线观看 | 成人免费网站www网站高清 | 黄网在线 | 日韩精品一区二区三区 | 午夜婷婷激情 | 国产一区二区三区在线 | 91精品国产综合久久福利软件 | 国产精品久久久久久久午夜 | 一区二区不卡视频 | 欧洲视频一区二区三区 | 毛片网在线观看 | 99热这里有精品 | 亚洲精品电影网在线观看 | 久久国产精品久久久久久 | 91在线观看视频 | 中文字幕1区 | 国产精品美女在线观看 | 亚洲综合一二区 | 国产精品第一国产精品 | 韩国精品一区 | 97碰碰碰免费公开在线视频 | 欧日韩在线视频 | 免费毛片在线播放 | 国产精品一区二区视频 | 亚洲色图3p| 天天精品 | 国产精品二区一区二区aⅴ污介绍 | 午夜激情福利视频 | 精品久久久久久久久久久久久久 | 欧洲亚洲视频 | 一级片免费在线视频 | 91精品国产日韩91久久久久久 | 大乳videos巨大吃奶 | 精品91| 日本a v网站| 国产精品免费在线 | 91精产国品一二三区在线观看 | 日韩电影在线一区 | 国产一区中文字幕 | 国产91在线 | 亚洲 | 在线欧美色 | 亚洲成人精品 | 国内精品久久久久 | 亚洲欧洲无码一区二区三区 | 国产精品99在线观看 | 一区二区欧美视频 | 国产精品欧美日韩在线观看 | 久久精品成人一区二区三区蜜臀 | 精品九九 | 久草日韩| 两性午夜视频 | 国产精品污www一区二区三区 | 国产精品久久久久久久久久久不卡 | 99精品国产热久久91蜜凸 | 国产精自产拍久久久久久 | 精品日韩一区二区三区 | 色综久久 | 很黄很污的网站 | 99免费观看视频 | 日韩美女av在线 | 日韩欧美在线一区 | 在线视频成人 | 一区二区三区四区av | 国产精品无码久久久久 | 久久亚洲精品裙底抄底 | 国产精品色哟哟哟 | 日韩在线欧美 | 国产精品视频一区二区三区不卡 | 国产一区二区久久久 | 密色视频 | 国产一区二区av | 欧美在线a | 精品国产鲁一鲁一区二区三区 | 蜜桃免费一区二区三区 | www.中文字幕| 欧美日韩二区三区 | 成人免费看黄 | 黄视频网站免费观看 | 国产精品11 | 欧美成人高清视频 | 国产伦精品一区二区三区四区视频 | 色综合欧美 | 欧美一区二区三区在线观看视频 | 四虎最新入口 | 国产欧美一区二区精品性色 | 国产精品久久久久久久久久久久 | 欧美狠狠操 | 不卡一区二区三区视频 | 国产成人精品一区二 | 在线中文字幕日韩 | 日韩欧美国产网站 | 精品国产鲁一鲁一区二区在线观看 | 91成人区 | 欧美精品一区三区 | 亚洲精品国产setv | 一区二区三区有限公司 | 99热国产精品 | 国产精品久久久久久亚洲调教 | 成人免费视频视频在线观看 免费 | 国产精品一区二区三区在线免费观看 | 亚洲精品一区二区网址 | 91精品久久久久久久久久入口 | 成年免费观看视频 | 国产精品永久免费自在线观看 | 国产 欧美 日韩 一区 | 欧美三级视频在线播放 | 男女免费在线观看 | 午夜日韩 | 中文字字幕一区二区三区四区五区 | 日本一区二区精品 | v片网站| 久久久夜夜夜 | 久久国产精品99久久久久久牛牛 | 四虎网址 | av在线一区二区三区 | 国产在线二区 | av在线第一页 | 黄色国产一级片 | 综合久久网 | 亚洲精品一区久久久久久 | 久久99精品久久久久久久青青日本 | 成人欧美一区二区三区在线播放 | 91麻豆精品国产91久久久更新时间 | 国产精品综合 | 久久aⅴ乱码一区二区三区 91综合网 | 午夜爽爽影院 | 91精品久久久久久综合五月天 | 婷婷av网站 | 国产毛片一区二区 | 天天操天天干视频 | 在线成人免费视频 | 国产精品毛片久久久久久久 | 日日做 | 欧美日韩国产一区二区三区 | 欧美午夜在线 | 国产精品久久久久无码av | 欧美一区二区三区在线观看视频 | 国产区在线观看 | 影音先锋成人资源网 | 亚洲激情在线观看 | 国产免费一区二区三区 | 欧美成人精品一区二区三区 | 二区三区 | 欧美视频在线观看一区 | 精品国产精品国产偷麻豆 | 天天操狠狠操 | 日韩三级网| 亚洲精品乱码久久久久久蜜桃不爽 | 日韩 国产 在线 | 国产精品一任线免费观看 | a国产在线 | 2019天天干 | 亚洲精品一区二区三区在线 | 2019中文字幕视频 | 日韩精品视频在线播放 | 午夜影院网站 | 国产区精品 | 天天久久 | 伊人av在线免费观看 | 91在线精品秘密一区二区 | www日批| 成人a在线视频免费观看 | 亚洲视频区 | 久草电影网 | 国产日韩精品视频 | 亚洲精品美女久久 | 国产视频第一页 | 久久久久黄 | 欧美a在线| 久久精品亚洲欧美日韩精品中文字幕 | 亚洲最新中文字幕 | 精品久久一区 | av7777| 国产超碰人人模人人爽人人添 | 精品国产乱码久久久久久久软件 | 国产亚洲精品精品国产亚洲综合 | 在线观看欧美一区二区三区 | 欧美激情一区二区三区 | 欧美精品片 | 日韩欧美一级精品久久 | 免费一区二区 | 成人精品在线视频 | 国产一区二区三区四区五区加勒比 | 日韩在线一区二区三区 | 欧美日韩一区二区在线观看 | 成人免费网站 | 精品久久久久久亚洲综合网站 | 午夜不卡一区二区 | 欧美激情在线精品一区二区三区 | 狠狠操网站 | 国产精品久久久久久一区二区三区 | 成人av教育 | 91视频播放| 成人av观看 | 亚洲97色 | 姐姐在线观看动漫第二集免费 | 黄色一级毛片 | 在线小视频 | 亚洲欧美电影 | 成人精品一区二区三区 | 欧美一区二区三区电影 | 久久精品欧美一区二区三区不卡 | 天堂色网 | 中文字幕一区二区三区乱码在线 | 免费一区二区三区 | 日韩欧美国产精品一区二区三区 | 91久久综合亚洲鲁鲁五月天 | 一区二区三区高清不卡 | 国产精品一区在线观看 | 亚洲午夜精品视频 | 免费成人在线网站 | 国产一区二区三区久久 | 91高清免费 | hd国产人妖ts另类视频 | 欧美日韩中文字幕在线 | 国产伦精品一区二区 | 天天综合永久入口 | 国产一区免费在线观看 | 黄色高清视频在线观看 | 91精品国产乱码久久久久久久久 | 在线观看亚洲一区二区 | 大香伊蕉在人线视频777 | 黄网站免费在线 | 情一色一乱一欲一区二区 | 欧洲精品一区 | 欧美激情国产日韩精品一区18 | 国产区福利 | 久久日本视频 | 精品久久久久久久久久久久 | 欧洲精品 | www一起操| www.日韩视频 | 免费看a | 国产一区二区视频在线播放 | 蜜桃免费一区二区三区 | 精品一区二区三区在线观看视频 | 搡女人真爽免费午夜网站 | 国产成人免费 | 亚洲一区二区三区四区的 | 国产精品18久久久久久久久久久久 | 国产一区二区久久久 | 99国产精品久久久久久久成人热 | 99视频精品 | 国产视频福利在线 | 亚洲三级在线观看 | 久草天堂| 欧美日韩精品一区二区三区 | 久久国产精品一区二区三区 | 一色屋精品久久久久久久久久 | 中文字幕一区二区三区四区五区 | 米奇成人网 | 日韩视频在线观看视频 | 欧美精品色网 | 亚洲精品一区二区三区蜜桃久 | 日本免费视频 | 天天久久| 国产精品久久久久久久免费大片 | 97人人超碰| 精品人成 | 成人精品视频99在线观看免费 | 国产精品一区二区在线看 | 免费久久99精品国产婷婷六月 | 国产精品久久久久久久电影 | 天天天天天天天操 | 伊人激情综合网 | 日韩中文字幕一区二区 | 日韩精品一区二区三区老鸭窝 | 91视频免费看| 99久久免费视频在线观看 | 99亚洲精品 | 天堂一区二区三区 | 亚洲免费在线播放 | 天天色天天看 | 二区欧美 | 亚洲高清视频在线 | 91精品在线看 | 一区二区在线影院 | 中文av在线播放 | 日韩电影一区二区三区 | 久久久久久久久久久久久久久久久久久 | 天天天干天天天操 | 久久综合久久综合久久综合 | 欧美一级c片 | 亚洲高清视频在线观看 | 人人干人人爱 | 日本一区高清 | 99色在线视频 | 欧美成人精品在线 | 91麻豆产精品久久久久久 | 久久久久久九九九九九九 | 国产精品亚洲第一 | 国产一区二区三区久久久 | 久久国产精品一区二区三区 | 色香阁99久久精品久久久 | 国产综合久久久 | 国产一区二区三区四区在线观看 | 成人黄色电影在线观看 | 色婷婷精品国产一区二区三区 | 美女午夜影院 | 亚洲国产精品一区二区三区 | 亚洲激情视频 | 亚洲欧美高清 | 亚洲成人福利在线观看 | 国产精品久久久久久婷婷天堂 | 亚洲精品一区二区三区 | www.日韩视频 | 在线成人av| 91色在线| av基地网| 亚洲免费在线观看 | 99精品99 | 男女激情网址 | 国产区视频在线 | 精品国产一区二区三区性色av | 欧美激情性国产欧美无遮挡 | 不卡的av电影| 亚洲天天干 | 成人av片在线观看 | 欧美日韩精品一区二区 | 午夜电影合集 | 一级片在线观看 | 九九香蕉视频 | 成人av观看 | 久久精品这里热有精品 | 成人免费毛片高清视频 | 亚洲欧美日韩另类精品一区二区三区 | 91cn在线观看 | 在线一级视频 | 国内精品一区二区 | 一级黄色爱爱视频 | 一级免费视频 | 日韩一区二区在线播放 | 成人精品鲁一区一区二区 | 成人欧美日韩一区二区三区 | 91精品一区二区 | 一级片免费视频 | 91久久久久久久久久久 | 7799精品视频 | 蜜桃精品视频在线 | www.操.com | 奇米色欧美一区二区三区 | 黄久久久| 日本高清无卡码一区二区久久 | 精品无码久久久久久国产 | 毛片视频免费 | av网站免费 | 国产欧美精品区一区二区三区 | julia一区二区三区中文字幕 | 中文字幕 国产精品 | 久久九| 国产真实乱全部视频 | 日韩日韩日韩日韩日韩日韩 | 精品国产一区二区三区久久久蜜月 | 日本一区二区在线视频 | 91av官网 | 日本亚洲欧美 | 精品视频久久 | 在线观看羞羞 | 国产成人福利在线观看 | 日韩在线欧美 | 久久9热 | www,99热| 国产日韩精品在线观看 | 日本成人中文字幕在线观看 | 久久麻豆视频 | 国产伊人一区 | 久久久久国产精品免费免费搜索 | 久久久片 | 伊人精品在线 | 热久久这里只有精品 | 国产色在线观看 | 老司机深夜福利视频 | 日韩成人影院 | 亚洲人成人一区二区在线观看 | 中文字幕二区 | 日韩有码在线观看 | 精品久久一区二区 | 亚洲精品一区二区三区蜜桃久 | 欧美高清一区 | 九九久久精品 | 91精品国产综合久久久久久丝袜 | 毛片久久| 午夜婷婷色 | 日韩精品一区二区三区在线播放 | 日韩在线播放一区二区 | 黄色一级毛片 | 91日韩精品一区二区三区 | 欧美色性 | 精品国产一区二区三区四 | 天堂资源 | 视频在线一区二区三区 | 日韩欧美在线观看视频网站 | 一级片视频免费 | 欧美精品一区久久 | 国产精品美女久久久久久免费 | 亚洲成人综合在线 | 成人av免费看| 日韩精品一区二区三区在线播放 | 中文字幕日韩欧美一区二区三区 | 成人在线小视频 | 欧美黄色一区二区 | 成人影院在线 | 国产成在线观看免费视频 | 亚洲视频在线观看免费 | 国产欧美一区二区精品婷 | 国产高清在线看 | 成人午夜啪啪好大 | 国产精品毛片久久久久久久 | av黄色在线看| 偷拍做爰吃奶视频免费看 | 欧洲视频一区二区三区 | aⅴ色国产 欧美 | 国产中文在线 | 中文字幕1区 | 国产一区二区免费 | 九九综合九九 | 经典法国性xxxx精品 | 久久免费小视频 | h视频亚洲| 日本一级淫片免费看 | 香蕉大人久久国产成人av | 韩国三级中文字幕hd久久精品 | 免费的av网站 | 久久久婷 | 日本三级在线观看中文字 | 成人黄色在线观看 | 伊人久久婷婷 | 欧美成人精品一区二区三区 | 蜜月久久99静品久久久久久 | 九九热在线免费视频 | 天堂一区 | 97国产精品视频人人做人人爱 | 欧美视频在线免费看 | 亚洲视频在线一区 | 日韩中文字幕精品 | 日韩国产在线观看 | 成人午夜免费视频 | 日韩中文字幕在线免费观看 | 黑人巨大精品欧美一区免费视频 | 美女天堂 | 99视频精品 | 亚洲综合中文网 | 久久亚洲精品国产一区 | 国产一区在线视频 | 中国1级黄色片 | 午夜激情视频在线观看 | 欧美午夜精品一区二区三区电影 | 国产精品美女www爽爽爽软件 | 91视频免费观看 | 亚洲久久视频 | 亚洲欧美日韩在线一区 | 日日操夜夜操免费视频 | 午夜免费视频网站 | 秋霞a级毛片在线看 | 中文字幕在线三区 | 亚州精品天堂中文字幕 | 在线99视频| 亚洲天天干| 中文字幕一区二区三区不卡 | 久久久久久久久久久久久久久久久久久 | 男女www视频 | 91精品国产乱码久久久久久久久 | 国产精品99在线观看 | 日韩国产一区二区 | 欧美中文字幕一区二区 | 亚洲国产成人久久一区二区三区 | 亚洲免费色 | 久久久久久电影 | 久久久国产一区二区三区 | 国产中文字幕在线 | 欧美日韩精品一区二区三区四区 | 在线一区二区三区视频 | 亚洲美女精品视频 | 99久久免费看视频 | 日韩视频一区二区三区 | 中文字幕亚洲欧美日韩在线不卡 | 国产精品久久免费视频 | 超级碰在线| 日日骚 | 一级黄色影片在线观看 | av中文字幕在线播放 | 蜜桃comaaa | 亚洲 国产 另类 精品 专区 | 欧美精品综合 | 国产高清一区 | 精品一区免费观看 | 久草免费在线视频 | 在线观看三区 | 91玖玖| 久久久久久国产 | 91一级 | 欧美精品在欧美一区二区少妇 | 国产福利在线播放 | 99福利视频 | 草久在线观看 | 日韩高清中文字幕 |