网络通信——HTTP接口访问——POST方式调用HTTP接口

GET方式的毛病在于:请求参数只能以“参数名=参数值&参数名=参数值”这样的格式添加到接口地址末尾,使得它无法传送复杂结构的请求报文。

POST方式把接口地址与请求报文分开,允许使用自定义的报文格式(如JSON),由此扩大了该方式的应用场景。

=================================================================================================================

布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="5dp" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="40dp" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="请选择要更新的应用:"
            android:textColor="@color/black"
            android:textSize="17sp" />

        <Spinner
            android:id="@+id/sp_app_name"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:spinnerMode="dialog" />
    </LinearLayout>

    <ImageView
        android:id="@+id/iv_app"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:scaleType="fitCenter" />

    <TextView
        android:id="@+id/tv_app_result"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColor="@color/black"
        android:textSize="17sp" />

</LinearLayout>

主代码:

package com.example.myapplication;

import android.annotation.SuppressLint;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.Spinner;
import android.widget.TextView;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import com.example.myapplication.bean.PackageInfo;
import com.example.myapplication.constant.ApkConstant;
import com.example.myapplication.task.CheckUpdateTask;
import com.example.myapplication.task.req.CheckUpdateReq;
import com.example.myapplication.task.resp.CheckUpdateResp;
import com.google.gson.Gson;

@SuppressLint("DefaultLocale")
public class MainActivity extends AppCompatActivity implements CheckUpdateTask.OnCheckUpdateListener
{

    private static final String TAG = "HttpPostActivity";
    private Spinner sp_app_name; // 应用名称的下拉框
    private ImageView iv_app;
    private TextView tv_app_result;
    private boolean isFirstSelect = true; // 是否首次选择

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        iv_app = findViewById(R.id.iv_app);
        tv_app_result = findViewById(R.id.tv_app_result);
        initAppSpinner(); // 初始化应用名称的下拉框
    }

    // 初始化应用名称的下拉框
    private void initAppSpinner() {
        ArrayAdapter<String> apkNameAdapter = new ArrayAdapter<String>(this,
                R.layout.item_select, ApkConstant.NAME_ARRAY);
        sp_app_name = findViewById(R.id.sp_app_name);
        sp_app_name.setPrompt("请选择要更新的应用");
        sp_app_name.setAdapter(apkNameAdapter);
        sp_app_name.setOnItemSelectedListener(new AppNameSelectedListener());
        sp_app_name.setSelection(0);
    }

    class AppNameSelectedListener implements AdapterView.OnItemSelectedListener {
        public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
            if (isFirstSelect) { // 刚打开页面时不需要执行下载动作
                isFirstSelect = false;
                return;
            }
            queryAppInfo(arg2); // 查询应用的详细信息
        }

        public void onNothingSelected(AdapterView<?> arg0) {}
    }

    // 查询应用的详细信息
    private void queryAppInfo(int pos) {
        iv_app.setImageResource(ApkConstant.ICON_ARRAY[pos]); // 设置图像视图的资源图片
        CheckUpdateReq req = new CheckUpdateReq(); // 创建检查更新的请求对象
        req.package_list.add(new PackageInfo(ApkConstant.PACKAGE_ARRAY[pos]));
        String content = new Gson().toJson(req); // 把检查更新的请求对象转换为json字符串
        CheckUpdateTask task = new CheckUpdateTask(); // 创建一个检查应用更新的异步任务
        task.setCheckUpdateListener(this); // 设置应用更新检查的监听器
        task.execute(content); // 把应用更新检查任务加入到处理队列
    }

    // 在结束应用更新检查时触发
    @Override
    public void finishCheckUpdate(String resp) {
        if (TextUtils.isEmpty(resp)) {
            Toast.makeText(this, "应用检查更新失败", Toast.LENGTH_SHORT).show();
            return;
        }
        // 把JSON串转换为对应结构的实体对象
        CheckUpdateResp checkResp = new Gson().fromJson(resp, CheckUpdateResp.class);
        if (checkResp!=null && checkResp.package_list!=null && checkResp.package_list.size()>0) {
            PackageInfo info = checkResp.package_list.get(0);
            String desc = String.format("应用检查更新结果如下:\n应用名称:%s\n应用包名:%s\n最新版本:%s\n下载地址:%s",
                    info.app_name, info.package_name, info.new_version, info.download_url);
            tv_app_result.setText(desc); // 显示当前选中应用的检查更新结果
        }
    }

}
CheckUpdateResp
package com.example.myapplication.task.resp;

