当前位置: 首页 > news >正文

管局审核网站名称门户网站的案例分析

管局审核网站名称,门户网站的案例分析,外贸网站排行,网站建设的公司业务用Java发送web请求所用到的包都在java.net下#xff0c;在具体使用时可以用如下代码#xff0c;你可以把它封装成一个工具类 import javax.net.ssl.*; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.Outpu…用Java发送web请求所用到的包都在java.net下在具体使用时可以用如下代码你可以把它封装成一个工具类 import javax.net.ssl.*; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.URL; import java.security.SecureRandom; import java.security.cert.CertificateException; import java.security.cert.X509Certificate;public class Testt {/*HostnameVerifier 是一个Java接口其中的verify方法用来在下面的类中提供主机名的SSL校验这里个人用不做具体校验所有的主机名都给过*/final static HostnameVerifier DO_NOT_VERIFY new HostnameVerifier(){public boolean verify(String arg0, SSLSession arg1) {return true;}};/*trustAllHosts方法 方法创建了一个 TrustManager 接口的匿名实现它是用来检查证书的无论是服务器证书还是客户端证书这通过重写 checkServerTrusted 和 checkClientTrusted 方法为空 不做任何检查*/public static void trustAllHosts() {TrustManager[] trustAllCerts new TrustManager[] {new X509TrustManager(){public X509Certificate[] getAcceptedIssuers() {return new X509Certificate[] {};}public void checkServerTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {}public void checkClientTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {}}};/*SSLContext 使用上述的 TrustManager 初始化一个 SSLContext 实例并将其设置为 HttpsURLConnection 的默认 SSLSocketFactory这允许 HttpsURLConnection 信任所有SSL证书TLS是握手协议的一种*/try {SSLContext sc SSLContext.getInstance(TLS);sc.init(null, trustAllCerts, new SecureRandom());HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());}catch (Exception e) {e.printStackTrace();}}/*** 发出请求的具体方法* param urlPath https协议接口的路径 https://xxxxxx* param Json 发出请求需要携带的参数需要是Json格式* return*/public static String doPostToJson(String urlPath, String Json) {String result ;BufferedReader reader null;HttpURLConnection conn null;try {/*掉用上面的静态方法使得请求发出时作为调用者的我们对服务端所拥有的任何https证书都是兼容的这里说一句题外话一般情况下作为接口使用者trustAllHosts方法里面的代码是不变的因为你作为使用者总没道理说让人家服务端兼容你什么除非你是证书的使用者不过这种情况会有证书厂商告诉你如何做不得不说厂商服务是个好东西*/trustAllHosts();URL url new URL(urlPath);/*如果协议是 https则使用 HttpsURLConnection 并设置 HostnameVerifier 为 DO_NOT_VERIFY。否则使用 HttpURLConnection*/if (url.getProtocol().toLowerCase().equals(https)) {HttpsURLConnection httpsConn (HttpsURLConnection) url.openConnection();httpsConn.setHostnameVerifier(DO_NOT_VERIFY);conn httpsConn;}else {conn (HttpURLConnection) url.openConnection();}// 设置请求以POST形式发出conn.setRequestMethod(POST);// 是否携带请求提POST和GET请求必须为trueconn.setDoOutput(true);// 是否会获取服务端的响应默认是trueconn.setDoInput(true);//禁用缓存conn.setUseCaches(false);// Keep-Alive告诉服务端对已有的TCP连接保持一定时间的活性以保障后续发出的请求不需要建立新的TCP连接从而减少网络开销conn.setRequestProperty(Connection, Keep-Alive);//字符集这个配置不是标准的请求头但是有些妖孽系统会读取这个conn.setRequestProperty(Charset, UTF-8);// 这个是请求格式告诉服务端这个请求发送的是Json数据以及字符集conn.setRequestProperty(Content-Type, application/json; charsetUTF-8);// 告诉服务端相应格式也希望是json格式conn.setRequestProperty(accept, application/json);//如果参数不为空则将参数以字节数流的方式写入请求体里面if (Json ! null) {byte[] writebytes Json.getBytes();conn.setRequestProperty(Content-Length, String.valueOf(writebytes.length));OutputStream outwritestream conn.getOutputStream();outwritestream.write(Json.getBytes());outwritestream.flush();outwritestream.close();}//读取响应相应数据也是一个jsonif (conn.getResponseCode() 200) {reader new BufferedReader(new InputStreamReader(conn.getInputStream(), utf-8));result reader.readLine();}}catch (Exception e) {e.printStackTrace();}finally {//读取相应用的输入流需要在这里关闭而写入请求参数的输出流是随用随关的if (reader ! null) {try {reader.close();conn.disconnect();}catch (IOException e) {e.printStackTrace();}}}return result;}}对于上面的代码重点要说明的第一点是HostnameVerifier接口提供的方法它主要用于访问https协议下的接口时验证当前已和你建立连接的hostname主机名和连接的SSLSessionSSL会话证书是否匹配防止中间人攻击比如可以如下操作 import javax.net.ssl.HostnameVerifier; import javax.net.ssl.HttpsURLConnection; import javax.net.ssl.SSLSession; import java.io.IOException; import java.net.URL;public class HostnameVerifierExample {public static void main(String[] args) {try {// 创建一个URL对象URL url new URL(https://xxxxx);// 打开HTTPS连接HttpsURLConnection connection (HttpsURLConnection) url.openConnection();// 设置自定义的HostnameVerifierHostnameVerifier customVerifier new HostnameVerifier() {Overridepublic boolean verify(String hostname, SSLSession session) {// 在这里实现你的验证逻辑// 例如你可以比较hostname和session中的证书信息// 为了简单起见这里我们直接接受任何主机名不推荐这样做有安全风险// 在实际应用中你应该根据你的安全策略来实现这个逻辑// 比如你可以检查hostname是否与你预期的服务器主机名匹配// 或者你可以使用HttpsURLConnection.getDefaultHostnameVerifier()来获取默认的验证器并基于它的结果进行扩展// 这是一个不安全的示例仅用于说明如何使用verify方法// 在实际应用中你应该避免这样做return true; // 更安全的做法可能是这样的// if (expected.hostname.equals(hostname)) {// return true;// } else {// HostnameVerifier defaultVerifier HttpsURLConnection.getDefaultHostnameVerifier();// return defaultVerifier.verify(hostname, session);// }}};// 设置自定义的HostnameVerifier到连接中connection.setHostnameVerifier(customVerifier);// 继续处理HTTPS连接比如读取响应等// ...// 关闭连接connection.disconnect();} catch (IOException e) {e.printStackTrace();}} }第二是trustAllHosts方法里面的东西,TrustManager是用来实现证书验证的类X509TrustManager是X.509 证书的验证实现通俗的讲是一个基础的证书因此我上面的代码中也说了如果你是正式的https证书使用者会有厂商服务告诉你怎么验证证书在X509TrustManager 中提供了三个方法 getAcceptedIssuers()返回此信任管理器接受的发行者证书根证书或中间证书数组。在上面的代码中这个方法返回了一个空数组意味着它不做任何特定的发行者证书获取checkServerTrusted(X509Certificate[] certs, String authType)验证服务器提供的证书链是否可信。在代码中这个方法被空实现了意味着不会进行任何验证。checkClientTrusted(X509Certificate[] certs, String authType)验证客户端提供的证书链是否可信在需要客户端证书的情况下。同样在代码中这个方法也被空实现了
http://www.hkea.cn/news/14539245/

