关于SSL登陆的实现

原创 2004年08月09日 11:51:00

主程序如下:

public static void main(String strArgv[])
        throws Exception
    {
        X509TrustManager xtm = new MyTrustManager();
        TrustManager mytm[] =
            {xtm};
        SSLContext ctx = SSLContext.getInstance("SSL");
        ctx.init(null,mytm,null);
        SSLSocketFactory sf = ctx.getSocketFactory();

       URL url = new URL("yourhttpssite");
       HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();
       connection.setSSLSocketFactory(sf);
       connection.setHostnameVerifier(new MyVerified());
       connection.setDoOutput(true);
           BufferedReader in
           = new BufferedReader(new InputStreamReader(connection.getInputStream()));
//       BufferedReader in
//    = new BufferedReader(new InputStreamReader(url.openStream()));
       String line;
       while ((line = in.readLine()) != null) {
           System.out.println(line);
       }
       in.close();
   }

 

------------------------MyTrustManager.java------------------------------------

package com.netutel.ubisp.util;
import javax.net.ssl.*;
import java.net.*;
import java.security.cert.*;
import java.security.cert.CertificateException;

public class MyTrustManager implements X509TrustManager {
    MyTrustManager() { // constructor
        // create/load keystore
    }

    public void checkClientTrusted(X509Certificate chain[], String authType)
        throws CertificateException {
    }

    public void checkServerTrusted(X509Certificate chain[], String authType)
        throws CertificateException {
        // special handling such as poping dialog boxes
    }
    public X509Certificate[] getAcceptedIssuers() {
        return null;
    }
}


-----------------------------MyVerified.java----------------------------------------
package com.netutel.ubisp.util;
import java.net.*;
import java.io.*;
import java.util.*;
import java.io.*;
import java.net.*;
import javax.net.ssl.*;

public class MyVerified implements HostnameVerifier {
    public boolean verify(String hostname, SSLSession session) {
        return true;
    }
}

 

关键在最后一个类HostnameVerifier

具体的文章可以翻看网络的文章

SSL工作原理介绍以及java实现

SSL工作原理介绍以及java实现目录SSL工作原理介绍以及java实现 SSL简介 SSL工作原理 握手协议Handshake protocol 1握手阶段使用RSA加密算法 2握手阶段使用Diff...
  • ENERGIE1314
  • ENERGIE1314
  • 2017年01月17日 11:21
  • 929

shiro实现SSL登陆

个人主页,技术杂谈原文链接考虑项目安全需求,将http请求转为https,项目中已集成的shiro框架已实现SSL登陆,来看下具体实现吧。tomcat的server.xml文件配置。将http的808...
  • chen1218chen
  • chen1218chen
  • 2017年06月20日 09:28
  • 103

JAVA实现SSL身份登录

本部分包含下列主题: JSSE 和 WebLogic Server使用 JNDI 身份验证SSL 证书身份验证开发环境编写使用 SSL 的应用程序SSL 客户端代码示例 ...
  • liaojianbiao
  • liaojianbiao
  • 2013年12月02日 15:19
  • 3091

SSL设置免密登录

一:SSL基本介绍ssh是secure shell的缩写,是建立在应用层和传输层基础上的安全协议,专为远程登录会话和其他网络服务提供安全性的协议。利用ssh协议可以有效地防止远程管理过程中的信息泄露问...
  • u011654631
  • u011654631
  • 2017年04月01日 14:16
  • 734

SSL协议的分析和实现

1引言      SSL是一种在客户端和服务器端之间建立安全通道的协议。SSL一经提出,就在Internet上得到广泛的应用。SSL最常用来保护Web的安全。为了保护存有敏感信息Web的服务器的安...
  • ghevinn
  • ghevinn
  • 2013年10月10日 11:55
  • 4891

C#POP3协议实现SSL验证登陆GMAIL

最近在折腾POP3协议,登陆pop.qq.com和pop.163.com没有什么问题,于是就想着登陆pop.gmail.com,结果失败了。经查,发现gmail的pop3端口不是110,而是995。于...
  • xxdddail
  • xxdddail
  • 2013年07月30日 17:46
  • 2878

SSL协议的分析及实现

1 引言 SSL是一种在客户端和服务器端之间建立安全通道的协议。SSL一经提出,就在Internet上得到广泛的应用。SSL最常用来保护Web的安全。为了保护存有敏感信息Web的服务器的安全,消...
  • weiwei2012start
  • weiwei2012start
  • 2014年01月08日 10:53
  • 1153

Tomcat 配置WebService的HTTPS实现SSL的单双向认证

近日项目上使用Tomcat发布了一个Web Service服务,
  • yidragon88xx
  • yidragon88xx
  • 2014年07月03日 14:07
  • 2107

java实现ssl单/双向认证通信[推荐]

有关SSL的原理和介绍在网上已经有不少,对于Java下使用keytool生成证书,配置SSL通信的教程也非常多。但如果我们不能够亲自动手做一个SSL Sever和SSL Client,可能就永远也不能...
  • zbuger
  • zbuger
  • 2016年06月17日 00:30
  • 2750

java实现ssl双向认证

使用httpclient实现双向认证转载自:http://www.blogjava.net/itvincent/articles/330988.html 1、生成服务器端证书 keytool -g...
  • zhr562343414
  • zhr562343414
  • 2017年03月26日 15:48
  • 436
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于SSL登陆的实现
举报原因:
原因补充:

(最多只允许输入30个字)