import com.example.myapplication.bean.PackageInfo;
import java.util.ArrayList;
import java.util.List;

public class CheckUpdateResp
{

    public List<PackageInfo> package_list = new ArrayList<PackageInfo>();
}
PackageInfo
package com.example.myapplication.bean;

public class PackageInfo
{

    public String app_name; // 应用名称
    public String package_name; // 应用包名
    public String download_url; // 下载地址
    public String new_version; // 新版本号

    public PackageInfo()
    {

        app_name = "";
        package_name = "";
        download_url = "";
        new_version = "";
    }

    public PackageInfo(String package_name)
    {

        this.package_name = package_name;
    }

}
UrlConstant
package com.example.myapplication.constant;

public class UrlConstant
{
    // 以下是HTTP接口调用的服务地址,根据实际情况修改IP和端口
    public static final String REQUEST_URL = "http://192.168.1.7:8080/NetServer";

    //public static final String REQUEST_URL = "http://192.168.1.2:6001/NetServer";

    // 检查应用更新的服务地址
    public static final String CHECK_UPDATE_URL = REQUEST_URL + "/checkUpdate";

    // 上传文件的服务地址
    public static final String UPLOAD_URL = REQUEST_URL + "/uploadServlet";

    // 获取旅游图片的服务地址
    public static final String GET_PHOTO_URL = REQUEST_URL + "/getPhoto";

    // 根据经纬度查询详细地址的网址(天地图)
    public static final String GET_ADDRESS_URL = "https://api.tianditu.gov.cn/geocoder?postStr={'lon':%f,'lat':%f,'ver':1}&type=geocode&tk=145897399844a50e3de2309513c8df4b";

   // 请求图片验证码的网址
    public static final String IMAGE_CODE_URL = "http://yx12.fjjcjy.com/Public/Control/GetValidateCode?time=";
}
CheckUpdateTask
package com.example.myapplication.task;

import android.os.AsyncTask;
import android.util.Log;
import com.example.myapplication.constant.UrlConstant;
import com.example.myapplication.util.HttpUtil;

// 检查应用更新的异步任务
public class CheckUpdateTask extends AsyncTask<String, Void, String>
{

    private final static String TAG = "CheckUpdateTask";

//    public CheckUpdateTask() {
//        super();
//    }

    // 线程正在后台处理
    protected String doInBackground(String... params)
    {

        String req = params[0]; // HTTP请求内容
        Log.d(TAG, "req = " + req);
        // 发送HTTP请求信息,并获得HTTP应答内容。检查更新的接口地址见UrlConstant.java
        String resp = HttpUtil.post(UrlConstant.CHECK_UPDATE_URL, req, null);
        Log.d(TAG, "resp = " + resp);
        return resp; // 返回HTTP应答内容
    }

    // 线程已经完成处理
    protected void onPostExecute(String resp)
    {

        mListener.finishCheckUpdate(resp); // HTTP调用完毕,触发监听器的结束检查事件
    }

    private OnCheckUpdateListener mListener; // 声明一个结束更新检查的监听器对象

    // 设置结束更新检查的监听器
    public void setCheckUpdateListener(OnCheckUpdateListener listener)
    {

        mListener = listener;
    }

    // 定义一个结束更新检查的监听器接口
    public interface OnCheckUpdateListener
    {

        void finishCheckUpdate(String resp);
    }

}
HttpUtil
package com.example.myapplication.util;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.util.Log;

import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.security.SecureRandom;
import java.security.cert.X509Certificate;
import java.util.Map;
import java.util.zip.GZIPInputStream;

import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

public class HttpUtil {
    private final static String TAG = "HttpUtil";
    private final static int CONNECT_TIMEOUT = 15000;
    private final static int READ_TIMEOUT = 15000;

