package com.j1.soa.resource.member.oracle.service;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.HttpURLConnection;
import java.net.URL;

import net.sf.json.JSONObject;

import com.j1.soa.common.Md5Util;

public class HttpText {

     final static String url = "http://192.168.200.53:8081/httpServer/c_i/common_i";
    //final static String url = "http://127.0.0.1:8080/httpServer/c_i/common_i";

    /**
     * 发送HttpPost请求
     * @param strURL  服务地址
     * @param sign  加密后的32 大写 MD5
     * @return 成功:返回json字符串<br/>
     */
    public static String post(String strURL,  String format,String method ,String sessionKey,String up_Date,String version,String sign) {
        System.out.println(strURL);
        System.out.println(sign);
        StringBuffer buffer = new StringBuffer();
        try {
            URL url = new URL(strURL);// 创建连接
            HttpURLConnection connection = (HttpURLConnection) url
                    .openConnection();
             connection.setDoOutput(true);
             connection.setDoInput(true);
             connection.setRequestMethod("POST");
             connection.setUseCaches(false);
             connection.setInstanceFollowRedirects(true);
           //  connection.setContentType("text/xml;charset=utf-8");
             connection.setRequestProperty("Accept", "application/json"); // 设置接收数据的格式
             connection.setRequestProperty("ContentType", "utf-8"); // 设置发送数据的格式
             connection.setRequestProperty("Accept-Charset", "utf-8");
             connection.connect();
               //POST请求
          //   BufferedReader br = new BufferedReader(new InputStreamReader(is,"utf-8"));
             PrintWriter out =   new PrintWriter(new OutputStreamWriter(connection.getOutputStream(),"utf-8")); // utf-8编码  ;
            JSONObject obj = new JSONObject();
            obj.element("sessionKey", sessionKey);
            obj.element("method",method);
            obj.element("format", format);
            obj.element("up_Date", up_Date);
            obj.element("sign", sign);
            obj.element("version", version);
           JSONObject objbusinessdate = new JSONObject();
           objbusinessdate.element("memCardNo", "f999999299-ffJ1");//卡号
            objbusinessdate.element("contactor", "移动人");//姓名
             objbusinessdate.element("idCardCode", "32080220163212012");//身份证
           objbusinessdate.element("sex", "F");//性别
           objbusinessdate.element("birthDay", "2016-03-21");//生日 YYYY-MM-DD
        //    objbusinessdate.element("age",  19);//年龄
             objbusinessdate.element("address", "移动电话");// 地址
        //    objbusinessdate.element("hTel", "1111111111");// 座机
             objbusinessdate.element("mTel", "00800780");// 移动电话
           objbusinessdate.element("eMail", "11111@j1.com");//email
           objbusinessdate.element("enrDeptId", "1111");//部门id
             objbusinessdate.element("roptrId", "3219");//操作人id
            objbusinessdate.element("ybCardCode", "111111111111");//医保卡
         //   objbusinessdate.element("qqCode", "111111");//qq
            objbusinessdate.element("note", "移动电话"); //备注
            //"contactor":"15821023367","sex":"1","mTel":"15821023367","eMail":"fufu_pupu@163.com","regTime":"2016-11-22 10:18:19"
           /*** JSONObject objbusinessdate = new JSONObject();
                       objbusinessdate.element("username", "tyf");//  username ,
                       objbusinessdate.element("password", "1111"); //password

                       /***
                        * select    te.tranid     tranId,
                                    ca.contactor  contactor ,
                                    ca.memcardno  memCardNo,
                                     sa.retnamt   discount,
                                    sa.saleamt     saleAmt ,
                                    sa.trandate    tranDate,
                                    cae.articode   artiCode,
                                    cae.artiname   artiName,
                                    -te.artiqty    artiQty ,
                                    te.saleprice   salePrice

                 JSONObject objbusinessdate = new JSONObject();
                        objbusinessdate.element("deptNo", "000");//门店编码
                        objbusinessdate.element("deptName", "000");//门店名称
                        objbusinessdate.element("tranid", "1123");//  销售订单号 ,
                        objbusinessdate.element("contactor", "000");// 会员名称
                        objbusinessdate.element("memCardNo", "000");//会员卡号
                        objbusinessdate.element("discount", "000");//优惠
                        objbusinessdate.element("mTel", "000");//手机号码
                JSONObject artiitem = new JSONObject();         

                        artiitem.element("saleAmt", "000");//实付金额
                        artiitem.element("tranDate", "000");//销售时间
                        artiitem.element("artiCode", "000");      //商品编码
                        artiitem.element("artiName", "000");//商品名称
                        artiitem.element("artiQty", "000");//数量
                        artiitem.element("salePrice", "000");  //成交价格
                 objbusinessdate.element("artiitem", artiitem);
                        */
          //  String txt = new String(objbusinessdate.toString().getBytes(), "utf-8");
            obj.element("businessData", objbusinessdate);

            System.out.println(obj.toString());

           // out.write(obj.toString().getBytes());

            // 发送请求参数
            out.print(obj.toString() );
            // flush输出流的缓冲
            out.flush();

            // 读取响应
            int length = (int) connection.getContentLength();// 获取长度
            System.out.println("length:"+length);
            BufferedReader rd = new BufferedReader(new InputStreamReader(connection.getInputStream()));
            String line;
            while( (line = rd.readLine())!=null){
                buffer.append(line);
            }
            out.close();
            rd.close(); 

            connection.disconnect();
            System.out.println(buffer.toString()+"  0000");
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return "error"; // 自定义错误信息
    }

    public static void main(String[] args) {

        //MD5加密顺序  format  meThod  sessionKey token  up_date  version
        //           format+method+sessionKey+token+up_date+version
         String token="91A1643059824847938125BA0AC0F557";//"bf0d8da2736e4d8caea055d863610a33  ";91A1643059824847938125BA0AC0F557 //token 不产于传送 但是参与加密

         String format ="json";      //传送方式
         String method ="saveMember";//"queryTbl_Employee " erpTranDetailCount_ToJ1 saveMember ;//调用方法
         String sessionKey ="123456789078945";//sessionkey
         String up_date ="2016-10-27";//上传日期  yyyy-mm-dd
         String version ="1.0.2";//版本号

     //  TranIdListServiceImpl.testhttprequest();
         //System.exit(0);
         String sign=null;
        try {
            sign = Md5Util.Bit32(format+method+sessionKey +token+up_date+version);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
          post(url,format,method ,sessionKey,up_date,version,sign);
    }

}

http发送post请求的更多相关文章

  1. Java发送Http请求并获取状态码

    通过Java发送url请求,查看该url是否有效,这时我们可以通过获取状态码来判断. try { URL u = new URL("http://10.1.2.8:8080/fqz/page ...

  2. AngularJs的$http发送POST请求,php无法接收Post的数据解决方案

      最近在使用AngularJs+Php开发中遇到php后台无法接收到来自AngularJs的数据,在网上也有许多解决方法,却都点到即止.多番摸索后记录下解决方法:tips:当前使用的AngularJ ...

  3. Ajax发送POST请求SpringMVC页面跳转失败

    问题描述:因为使用的是SpringMVC框架,所以想使用ModelAndView进行页面跳转.思路是发送POST请求,然后controller层中直接返回相应ModelAndView,但是这种方法不可 ...

  4. 使用HttpClient来异步发送POST请求并解析GZIP回应

    .NET 4.5(C#): 使用HttpClient来异步发送POST请求并解析GZIP回应 在新的C# 5.0和.NET 4.5环境下,微软为C#加入了async/await,同时还加入新的Syst ...

  5. 在发送ajax请求时加时间戳或者随机数去除js缓存

    在发送ajax请求的时候,为了保证每次的都与服务器交互,就要传递一个参数每次都不一样,这里就用了时间戳 大家在系统开发中都可能会在js中用到ajax或者dwr,因为IE的缓存,使得我们在填入相同的值的 ...

  6. HttpUrlConnection发送url请求(后台springmvc)

    1.HttpURLConnection发送url请求 public class JavaRequest { private static final String BASE_URL = "h ...

  7. kattle 发送post请求

    一.简介 kattle是一款国外开源的ETL工具,纯java编写,可以在Window.Linux.Unix上运行,数据抽取高效稳定.它允许你管理来自不同数据库的数据,通过提供一个图形化的用户环境来描述 ...

  8. 【荐】怎么用PHP发送HTTP请求(POST请求、GET请求)?

    file_get_contents版本: <?php /** * 发送post请求 * @param string $url 请求地址 * @param array $post_data pos ...

  9. 使用RestTemplate发送post请求

    最近使用RestTemplate发送post请求,遇到了很多问题,如转换httpMessage失败,中文乱码等,调了好久才找到下面较为简便的方法: RestTemplate restTemplate ...

  10. 【转载】JMeter学习(三十六)发送HTTPS请求

    Jmeter一般来说是压力测试的利器,最近想尝试jmeter和BeanShell进行接口测试.由于在云阅读接口测试的过程中需要进行登录操作,而登录请求是HTTPS协议.这就需要对jmeter进行设置. ...

随机推荐

  1. Shell中逻辑判断

    [ 条件1 -a 条件2 ]   当1和2都真时才为真 [ 条件1 -o 条件2 ]   当1和2其中一个为真即为真 [ ! 条件 ]           取反   &&     与 ...

  2. jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate)

    这篇文章主要介绍了jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate),需要的朋友可以参考下 使用jQuery ui首先需要引入jQuery类库 ...

  3. 你好,C++(27)在一个函数内部调用它自己本身 5.1.5 函数的递归调用

    5.1.5 函数的递归调用 在函数调用中,通常我们都是在一个函数中调用另外一个函数,以此来完成其中的某部分功能.例如,我们在main()主函数中调用PowerSum()函数来计算两个数的平方和,而在P ...

  4. 3.3.2 嵌入汇编(摘自<linux内核完全剖析>)

    内核C语言程序嵌入式汇编代码又叫内联汇编,具有输入和输出参数的嵌入汇编语句的基本格式为: ************************************************** asm( ...

  5. 转载:CURL常用命令

    转载网址:http://www.cnblogs.com/gbyukg/p/3326825.html 下载单个文件,默认将输出打印到标准输出中(STDOUT)中 curl http://www.cent ...

  6. phpwind伪静态规则(IIS,Nginx,Apache)的介绍及代码

    phpwind iis下伪静态规则[ISAPI_Rewrite]RewriteRule ^(.*)/(.*)-htm-(.*)-(.*).html$ $1/$2.php?$3=$4RewriteRul ...

  7. R: for installing package 'RODBC'

    Today, i try to install a package in R named 'DOBDC', while i meet a message: > install.packages( ...

  8. VS2012和2010 设置framework版本

    记录下找着麻烦http://zhidao.baidu.com/question/537279472.html VS2010和VS2012或者sv2008和VS2010,高版本VS编译都会出现,使用VS ...

  9. 关于nginx架构探究(4)

    事件管理机制 Nginx是以事件驱动的,也就是说Nginx内部流程的向前推进基本都是靠各种事件的触发来驱动,否则Nginx将一直阻塞在函数epoll_wait()或suspend函数,Nginx事件一 ...

  10. 如何升级nodejs版本

    直接下载最新版安装即可,例如我本地的nodejs版本为: y@y:untitled$ node -v v0.10.33 当前node官网最新版本为:Current Version: v0.12.2 下 ...