相关文章:

  • 徐州网站制作功能企业网站的类型
  • 做网站的荣誉证书wordpress添加cnzz
  • 外贸网站怎么做谷歌搜索网站建设视频教程网站
  • 手机触屏网站开发dede网站重新安装
  • 建网站策划方案上虞网站设计
  • 四川做网站的上海seo推广整站
  • 织梦电影网站模板下载做阿里巴巴网站要多少钱
  • 美妆网站设计模板足彩网站建设
  • 网站建设宝典聊城专业网站建设
  • 怎么把网站横幅做很大公司做网站需要注意什么
  • 网站维护意义wordpress与drupal对比
  • 学生校园网站模板公司网站的开发策略
  • 婚庆网站html模板龙岩天宫山住宿怎么订
  • vscode的网站开发配置用一个口罩做一把枪
  • 西北电力建设第一工程公司网站云南最近出了什么流行病
  • 东城区网站建设关于公司网络优化方案
  • 上海网站的优化公司哪家好国内各大网站
  • 网站备案被注销 接入商为学校网站做网站推广策划
  • 宁阳网站定制响应式网站软件
  • 哪里有做网站服务商重庆教育建设集团有限公司网站
  • 唐山网站建设学徒高邮城乡建设网站
  • 微舍 微网站 怎么做ftp备份网站
  • 网站装修怎么做点菜网站模板
  • 有哪些专做旅游定制的网站wordpress模板破解版
  • 微信小程序免费开店详细步骤广东seo
  • 用软件什么做网站wordpress 更改自带域名
  • 百度对新网站排名问题湖南省建设厅网站首页
  • 企业网站推广文案上海建筑网站建设
  • 专业做律师网站的公司企业网站seo实
  • 个人做网站费用营销型网站开发