    // 兼容https开头的调用地址
    private static void compatibleSSL(String callUrl) throws Exception {
        if (callUrl.toLowerCase().startsWith("https")) {
            SSLContext sc = SSLContext.getInstance("TLS");
            sc.init(null, new TrustManager[]{new X509TrustManager() {
                @Override
                public X509Certificate[] getAcceptedIssuers() {
                    return null;
                }

                @Override
                public void checkServerTrusted(X509Certificate[] arg0, String arg1) {
                }

                @Override
                public void checkClientTrusted(X509Certificate[] arg0, String arg1) {
                }
            }}, new SecureRandom());
            HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
            HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
                @Override
                public boolean verify(String hostname, SSLSession session) {
                    return true;
                }
            });
        }
    }

    // 对指定接口地址发起GET调用
    public static String get(String callUrl, Map<String, String> headers)
    {
        String resp = ""; // 应答内容
        try
        {
            Log.d(TAG, "请求地址:"+callUrl);

            compatibleSSL(callUrl); // 兼容https开头的调用地址
            URL url = new URL(callUrl); // 根据网址字符串构建URL对象

            // 打开URL对象的网络连接,并返回HttpURLConnection连接对象
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET"); // 设置请求方式
            setConnHeader(conn, headers);// 设置HTTP连接的头部信息
            conn.connect(); // 开始连接

            // 打印HTTP调用的应答内容长度、内容类型、压缩方式
            Log.d(TAG,  String.format("应答内容长度=%d, 内容类型=%s, 压缩方式=%s", conn.getContentLength(), conn.getContentType(), conn.getContentEncoding()) );

            // 对输入流中的数据解压和字符编码,得到原始的应答字符串
            resp = getUnzipString(conn);

            // 打印HTTP调用的应答状态码和应答报文
            Log.d(TAG,  String.format("应答状态码=%d, 应答报文=%s", conn.getResponseCode(), resp) );

            conn.disconnect(); // 断开连接

        }
        catch (Exception e)
        {

            e.printStackTrace();
        }
        return resp;
    }

    // 从指定url获取图片
    public static Bitmap getImage(String callUrl, Map<String, String> headers) {
        Bitmap bitmap = null; // 位图对象
        try {
            Log.d(TAG, "请求地址:"+callUrl);
            compatibleSSL(callUrl); // 兼容https开头的调用地址
            URL url = new URL(callUrl); // 根据网址字符串构建URL对象
            // 打开URL对象的网络连接,并返回HttpURLConnection连接对象
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET"); // 设置请求方式
            setConnHeader(conn, headers);// 设置HTTP连接的头部信息
            conn.connect(); // 开始连接
            // 打印图片获取的应答内容长度、内容类型、压缩方式
            Log.d(TAG,  String.format("应答内容长度=%d, 内容类型=%s, 压缩方式=%s",
                    conn.getContentLength(), conn.getContentType(), conn.getContentEncoding()) );
            // 对输入流中的数据解码,得到位图对象
            bitmap = BitmapFactory.decodeStream(conn.getInputStream());
            // 打印图片获取的应答状态码和位图大小
            Log.d(TAG,  String.format("应答状态码=%d, 位图大小=%s", conn.getResponseCode(), bitmap.getByteCount()) );
            conn.disconnect(); // 断开连接
        } catch (Exception e) {
            e.printStackTrace();
        }
        return bitmap;
    }

    // 对指定接口地址发起POST调用
    public static String post(String callUrl, String req, Map<String, String> headers) {
        String resp = ""; // 应答内容
        try {
            Log.d(TAG, "请求地址:"+callUrl+", 请求报文="+req);
            compatibleSSL(callUrl); // 兼容https开头的调用地址
            URL url = new URL(callUrl); // 根据网址字符串构建URL对象
            // 打开URL对象的网络连接,并返回HttpURLConnection连接对象
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("POST"); // 设置请求方式
            setConnHeader(conn, headers);// 设置HTTP连接的头部信息
            conn.setRequestProperty("Content-Type", "application/json"); // 请求报文为json格式
            conn.setDoOutput(true); // 准备让连接执行输出操作。默认为false,POST方式需要设置为true
            //conn.setDoInput(true); // 准备让连接执行输入操作。默认为true
            conn.connect(); // 开始连接
            OutputStream os = conn.getOutputStream(); // 从连接对象中获取输出流
            os.write(req.getBytes()); // 往输出流写入请求报文
            // 打印HTTP调用的应答内容长度、内容类型、压缩方式
            Log.d(TAG,  String.format("应答内容长度=%s, 内容类型=%s, 压缩方式=%s",
                    conn.getHeaderField("Content-Length"), conn.getHeaderField("Content-Type"),
                    conn.getHeaderField("Content-Encoding")) );
            // 对输入流中的数据解压和字符编码,得到原始的应答字符串
            resp = getUnzipString(conn);
            // 打印HTTP调用的应答状态码和应答报文
            Log.d(TAG,  String.format("应答状态码=%d, 应答报文=%s", conn.getResponseCode(), resp) );
            conn.disconnect(); // 断开连接
        } catch (Exception e) {
            e.printStackTrace();
        }
        return resp;
    }

    // 把文件上传给指定的URL
    public static String upload(String uploadUrl, String uploadFile, Map<String, String> headers)
    {

        String resp = ""; // 应答内容
        // 从本地文件路径获取文件名
        String fileName = uploadFile.substring(uploadFile.lastIndexOf("/"));
        String end = "\r\n"; // 结束字符串
        String hyphens = "--"; // 连接字符串
        String boundary = "WUm4580jbtwfJhNp7zi1djFEO3wNNm"; // 边界字符串
        try (FileInputStream fis = new FileInputStream(uploadFile)) {
            Log.d(TAG, "上传地址:"+uploadUrl+", 上传文件="+uploadFile);
            compatibleSSL(uploadUrl); // 兼容https开头的调用地址
            URL url = new URL(uploadUrl); // 根据网址字符串构建URL对象
            // 打开URL对象的网络连接,并返回HttpURLConnection连接对象
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("POST"); // 设置请求方式
            setConnHeader(conn, headers);// 设置HTTP连接的头部信息
            conn.setDoOutput(true); // 准备让连接执行输出操作。默认为false,POST方式需要设置为true
            //conn.setDoInput(true); // 准备让连接执行输入操作。默认为true
            conn.setRequestProperty("Connection", "Keep-Alive"); // 连接过程要保持活跃
            // 请求报文要求分段传输,并且各段之间以边界字符串隔开
            conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);

            // 根据连接对象的输出流构建数据输出流
            DataOutputStream ds = new DataOutputStream(conn.getOutputStream());
            // 以下写入请求报文的头部
            ds.writeBytes(hyphens + boundary + end);
            ds.writeBytes("Content-Disposition: form-data; "
                    + "name=\"file\";filename=\"" + fileName + "\"" + end);
            ds.writeBytes(end);
            // 以下写入请求报文的主体
            byte[] buffer = new byte[1024];
            int length;
            // 先将文件数据写入到缓冲区,再将缓冲数据写入输出流
            while ((length = fis.read(buffer)) != -1) {
                ds.write(buffer, 0, length);
            }
            ds.writeBytes(end);
            // 以下写入请求报文的尾部
            ds.writeBytes(hyphens + boundary + hyphens + end);
            ds.close(); // 关闭数据输出流
            // 打印HTTP调用的应答内容长度、内容类型、压缩方式
            Log.d(TAG,  String.format("应答内容长度=%s, 内容类型=%s, 压缩方式=%s",
                    conn.getHeaderField("Content-Length"), conn.getHeaderField("Content-Type"),
                    conn.getHeaderField("Content-Encoding")) );
            // 对输入流中的数据解压和字符编码,得到原始的应答字符串
            resp = getUnzipString(conn);
            // 打印HTTP上传的应答状态码和应答报文
            Log.d(TAG,  String.format("应答状态码=%d, 应答报文=%s", conn.getResponseCode(), resp) );
            conn.disconnect(); // 断开连接
        }
        catch (Exception e)
        {

            e.printStackTrace();
        }
        return resp;
    }

    // 设置HTTP连接的头部信息
    private static void setConnHeader(HttpURLConnection conn, Map<String, String> headers)
    {

        conn.setConnectTimeout(CONNECT_TIMEOUT); // 设置连接的超时时间,单位毫秒
        conn.setReadTimeout(READ_TIMEOUT); // 设置读取应答数据的超时时间,单位毫秒
        conn.setRequestProperty("Accept", "*/*"); // 设置数据格式
        conn.setRequestProperty("Accept-Language", "zh-CN"); // 设置文本语言
        conn.setRequestProperty("Accept-Encoding", "gzip, deflate"); // 设置编码格式

        // 设置用户代理,包括操作系统版本、浏览器版本等等
        conn.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:33.0) Gecko/20100101 Firefox/33.0");
        if (headers != null)
        {

            for (Map.Entry<String, String> item : headers.entrySet())
            {

                conn.setRequestProperty(item.getKey(), item.getValue());
            }
        }
    }

    // 把输入流中的数据按照指定字符编码转换为字符串。处理大量数据需要使用本方法
    private static String isToString(InputStream is, String charset)
    {

        String result = "";
        // 创建一个字节数组的输出流对象
        try (ByteArrayOutputStream baos = new ByteArrayOutputStream())
        {

            int i = -1;
            while ((i = is.read()) != -1)   // 循环读取输入流中的字节数据
            {
                baos.write(i); // 把字节数据写入字节数组输出流
            }
            byte[] data = baos.toByteArray(); // 把字节数组输出流转换为字节数组
            result = new String(data, charset); // 将字节数组按照指定的字符编码生成字符串
        }
        catch (Exception e)
        {

            e.printStackTrace();
        }

        return result; // 返回转换后的字符串
    }

    // 从HTTP连接中获取已解压且重新编码后的应答报文
    private static String getUnzipString(HttpURLConnection conn) throws IOException
    {
        String contentType = conn.getContentType(); // 获取应答报文的内容类型(包括字符编码)

        String charset = "UTF-8"; // 默认的字符编码为UTF-8

        if (contentType != null)
        {

            if (contentType.toLowerCase().contains("charset=gbk"))   // 应答报文采用gbk编码
            {
                charset = "GBK"; // 字符编码改为GBK
            }
            else if (contentType.toLowerCase().contains("charset=gb2312"))  // 采用gb2312编码
            {
                charset = "GB2312"; // 字符编码改为GB2312
            }
        }

        String contentEncoding = conn.getContentEncoding(); // 获取应答报文的压缩方式

        InputStream is = conn.getInputStream(); // 获取HTTP连接的输入流对象

        String result = "";

        if (contentEncoding != null && contentEncoding.contains("gzip"))   // 应答报文使用gzip压缩
        {
            // 根据输入流对象构建压缩输入流
            try (GZIPInputStream gis = new GZIPInputStream(is))
            {
                // 把压缩输入流中的数据按照指定字符编码转换为字符串
                result = isToString(gis, charset);
            }
            catch (Exception e)
            {

                e.printStackTrace();
            }
        }
        else
        {

            // 把输入流中的数据按照指定字符编码转换为字符串
            result = isToString(is, charset);
        }

        return result; // 返回处理后的应答报文
    }

}

 

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
◆ 01.htm 1、怎么用mscomm控件检测modem是否与计算机联接正确?2、如何用mscomm挂断modem与别的电话机间的连接?(已接通) ◆ 02.htm CWinInetConnection---一个封装了WinInet API函数的类 ◆ 03.htm MODEM通讯意外处理 ◆ 04.htm MsComm 文字传输 ◆ 05.htm PING一个IP地址(向它发送一个数据包并等待回应) ◆ 06.htm SMTP协议简介 (Simple Mail Transfer Protocol) ◆ 07.htm VB5.0 中远程数据库的访问 ◆ 08.htm VB下如何编写CRC校验程序 ◆ 09.htm VB中Winsock控制的UDP协议的使用 ◆ 10.htm Visual Basic 6中发送邮件的新方法 ◆ 11.htm Visual Basic通信程序设计 ◆ 12.htm Whois 示例程序 ◆ 13.htm Winsock Terminal示例程序 ◆ 14.htm WinSock断开导致客户端问题 ◆ 15.htm 把Outlook信箱中的附件另存为 ◆ 16.htm 保证连网计算机时间同步 ◆ 17.htm 编写网络寻呼机 ◆ 18.htm 编制自已的电话录音小程序 ◆ 19.htm 程序中如何启动默认的拨号连接 ◆ 20.htm 程序中如何启动默认的拨号连接? ◆ 21.htm 打开器并进入指定网址 ◆ 22.htm 打开一个直接到自己主页的器 ◆ 23.htm 得到用户的IP地址 ◆ 24.htm 电话拨号 ◆ 25.htm 电子邮件的标准格式 (RFC 822) ◆ 26.htm 断开拨号网络连接 ◆ 27.htm 断开与 Internet 的连接 ◆ 28.htm 发送电子邮件附件 ◆ 29.htm 发送电子邮件附件1 ◆ 30.htm 发送电子邮件附件2 ◆ 31.htm 发送电子邮件附件3 ◆ 32.htm 发送电子邮件附件4 ◆ 33.htm 获得用户网络登录名 ◆ 34.htm 基 于Win95 的VB5 串 口 通 信 程 序 ◆ 35.htm 基于Win95的VB5串口通信程序 ◆ 36.htm 几个设置IE的API ◆ 37.htm 检测运程数据传送的断线 ◆ 38.htm 简单的聊天程序 ◆ 39.htm 简单电子邮件发送程序 ◆ 40.htm 建立拨号联接 ◆ 41.htm 将所有窗口最小化 ◆ 42.htm 利用IE控件访问Internet ◆ 43.htm 利用IE控件设计简易器 ◆ 44.htm 利用Mscomm32控件判断MODEM是否打开,或者正在工作,并且判断拨号时是否遇忙音 ◆ 45.htm 利用TAPI进行电话拨号 ◆ 46.htm 利用VB访问Internet ◆ 47.htm 利用VB设计聊天室 ◆ 48.htm 利用Visual Basic实现无线通讯 ◆ 49.htm 利用Winsock控件实现局域网通信 ◆ 50.htm 强制一个本地或远程NT系统关闭 ◆ 51.htm 取得网卡序列号 ◆ 52.htm 如何从 Internet 上取回某一个网页的內容? ◆ 53.htm 如何检测是否已连接到Internet? ◆ 54.htm 如何利用Winsock控件编写自己的Internet程序 ◆ 55.htm 如何每天抓取 Internet 上某一个网页中的图片来更换桌面的壁纸? ◆ 56.htm 如何启动拨号网路中的连线? ◆ 57.htm 如何使用MSCOMM32.OCX发送大于80H的字符,可否给个示例程序 ◆ 58.htm 如何通过VB获取网卡地址 ◆ 59.htm 如何用VB打开默认器或默认发信程序? ◆ 60.htm 如何用Visual Basic编写小型的网络系统 ◆ 61.htm 如何在程序中启动 NT 的【拨号连接】对话框 ◆ 62.htm 如何在程序中启动 NT 的【拨号连接】对话框? ◆ 63.htm 如何在网页上使用 VB5 制作的 ActiveX 控件? ◆ 64.htm 如何中断【拨号网络连接】 ◆ 65.htm 设计Browser及FTP程序 ◆ 66.htm 设计Chat程序 ◆ 67.htm 设计E-mail程序 ◆ 68.htm 设置计算机名称 ◆ 69.htm 使用VB获得一页的HTML代码 ◆ 70.htm 使用VB收发电子邮件 ◆ 71.htm 使用标签控件调出器 ◆ 72.htm 使用超链接和发送Email ◆ 73.htm 使用器的文件复制对话框 ◆ 74.htm 输入/输出篇 ◆ 75.htm 通过WnetEnumResource函数获得网络资源 ◆ 76.htm 通往 Internet 的捷径 ◆ 77.htm 显示计算机的名称 ◆ 78.htm 用 MAPI 控件实现发送邮件 ◆ 79.htm 用 WinSock 控件下载文件 ◆ 80.htm 用 Winsock 实现聊天的程序 ◆ 81.htm 用Internet Transfer编写FTP程序 ◆ 82.htm 用Sockets发送电子邮件 ◆ 83.htm 用VB 创 建 自 己 的 通 信 程 序 ◆ 84.htm 用VB5.0开发通信软件的技巧 ◆ 85.htm 用VB5开发IE ◆ 86.htm 用VB编写网络寻呼 ◆ 87.htm 用VB编写小型的网络系统 ◆ 88.htm 用VB创建自己的通信程序 ◆ 89.htm 用VB构建Internet的应用[微软提供] ◆ 90.htm 用VB开发标准CGI程序 ◆ 91.htm 用VB实现客户——服务器(TCP IP)编程实例 ◆ 92.htm 用VB实现客户服务器(TCP、IP)编程实例 ◆ 93.htm 用VB实现聊天讨论室和点对点会话 ◆ 94.htm 用VB写一个定时PING某IP的程序 ◆ 95.htm 用VB制作器 ◆ 96.htm 用Visual Basic 5.0设计E-mail程序(MAPI) ◆ 97.htm 用Visual Basic6.0编写客户服务器程序 ◆ 98.htm 用Visual Basic创建FTP组件 ◆ 99.htm 用Visual Basic开发数据库器 ◆ 100.htm 用Visual Basic轻松地设计Browser及Ftp程序 ◆ 101.htm 用Winsock控件发信Email ◆ 102.htm 用Winsock控件实现文件的下载 ◆ 103.htm 用Winsock实现点对点通信 ◆ 104.htm 邮件检查程序(二) ◆ 105.htm 邮件检查程序(一) ◆ 106.htm 在VB程序中怎样挂断拨号网络 ◆ 107.htm 在VB中操纵OLE服务器应用程序 ◆ 108.htm 在VB中利用UDP协议编写聊天程序 ◆ 109.htm 在VB中模拟实现邮件传输 ◆ 110.htm 在VB中如何得到网络中某一台电脑(电脑名)的网卡地质? (自己的) ◆ 111.htm 在VB中实现文件上传 ◆ 112.htm 在VB中实现文件上载 ◆ 113.htm 在VB中使用UDP协议 ◆ 114.htm 在VB中用Outlook发电子邮件 ◆ 115.htm 在WindowsNT网络中广播消息 ◆ 116.htm 在程序中打开 Internet 拨号连接窗口 ◆ 117.htm 在一个单位内部或通过广域协议(如X.25)互联的行业内部都有几十或上万台计算机互联,用Intranet虽然可以建立聊天室,但实现点对点实时对话却比较困难。本人用Winsock和VB自制了一套聊天室和对话系统,特拿来供同行们参考。 ◆ 118.htm 在应用中集成器 ◆ 119.htm 在桌面上建立一个 Internet 快捷键 ◆ 120.htm 怎样接收电子邮件(POP3协议简介) ◆ 121.htm 怎样用VB得知系统当前是否处于internet链结状态 ◆ 122.htm 制作自己的网络搜索软件 ◆ 123.htm 自动更新工作站的应用程序 ◆ 124.htm 自己的IE——用VB制作器 ◆ 125.htm HTTP协议(学习笔记) ◆ 126.htm HTTP协议四--关于Chunked编码 ◆ 127.htm IE器完全控制 ◆ 128.htm OICQ服务器系统通讯协议 ◆ 129.htm POP3协议的基本命令 ◆ 130.htm RAS API上的其他Function ◆ 131.htm VB + API 获取 IE 的 “代理服务器” 配制 ◆ 132.htm vb调用winInet API接口post数据到指定的url ◆ 133.htm vb开发通信软件 ◆ 134.htm vb设计数据库电子邮件程序(1) ◆ 135.htm vb设计数据库电子邮件程序(2) ◆ 136.htm vb设计数据库电子邮件程序(3) ◆ 137.htm vb设计数据库电子邮件程序(4) ◆ 138.htm vb设计数据库电子邮件程序(5) ◆ 139.htm vb设计数据库电子邮件程序(6) ◆ 140.htm VB实现应用程序在局域网上自动更新 ◆ 141.htm VB邮件检查程序 ◆ 142.htm vb中从域名得到IP及从IP得到域名 ◆ 143.htm VB中检测是否连网 ◆ 144.htm WebClass实现动态WEB编程之理论篇 ◆ 145.htm Winsocket网络编程谈 ◆ 146.htm Winsock编程框架 ◆ 147.htm Winsock错误代码一览表 ◆ 148.htm 程式自动呼叫拨号网络(RAS API) ◆ 149.htm 打开一个超连接 ◆ 150.htm 得到登入windows 的人的id ◆ 151.htm 访问Internet并调用Explorer ◆ 152.htm 非同步文件下载类 ◆ 153.htm 给Outlook的所有用户发送信件 ◆ 154.htm 获得网卡的MAC地址 ◆ 155.htm 基于WinSock的小型网络管理系统及其实现 ◆ 156.htm 检测是否连接到Internet ◆ 157.htm 检测网络是否连通 ◆ 158.htm 建立Web的超链接树形图 ◆ 159.htm 建立你自己的器-Properties ◆ 160.htm 建立你自己的器-查看源文件 ◆ 161.htm 建立你自己的器-打印 ◆ 162.htm 建立你自己的器-打印设置 ◆ 163.htm 建立你自己的器-发送到FontPage ◆ 164.htm 建立你自己的器-发送到Visual Interdev ◆ 165.htm 建立你自己的器-发送到软盘 ◆ 166.htm 建立你自己的器-复制 ◆ 167.htm 建立你自己的器-另存为 ◆ 168.htm 建立你自己的器-全选 ◆ 169.htm 建立你自己的器-页面设置 ◆ 170.htm 开发通信软件的技术与技巧 ◆ 171.htm 开发网络应用的5个技巧 ◆ 172.htm 利用RAS调用在VB6.0中实现拨号上网 ◆ 173.htm 利用VB提取HTML文件中的EMAIL地址 ◆ 174.htm 枚举出局域网上所有网络资源 ◆ 175.htm 面向Internet的开发工具 ◆ 176.htm 你也可以YAI--VB5中Winsock控件的使用 ◆ 177.htm 判断一个文件是否在IE的缓存中 ◆ 178.htm 启动拨号网络中的连接 ◆ 179.htm 浅谈HTTP协议(二)--返回值 ◆ 180.htm 浅谈HTTP协议(一)--结构 ◆ 181.htm 如何利用 WebBrowser 控件显示 .GIF 动画? ◆ 182.htm 如何映射(中断网络磁盘) ◆ 183.htm 设计E-mail的接收部分 ◆ 184.htm 设置器默认网址 ◆ 185.htm 实现端口对端口的聊天 ◆ 186.htm 使用ASP建立Http组件 ◆ 187.htm 使用VB编写纯ASP程序 ◆ 188.htm 使用vb获取网上邻居里的计算机名 ◆ 189.htm 使用VB建立Web Server ◆ 190.htm 使用Visual Basic开发通讯软件 ◆ 191.htm 使用资源工具包执行本地和远程重新启动 ◆ 192.htm 谈谈远程控制中关于搜索、控制计算机的功能 ◆ 193.htm 压缩 Html ◆ 194.htm 用ASP、VB和XML建立互联网应用程序(1) ◆ 195.htm 用ASP、VB和XML建立互联网应用程序(2) ◆ 196.htm 用ASP、VB和XML建立互联网应用程序(3) ◆ 197.htm 用ASP、VB和XML建立互联网应用程序(4) ◆ 198.htm 用COMMUNICATION控件进行数据采集(学习笔记) ◆ 199.htm 用OLE自动化Outlook ◆ 200.htm ActiveX控件用于DHTML开发 ◆ 201.htm 用VB编写ActiveX DLL实现ASP编程 ◆ 202.htm 用VB编写Windows CGI应用程序 ◆ 203.htm 用VB编写标准CGI程序(上) ◆ 204.htm 用VB编写标准CGI程序(下) ◆ 205.htm 用VB编写收发电子邮件程序 ◆ 206.htm 用VB编写网络监控软件 ◆ 207.htm 用VB编写异步多线程下载程序 ◆ 208.htm 用VB导入导出IE器收藏夹 ◆ 209.htm 用VB定制合路器 ◆ 210.htm 用VB和XML建立集中式应用程序 ◆ 211.htm 用VB将Html转换为文本文件 ◆ 212.htm 用VB开发分布式应用 ◆ 213.htm 用VB设计基于代理服务器的网络计费系统 ◆ 214.htm 用VB制作文件下载程序 ◆ 215.htm 用Visual Basic 实现无线通讯 ◆ 216.htm 用Winsock制作一套聊天室和对话系统 ◆ 217.htm 远程共享显示及声音的实现 ◆ 218.htm 远程启动机器ABC API解决方案 ◆ 219.htm 远程启动机器ABC WMI解决方案 ◆ 220.htm 在VB5中利用Winsock和msDNS控件进行 ◆ 221.htm 找出计算机上当前登录入网的用户 ◆ 222.htm 用VB5 Winsock控件创建TCP(IP)客户机 服务器程序
Java调用HTTP接口POST请求,可以使用Java标准库中的`java.net.HttpURLConnection`类。 示例代码如下: ``` import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; public class HttpPostExample { public static void main(String[] args) { try { // 指定接口地址 URL url = new URL("http://your-interface-address"); // 打开连接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); // 设置请求方式 conn.setRequestMethod("POST"); // 设置请求头 conn.setRequestProperty("Content-Type", "application/json"); conn.setDoOutput(true); // 构造请求参数 String data = "{\"param1\":\"value1\",\"param2\":\"value2\"}"; // 发送请求 DataOutputStream wr = new DataOutputStream(conn.getOutputStream()); wr.writeBytes(data); wr.flush(); wr.close(); // 获取响应 int responseCode = conn.getResponseCode(); System.out.println("Response Code: " + responseCode); BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream())); String inputLine; StringBuffer response = new StringBuffer(); while ((inputLine = in.readLine()) != null) { response.append(inputLine); } in.close(); // 打印响应 System.out.println(response.toString()); } catch (Exception e) { e.printStackTrace(); } } } ``` 需要注意的是, 需要引入相应的包,上述代码需要用到URL, HttpURLConnection, DataOutputStream,BufferedReader等类 其中,参数 `data` 是请求的参数,格式为字符串。 通过上述代码可以发送一个 POST 请求,可以在响应的基础上进一步操作

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值