`
月下独酌
  • 浏览: 130959 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

android https之二

 
阅读更多
android https之一
android https之二
android https之三
	private HttpClient makeHttpsClient(String keyStorePasswd, int port) {
		try {
			KeyStore trustStore = KeyStore.getInstance(KeyStore
					.getDefaultType());
			String trustStorePath = System
					.getProperty("javax.net.ssl.trustStore");
			// File keystoreFile = new File(trustStorePath);
			// 由于android权限原因,无法读取trustStorePath="//system/etc/security/cacerts.bks"文件,此处由sdcard代替
			File keystoreFile = new File("/sdcard/cacerts.bks");
			trustStore.load(new FileInputStream(keystoreFile), keyStorePasswd
					.toCharArray());
			SSLSocketFactory socketFactory = new SSLSocketFactory(trustStore);
			socketFactory.setHostnameVerifier(new X509HostnameVerifier() {
				public boolean verify(String host, SSLSession session) {
					return true;
				}

				public void verify(String host, SSLSocket ssl)
						throws IOException {
				}

				public void verify(String host, X509Certificate cert)
						throws SSLException {
				}

				public void verify(String host, String[] cns,
						String[] subjectAlts) throws SSLException {
				}
			});
			Scheme sch = new Scheme("https", socketFactory, port);
			HttpClient httpClient = new DefaultHttpClient();
			httpClient.getConnectionManager().getSchemeRegistry().register(sch);
			return httpClient;
		} catch (KeyStoreException e) {
			Log.e("xx", e.getMessage());
		} catch (NoSuchAlgorithmException e) {
			Log.e("xx", e.getMessage());
		} catch (CertificateException e) {
			Log.e("xx", e.getMessage());
		} catch (KeyManagementException e) {
			Log.e("xx", e.getMessage());
		} catch (UnrecoverableKeyException e) {
			Log.e("xx", e.getMessage());
		} catch (IOException e) {
			Log.e("xx", e.getMessage());
		}
		return null;
	}

	private void sendrequest() {
		try {
			HttpClient httpClient = makeHttpsClient("changeit", 8443);
			HttpPost httpPost = makeHttpPost("https://10.167.17.187:8443");
			HttpResponse response;
			response = httpClient.execute(httpPost);

			if (response != null) {
				Log.i("xx", "" + response.getStatusLine().getStatusCode());
			} else {
				Log.i("xx", "NULL");
			}
		} catch (ClientProtocolException e) {
			Log.e("xx", e.getMessage());
		} catch (IOException e) {
			Log.e("xx", e.getMessage());
		}
	}

分享到:
评论
2 楼 月下独酌 2012-09-26  
sxchao2008 写道
/sdcard/cacerts.bks 这个证书可以到网上随便下一个吗? 如果不行 该如何生成? 我需要客户端通过https连接server端 。是否在server端也需要这么一个证书?

bks是android系统使用的证书库文件格式,是用来存储密钥key的。

在服务器端配置https的时候可以使用其他格式的证书库,比如jks格式的,这个和客户端没关系。

android系统中有一个自带的bks文件,root以后可以直接拿出来,在//system/etc/security/cacerts.bk这个目录下,默认密码是changeit,当然在网上随意下载一个也可以,但是要知道证书库的密码。

如果要自己制作bks证书库文件的话,请参考http://blog.csdn.net/hezhipin610039/article/details/7074000
1 楼 sxchao2008 2012-09-26  
/sdcard/cacerts.bks 这个证书可以到网上随便下一个吗? 如果不行 该如何生成? 我需要客户端通过https连接server端 。是否在server端也需要这么一个证书?

相关推荐

    Android中Https请求get和post

    在Android开发中,HTTPS协议是实现安全网络通信的重要方式,主要用来保护数据的传输安全,防止数据被中间人窃取或篡改。本篇将详细讲解Android中如何使用HTTPS进行GET和POST请求。 首先,HTTPS基于SSL/TLS协议,...

    Android Https通信改进版

    在Android开发中,HTTPS通信是保护用户数据安全的重要手段,特别是在传输敏感信息如登录凭证、个人信息等时。本文将深入探讨Android中HTTPS通信的改进版,以提高应用的安全性和性能。 首先,理解HTTPS的核心概念至...

    android https 双向验证

    在Android开发中,HTTPS协议是用于安全网络通信的重要手段,它可以保护数据的隐私性和完整性,防止中间人攻击。然而,通常的HTTPS连接仅进行单向验证,即客户端验证服务器的身份,而服务器并不验证客户端。但在某些...

    Android代码-Android SVG library

    Sharp Sharp is a Scalable Vector ...https://github.com/pents90/svg-android Merged changes from forks: https://github.com/b2renger/svg-android https://github.com/mindon/svg-android https://github.com

    AndroidHttps服务器端和客户端简单实例

    在Android开发中,HTTPS协议常用于确保数据传输的安全性,防止数据被窃取或篡改。本实例将探讨如何在Android环境下实现HTTPS服务器端和客户端的简单交互,支持单向和双向验证。以下是对实现这一功能所需的知识点的...

    android+https的例子

    2. **HttpURLConnection与HTTPS**: 自Android 2.3(API级别9)开始,`HttpURLConnection`成为推荐的网络通信方式,因为它更高效且易于使用。启用HTTPS的方式是将URL设置为`https://`开头,然后调用`...

    Android高薪之路:Android程序员面试宝典 李宁

    《Android高薪之路:Android程序员面试宝典》目录: 第1章 Android入门 1 1 关于Android的非技术问题 1 1 1 为什么看好 Android 1 1 2 以前是否从事过Android的工作 做过哪些工作 1 1 3 你做的最复杂的界面是什么 1 ...

    android https遇到自签名证书/信任证书

    在正常情况下,服务器会提供由权威证书颁发机构(CA)签发的数字证书,客户端(如Android设备)会验证这个证书的有效性,确保与之通信的服务器是真实的,而非中间人攻击。 二、自签名证书 自签名证书是由服务器自身...

    Android Studio Chipmunk (android-studio-2021.2.1.10-mac_arm.p2)

    Android Studio Chipmunk (2021.2.1) Beta 3 (android-studio-2021.2.1.10-mac_arm.zip)花栗鼠 适用于macOS Arm芯片系统,文件分割成两个压缩包,必须一起解压使用: Android Studio Chipmunk (android-studio-...

    Android实现https网络访问

    Android实现https网络访问,四种实现方式:1、客户端添加指定信任cer证书。2、客户端信任所有证书。3、HttpClient方式实现,支持所有Https免验证方式链接(与2类似,只不过采用HttpClient方式实现)。4、HttpClient...

    Android Studio Chipmunk (android-studio-2021.2.1.10-mac.part1)

    Android Studio Chipmunk (2021.2.1) Beta 3 (android-studio-2021.2.1.10-mac.zip)花栗鼠 适用于macOS Intel芯片系统,文件分割成两个压缩包,必须一起解压使用: Android Studio Chipmunk (android-studio-2021...

    android 使用webview控件,注意在android9.0以后必须使用https才能访问网页

    在Android应用开发中,WebView控件是一个非常重要的组件,它允许开发者在应用程序内嵌入一个浏览器,以便用户能够浏览网页内容。然而,随着网络安全性的不断提升,Android系统对WebView的使用也有了更严格的要求。在...

    android客户端发送https请求

    2. **创建TrustManager**:Android系统默认只信任预装的CA证书,若服务器使用自签名证书,我们需要自定义TrustManager,接受该特定的证书。创建一个继承X509TrustManager的类,重写checkServerTrusted方法,添加对...

    android-studio-2022.2.1.18-mac.part2.rar

    Android Studio Flamingo 2022.2.1(android-studio-2022.2.1.18-mac.dmg) 适用于macOS Intel芯片系统,文件使用WinRAR分割两个压缩包,必须一起下载使用。在macOS使用WinZip进行解压: Android Studio Flamingo...

    Android Studio Chipmunk (android-studio-2021.2.1.15-mac.part1)

    Android Studio Chipmunk 2021.2.1(android-studio-2021.2.1.15-mac.dmg)花栗鼠 适用于macOS Intel芯片系统,文件使用WinRAR分割成两个压缩包,必须一起下载使用。在macOS使用WinZip进行解压: Android Studio ...

    android-x86-64-9.0-r2.iso

    这个版本号"9.0"指的是Android Pie (API级别28),而"r2"可能是发布候选版或修订版的标识,意味着这是该版本的第二个修订。 描述中提到可以从"https://www.android-x86.org/download.html"下载,这是一个专门提供...

    android-26 对应android8

    2. **后台限制(Background Execution Limits)**:为了延长电池寿命和提高系统性能,Android 8.0对后台应用的执行进行了限制。包括限制后台服务的启动、限制BroadcastReceiver的使用以及限制后台位置更新等,这对...

    Android Studio Chipmunk (android-studio-2021.2.1.9-mac.part2)

    Android Studio Chipmunk (2021.2.1) Beta 2 (android-studio-2021.2.1.9-mac)花栗鼠 适用于macOS Intel芯片系统,文件分割成两个压缩包,必须一起下载两个压缩包进行解压使用: android-studio-2021.2.1.9-mac....

    android-studio-2022.2.1.18-mac-arm.part2.rar

    Android Studio Flamingo 2022.2.1(android-studio-2022.2.1.18-mac_arm.dmg) 适用于macOS Arm芯片系统,文件使用WinRAR分割两个压缩包,必须一起下载使用。在macOS使用WinZip进行解压: Android Studio Flamingo...

Global site tag (gtag.js) - Google Analytics