HttpClient simulate http request

introducing dependent pom.xml

 

<dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpmime</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient-osgi</artifactId>
        </dependency>

 

ApiConsts.java

public interface ApiConsts {

    int ApiTimeout = 10000;
    Charset ApiCharset = Charset.defaultCharset();
    String ApiCharsetName = ApiCharset.name();
    String DateTimeFormat = "yyyy-MM-dd HH:mm:ss";

}

HttpUtils.java

import org.apache.http.Header;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.fluent.Request;
import org.apache.http.entity.StringEntity;
import org.apache.http.message.BasicHeader;
import org.springframework.stereotype.Component;
/**
 * 
 * @author wanjun
 *
 */
@Component
public class HttpUtils {

    private static Header[] DefaultJSONHeader = new Header[] {
            new BasicHeader("Content-Type", "application/json; charset=" + ApiConsts.ApiCharsetName) };

    private static Header[] getDefaultJSONHeaderWithCookie(String cookcie) {
        return DefaultJSONHeader = new Header[] {
                new BasicHeader("Content-Type", "application/json; charset=" + ApiConsts.ApiCharsetName),
                new BasicHeader("Cookie", cookcie) };
    };

    public String doPost(String apiUrl, String requestBody, String cookie) throws Exception {
        try {
            int timeout = ApiConsts.ApiTimeout;
            System.out.println("=============== [HTTP POST] ================");
            System.out.println("URL:" + apiUrl + ", timeout:" + timeout + "ms");
            System.out.println("Request Body:" + requestBody);
            String reply = Request.Post(apiUrl).socketTimeout(timeout).connectTimeout(timeout)
                    .body(new StringEntity(requestBody, ApiConsts.ApiCharset))
                    .setHeaders(getDefaultJSONHeaderWithCookie(cookie)).execute().returnContent()
                    .asString(ApiConsts.ApiCharset);

            System.out.println("Response Body:" + reply + "\n");
            return reply;
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        }
        return requestBody;
    }

    public String doGet(String apiUrl) throws Exception {
        try {
            int timeout = ApiConsts.ApiTimeout;
            System.out.println("=============== [HTTP GET] ================");
            System.out.println("URL:" + apiUrl + ", timeout:" + timeout + "ms");

            String reply = Request.Get(apiUrl).socketTimeout(timeout).connectTimeout(timeout).execute().returnContent()
                    .asString(ApiConsts.ApiCharset);

            System.out.println("Response Body:" + reply + "\n");
            return reply;

        } catch (ClientProtocolException e) {
            e.printStackTrace();
        }
        return apiUrl;
    }

}

test:

@RequestMapping("/getMoney")
    public String memberWithdrawal(String userName,String pwd,String money) throws Exception {
        UserInfo userInfo = userInfoMapper.queryUserInfoByUserName(userName);
        RequestParamBean param = newRequestParamBean(); 
        //param.set()
        //param.set()
     String response = httpUtils.doPost("url", JSON.toJSONString(getMoney), userInfo.getCookie()); return response; }       

 

Guess you like

Origin www.cnblogs.com/wanjun-top/p/12625798.html