JAVA发送HttpClient
http://bijian1013.iteye.com/blog/2310211
在发送HTTP请求的时候会使用到POST和GET两种方式,如果是传送普通的表单数据,我们直接将参数到一个Key-value形式的Map中即可,随着JSON的应用越来越广,我们在很多场合需要传送JSON格式的参数。
下面我使用HttpClient类库提供的功能来实现这个,以便以后参考。
一.完善SpringMVC工程
完善SpringMVC工程(修改之前的Spring工程地址:http://bijian1013.iteye.com/blog/2307353),使其不仅支持GET、POST两种方式的请求,且支持普通表单数据请求和JSON格式的两种请求数据,完整工程代码见附件《SpringMVC.zip》,日志相关的依赖jar包可直接从HttpClient.zip中获取到。
- @Controller
- public class HelloController {
- private static Logger logger = LoggerFactory.getLogger(HelloController.class);
- @Autowired
- private HelloService helloService;
- @RequestMapping("/greeting")
- public ModelAndView greeting(@RequestParam(value = "name", defaultValue = "World") String name) {
- Map<String, Object> map = new HashMap<String, Object>();
- try {
- //由于浏览器会把中文直接换成ISO-8859-1编码格式,如果用户在地址打入中文,需要进行如下转换处理
- String tempName = new String(name.getBytes("ISO-8859-1"), "utf-8");
- logger.trace("tempName:" + tempName);
- logger.info(tempName);
- String userName = helloService.processService(tempName);
- map.put("userName", userName);
- logger.trace("运行结果:" + map);
- } catch (UnsupportedEncodingException e) {
- logger.error("HelloController greeting方法发生UnsupportedEncodingException异常:" + e);
- } catch (Exception e) {
- logger.error("HelloController greeting方法发生Exception异常:" + e);
- }
- return new ModelAndView("/hello", map);
- }
- @RequestMapping(value="/processing", method = RequestMethod.POST)
- public ModelAndView processing(HttpServletRequest request, HttpServletResponse response) {
- Enumeration en = request.getParameterNames();
- while (en.hasMoreElements()) {
- String paramName = (String) en.nextElement();
- String paramValue = request.getParameter(paramName);
- }
- String name = request.getParameter("name");
- String age = request.getParameter("age");
- UserDTO userDTO = new UserDTO();
- userDTO.setName(name);
- userDTO.setAge(Integer.valueOf(age));
- logger.info("process param is :{}" + userDTO);
- Map<String, Object> map = new HashMap<String, Object>();
- try {
- userDTO = helloService.processService(userDTO);
- //返回请求结果
- map.put("name", userDTO.getName());
- map.put("age", userDTO.getAge());
- } catch (Exception e) {
- logger.info("请求处理异常:" + e);
- }
- return new ModelAndView("/user", map);
- }
- /**
- * @responseBody表示该方法的返回结果直接写入HTTP response body中
- * 一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径
- * 加上@responseBody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。
- * 比如异步获取json数据,加上@responsebody后,会直接返回json数据。
- */
- @ResponseBody
- @RequestMapping(value="/greet",method = RequestMethod.GET)
- public Map<String, Object> greet(HttpServletRequest request, HttpServletResponse response,
- @RequestParam(value = "name", defaultValue = "World") String name) {
- Map<String, Object> map = null;
- try {
- //由于浏览器会把中文直接换成ISO-8859-1编码格式,如果用户在地址打入中文,需要进行如下转换处理
- String tempName = new String(name.getBytes("ISO-8859-1"), "utf-8");
- logger.trace("tempName:" + tempName);
- logger.info(tempName);
- String userName = helloService.processService(tempName);
- map = new HashMap<String, Object>();
- map.put("userName", userName);
- logger.trace("运行结果:" + map);
- } catch (UnsupportedEncodingException e) {
- logger.error("HelloController greet方法发生UnsupportedEncodingException异常:" + e);
- } catch (Exception e) {
- logger.error("HelloController greet方法发生Exception异常:" + e);
- }
- return map;
- }
- @ResponseBody
- @RequestMapping(value="/process",method = RequestMethod.POST)
- public String process(HttpServletRequest request, @RequestBody String requestBody) {
- logger.info("process param is :{}" + requestBody);
- JSONObject result = new JSONObject();
- try {
- JSONObject jsonObject = JSONObject.fromObject(requestBody);
- UserDTO userDTO = (UserDTO) JSONObject.toBean(jsonObject, UserDTO.class);
- userDTO = helloService.processService(userDTO);
- //返回请求结果
- result.put("status", "SUCCESS");
- result.put("userDTO", userDTO);
- } catch (Exception e) {
- logger.info("请求处理异常! params is:{}", requestBody);
- result.put("status", "FAIL");
- }
- return result.toString();
- }
- }
二.HttpClient请求普通的表单数据,返回HTML页面
- package com.bijian.study;
- import java.io.BufferedReader;
- import java.io.IOException;
- import java.io.InputStreamReader;
- import java.util.Map;
- import org.apache.commons.httpclient.DefaultHttpMethodRetryHandler;
- import org.apache.commons.httpclient.Header;
- import org.apache.commons.httpclient.HttpClient;
- import org.apache.commons.httpclient.HttpException;
- import org.apache.commons.httpclient.HttpMethod;
- import org.apache.commons.httpclient.HttpStatus;
- import org.apache.commons.httpclient.NameValuePair;
- import org.apache.commons.httpclient.methods.GetMethod;
- import org.apache.commons.httpclient.methods.PostMethod;
- import org.apache.commons.httpclient.params.HttpMethodParams;
- import org.apache.http.client.methods.HttpPost;
- /**
- * Http请求工具类
- * 请求的是普通的表单数据,返回HTML页面
- *
- * 需要导入commons-codec-1.3.jar
- */
- public class HttpClientUtil {
- /**
- * httpClient的get请求方式
- *
- * @param url
- * @param charset
- * @return
- * @throws Exception
- */
- public static String doGet(String url, String charset) throws Exception {
- HttpClient client = new HttpClient();
- GetMethod method = new GetMethod(url);
- if (null == url || !url.startsWith("http")) {
- throw new Exception("请求地址格式不对");
- }
- // 设置请求的编码方式
- if (null != charset) {
- method.addRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=" + charset);
- } else {
- method.addRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=" + "utf-8");
- }
- int statusCode = client.executeMethod(method);
- if (statusCode != HttpStatus.SC_OK) {// 打印服务器返回的状态
- System.out.println("Method failed: " + method.getStatusLine());
- }
- // 返回响应消息
- byte[] responseBody = method.getResponseBodyAsString().getBytes(method.getResponseCharSet());
- // 在返回响应消息使用编码(utf-8或gb2312)
- String response = new String(responseBody, "utf-8");
- System.out.println("------------------response:" + response);
- // 释放连接
- method.releaseConnection();
- return response;
- }
- /**
- * httpClient的get请求方式2
- *
- * @param url
- * @param charset
- * @return
- * @throws Exception
- */
- public static String doGet2(String url, String charset) throws Exception {
- /*
- * 使用 GetMethod 来访问一个 URL 对应的网页,实现步骤: 1:生成一个 HttpClinet 对象并设置相应的参数。
- * 2:生成一个 GetMethod 对象并设置响应的参数。 3:用 HttpClinet 生成的对象来执行 GetMethod 生成的Get
- * 方法。 4:处理响应状态码。 5:若响应正常,处理 HTTP 响应内容。 6:释放连接。
- */
- /* 1 生成 HttpClinet 对象并设置参数 */
- HttpClient httpClient = new HttpClient();
- // 设置 Http 连接超时为5秒
- httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(5000);
- /* 2 生成 GetMethod 对象并设置参数 */
- GetMethod getMethod = new GetMethod(url);
- // 设置 get 请求超时为 5 秒
- getMethod.getParams().setParameter(HttpMethodParams.SO_TIMEOUT, 5000);
- // 设置请求重试处理,用的是默认的重试处理:请求三次
- getMethod.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, new DefaultHttpMethodRetryHandler());
- String response = "";
- /* 3 执行 HTTP GET 请求 */
- try {
- int statusCode = httpClient.executeMethod(getMethod);
- /* 4 判断访问的状态码 */
- if (statusCode != HttpStatus.SC_OK) {
- System.err.println("Method failed: " + getMethod.getStatusLine());
- }
- /* 5 处理 HTTP 响应内容 */
- // HTTP响应头部信息,这里简单打印
- Header[] headers = getMethod.getResponseHeaders();
- for (Header h : headers)
- System.out.println(h.getName() + "------------ " + h.getValue());
- // 读取 HTTP 响应内容,这里简单打印网页内容
- byte[] responseBody = getMethod.getResponseBody();// 读取为字节数组
- response = new String(responseBody, charset);
- System.out.println("----------response:" + response);
- // 读取为 InputStream,在网页内容数据量大时候推荐使用
- // InputStream response = getMethod.getResponseBodyAsStream();
- } catch (HttpException e) {
- // 发生致命的异常,可能是协议不对或者返回的内容有问题
- System.out.println("Please check your provided http address!");
- e.printStackTrace();
- } catch (IOException e) {
- // 发生网络异常
- e.printStackTrace();
- } finally {
- /* 6 .释放连接 */
- getMethod.releaseConnection();
- }
- return response;
- }
- /**
- * 执行一个HTTP POST请求,返回请求响应的HTML
- *
- * @param url 请求的URL地址
- * @param params 请求的查询参数,可以为null
- * @param charset 字符集
- * @param pretty 是否美化
- * @return 返回请求响应的HTML
- */
- public static String doPost(String url, Map<String, Object> _params, String charset, boolean pretty) {
- StringBuffer response = new StringBuffer();
- HttpClient client = new HttpClient();
- PostMethod method = new PostMethod(url);
- // 设置Http Post数据
- if (_params != null) {
- for (Map.Entry<String, Object> entry : _params.entrySet()) {
- method.setParameter(entry.getKey(), String.valueOf(entry.getValue()));
- }
- }
- // 设置Http Post数据 方法二
- // if(_params != null) {
- // NameValuePair[] pairs = new NameValuePair[_params.size()];//纯参数了,键值对
- // int i = 0;
- // for (Map.Entry<String, Object> entry : _params.entrySet()) {
- // pairs[i] = new NameValuePair(entry.getKey(), String.valueOf(entry.getValue()));
- // i++;
- // }
- // method.addParameters(pairs);
- // }
- try {
- client.executeMethod(method);
- if (method.getStatusCode() == HttpStatus.SC_OK) {
- // 读取为 InputStream,在网页内容数据量大时候推荐使用
- BufferedReader reader = new BufferedReader(new InputStreamReader(method.getResponseBodyAsStream(),
- charset));
- String line;
- while ((line = reader.readLine()) != null) {
- if (pretty)
- response.append(line).append(System.getProperty("line.separator"));
- else
- response.append(line);
- }
- reader.close();
- }
- } catch (IOException e) {
- System.out.println("执行HTTP Post请求" + url + "时,发生异常!");
- e.printStackTrace();
- } finally {
- method.releaseConnection();
- }
- System.out.println("--------------------" + response.toString());
- return response.toString();
- }
- }
测试类HttpClientTest.java
- package com.bijian.study;
- import java.util.HashMap;
- import java.util.Map;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- public class HttpClientTest {
- private static Logger logger = LoggerFactory.getLogger(HttpRequestTest.class);
- public static void main(String[] args) {
- getRequestTest();
- getRequestTest2();
- postRequestTest();
- }
- private static void getRequestTest() {
- String url = "http://localhost:8080/SpringMVC/greeting?name=lisi";
- try {
- String str = HttpClientUtil.doGet(url, "UTF-8");
- if (str != null) {
- logger.info("http Get request result:" + str);
- } else {
- logger.info("http Get request process fail");
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- private static void getRequestTest2() {
- String url = "http://localhost:8080/SpringMVC/greeting?name=lisi";
- try {
- String str = HttpClientUtil.doGet2(url, "UTF-8");
- if (str != null) {
- logger.info("http Get request result:" + str);
- } else {
- logger.info("http Get request process fail");
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- private static void postRequestTest() {
- String url = "http://localhost:8080/SpringMVC/processing";
- Map<String, Object> _params = new HashMap<String, Object>();
- _params.put("name", "zhangshang");
- _params.put("age", 25);
- String str = HttpClientUtil.doPost(url, _params, "UTF-8", true);
- if (str != null) {
- logger.info("http Post request result:" + str);
- } else {
- logger.info("http Post request process fail");
- }
- }
- }
三.HttpClient请求json数据返回json数据
- package com.bijian.study;
- import java.io.IOException;
- import java.net.URLDecoder;
- import net.sf.json.JSONObject;
- import org.apache.http.HttpResponse;
- import org.apache.http.HttpStatus;
- import org.apache.http.client.methods.HttpGet;
- import org.apache.http.client.methods.HttpPost;
- import org.apache.http.entity.StringEntity;
- import org.apache.http.impl.client.DefaultHttpClient;
- import org.apache.http.util.EntityUtils;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- /**
- * Http请求工具类,发送json返回json
- *
- * 除了要导入json-lib-2.1.jar之外,还必须有其它几个依赖包:
- * commons-beanutils.jar
- * commons-httpclient.jar
- * commons-lang.jar
- * ezmorph.jar
- * morph-1.0.1.jar
- * 另外,commons-collections.jar也需要导入
- */
- public class HttpRequestUtil {
- private static Logger logger = LoggerFactory.getLogger(HttpRequestUtil.class);
- /**
- * 发送get请求
- * @param url 路径
- * @return
- */
- public static JSONObject httpGet(String url){
- //get请求返回结果
- JSONObject jsonResult = null;
- try {
- DefaultHttpClient client = new DefaultHttpClient();
- //发送get请求
- HttpGet request = new HttpGet(url);
- HttpResponse response = client.execute(request);
- /**请求发送成功,并得到响应**/
- if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
- /**读取服务器返回过来的json字符串数据**/
- String strResult = EntityUtils.toString(response.getEntity());
- /**把json字符串转换成json对象**/
- jsonResult = JSONObject.fromObject(strResult);
- url = URLDecoder.decode(url, "UTF-8");
- } else {
- logger.error("get请求提交失败:" + url);
- }
- } catch (IOException e) {
- logger.error("get请求提交失败:" + url, e);
- }
- return jsonResult;
- }
- /**
- * httpPost
- * @param url 路径
- * @param jsonParam 参数
- * @return
- */
- public static JSONObject httpPost(String url,JSONObject jsonParam){
- return httpPost(url, jsonParam, false);
- }
- /**
- * post请求
- * @param url url地址
- * @param jsonParam 参数
- * @param noNeedResponse 不需要返回结果
- * @return
- */
- public static JSONObject httpPost(String url,JSONObject jsonParam, boolean noNeedResponse){
- //post请求返回结果
- DefaultHttpClient httpClient = new DefaultHttpClient();
- JSONObject jsonResult = null;
- HttpPost method = new HttpPost(url);
- try {
- if (null != jsonParam) {
- //解决中文乱码问题
- StringEntity entity = new StringEntity(jsonParam.toString(), "utf-8");
- entity.setContentEncoding("UTF-8");
- entity.setContentType("application/json");
- method.setEntity(entity);
- }
- HttpResponse result = httpClient.execute(method);
- url = URLDecoder.decode(url, "UTF-8");
- /**请求发送成功,并得到响应**/
- if (result.getStatusLine().getStatusCode() == 200) {
- String str = "";
- try {
- /**读取服务器返回过来的json字符串数据**/
- str = EntityUtils.toString(result.getEntity());
- if (noNeedResponse) {
- return null;
- }
- /**把json字符串转换成json对象**/
- jsonResult = JSONObject.fromObject(str);
- } catch (Exception e) {
- logger.error("post请求提交失败:" + url, e);
- }
- }
- } catch (IOException e) {
- logger.error("post请求提交失败:" + url, e);
- }
- return jsonResult;
- }
- }
测试类HttpRequestTest.java
- package com.bijian.study;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import net.sf.json.JSONObject;
- import com.bijian.study.dto.UserDTO;
- /**
- * Http请求测试类
- */
- public class HttpRequestTest {
- private static Logger logger = LoggerFactory.getLogger(HttpRequestTest.class);
- public static void main(String[] args) {
- getRequestTest();
- postRequestTest();
- }
- private static void getRequestTest() {
- String url = "http://localhost:8080/SpringMVC/greet?name=lisi";
- JSONObject jsonObject = HttpRequestUtil.httpGet(url);
- if(jsonObject != null) {
- String userName = (String) jsonObject.get("userName");
- logger.info("http Get request process sucess");
- logger.info("userName:" + userName);
- }else {
- logger.info("http Get request process fail");
- }
- }
- private static void postRequestTest() {
- String url = "http://localhost:8080/SpringMVC/process";
- UserDTO userDTO = new UserDTO();
- userDTO.setName("zhangshang");
- userDTO.setAge(25);
- JSONObject jsonParam = JSONObject.fromObject(userDTO);
- JSONObject responseJSONObject = HttpRequestUtil.httpPost(url, jsonParam);
- if(responseJSONObject != null && "SUCCESS".equals(responseJSONObject.get("status"))) {
- JSONObject userStr = (JSONObject) responseJSONObject.get("userDTO");
- userDTO = (UserDTO) JSONObject.toBean(userStr, UserDTO.class);
- logger.info("http Post request process sucess");
- logger.info("userDTO:" + userDTO);
- }else {
- logger.info("http Post request process fail");
- }
- }
- }
完整的工程代码请下载附件《HttpClient.zip》。
四.补充说明
1.如果会出现异常:java.lang.NoClassDefFoundError: net/sf/ezmorph/Morpher,原因是少了JAR包,造成类找不到,除了要导入JSON网站上面下载的json-lib-2.1.jar包之外,还必须有其它几个依赖包:
- commons-beanutils.jar
- commons-httpclient.jar
- commons-lang.jar
- ezmorph.jar
- morph-1.0.1.jar
2.@responseBody表示该方法的返回结果直接写入HTTP response body中。一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@responseBody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@responsebody后,会直接返回json数据。
3.关于HttpClient的其它方面的学习使用,可以参考:http://www.iteblog.com/archives/1379。附件《httpclientutil.zip》就是从这里下载的。
4.在实际使用当中,我们可能需要随机变换请求数据,甚至随机请求不同的服务器,可以参考如下方式。
- public static void main(String arg[]) throws Exception {
- while (true) {
- String[] urlArray = {Constant.URL_1, Constant.URL_2};
- int index = new Random().nextInt(2);
- String requestUrl = urlArray[index];
- System.out.println(requestUrl);
- ...
- JSONObject jsonMsg = JSONObject.fromObject(obj);
- String ret = HttpRequestUtil.doPost(requestUrl, jsonMsg);
- System.out.println(ret);
- Thread.sleep(50);
- }
- }
Constant.java
- public class Constant {
- public static final String URL_1 = PropertiesFileUtil.getPropValue("url1", "config");
- public static final String URL_2 = PropertiesFileUtil.getPropValue("url2", "config");
- }
- import java.util.ResourceBundle;
- import org.apache.commons.lang.StringUtils;
- public final class PropertiesFileUtil {
- public static String getPropValue(String keyName, String propsName) {
- ResourceBundle resource = ResourceBundle.getBundle(propsName);
- String value = resource.getString(keyName);
- return value;
- }
- /**
- * 获取配置文件中keyName对应的value
- */
- public static String getPropValue(String keyName, String propsName, String defaultValue) {
- ResourceBundle resource = ResourceBundle.getBundle(propsName);
- String value = resource.getString(keyName);
- if (StringUtils.isEmpty(value)) {
- value = defaultValue;
- }
- return value;
- }
- }
- url1=http://localhost:8080/SpringMVC/greet?name=lisi
- url2=http://127.0.0.1:8080/SpringMVC/greet?name=zhangshan
JAVA发送HttpClient的更多相关文章
- JAVA发送HttpClient请求及接收请求结果
1.写一个HttpRequestUtils工具类,包括post请求和get请求 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 2 ...
- JAVA发送HttpClient请求及接收请求结果过程
1.写一个HttpRequestUtils工具类,包括post请求和get请求 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...
- java使用HttpClient
HttpClient常用的包有两个 org.apache.http.client以及org.apache.commons.httpclient 我常用的是org.apache.http.client. ...
- Java之HttpClient调用WebService接口发送短信源码实战
摘要 Java之HttpClient调用WebService接口发送短信源码实战 一:接口文档 二:WSDL 三:HttpClient方法 HttpClient方法一 HttpClient方法二 Ht ...
- java发送post请求 ,请求数据放到body里
java利用httpclient发送post请求 ,请求数据放到body里. /** * post请求 ,请求数据放到body里 * * @author lifq * * 2017年3月15日 下午3 ...
- Java使用HttpClient上传文件
Java可以使用HttpClient发送Http请求.上传文件等,非常的方便 Maven <dependency> <groupId>org.apache.httpcompon ...
- Java发送HTTPS请求
前言 上篇文章介绍了 java 发送 http 请求,大家都知道发送http是不安全的 .我也是由于对接了其他企业后总结了一套发送 https的工具.大家网上找方法很多的,但是可不是你粘过来就能用啊, ...
- 使用Java发送Http请求的内容
公司要将自己的产品封装一个WebService平台,所以最近开始学习使用Java发送Http请求的内容.这一块之前用PHP的时候写的也比较多,从用最基本的Socket和使用第三方插件都用过. 学习了J ...
- JAVA发送http GET/POST请求的两种方式+JAVA http 请求手动配置代理
java发送http get请求,有两种方式. 第一种用URLConnection: public static String get(String url) throws IOException { ...
随机推荐
- python笔记4 - 函数
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...
- ==和Equal()的区别
我们在编程的时候,经常会遇到判断两个对象是否相等的情况.说到判断两个对象是否相等,就不得不说对象的类型和对象在内存中的存储情况. 对象类型可以分为值类型和引用类型: 值类型包括:简单类型.结构类型.枚 ...
- (转)java并发对象锁、类锁、私有锁
转自:http://ifeve.com/java-locks/ 建议参考:http://www.zhihu.com/question/28113814 Java类锁和对象锁实践 感谢[jiehao]同 ...
- 蓝桥杯 第三届C/C++预赛真题(7) 放棋子(水题)
今有 6 x 6 的棋盘格.其中某些格子已经预先放好了棋子.现在要再放上去一些,使得:每行每列都正好有3颗棋子.我们希望推算出所有可能的放法.下面的代码就实现了这个功能. 初始数组中,“1”表示放有棋 ...
- 使用python封装get+post请求
思路: 将平时用的多的get和post请求封装,提高代码重用率. 其中Session类可以通过实例化,保存cookie信息,可以在程序结束前多次通过保存的cookie信息保持登录状态的访问. 那么为什 ...
- BZOJ 3362 Navigation Nightmare 带权并查集
题目大意:给定一些点之间的位置关系,求两个点之间的曼哈顿距离 此题土豪题.只是POJ也有一道相同的题,能够刷一下 别被题目坑到了,这题不强制在线.把询问离线处理就可以 然后就是带权并查集的问题了.. ...
- Django之前端模板继承
在使用Django进行web开发时,往往会构造一个基础框架模板即base.html,而后在其子模板中对它所包含站点公用部分和定义块进行重载. 首先创建一个base.html,源码为: <!DOC ...
- docker菜鸟入门
.Docker概念简介 1.1 Docker的应用场景 1.2 Docker的优势 1.3 Docker架构 1.4 Dorcker核心概念 Dockerfile.Docker镜像和Docker容器的 ...
- Poj1482
It's not a Bug, It's a Feature! Time Limit: 5000MS Memory Limit: 30000K Total Submissions: 1428 ...
- Powershell Function Get-TimeZone
代码原文地址: https://gallery.technet.microsoft.com/scriptcenter/Get-TimeZone-PowerShell-4f1a34e6 <# .S ...