这几天研究j2me图片文件上传,手机上用FileConnection浏览文件夹,读取图片文件,
然后提交到服务器上的http接口.
首先采用的是 HttpConnection ,发送数据(构建文件上传方式也一样), 发现数据都被采用了 chunked 编码,
服务端什么内容都获取不到( 这里遇到一个奇怪的问题,用我本机做服务端,即使chunked编码,也能够完整的获取到数据),
chunked只有在数据超过2016个字节的时候才会产生.
于是上网搜集资料,发现mingjava的colala实例采用的是将数据切分为 1700 字节大小,循环上传,直到上传完毕,
(这里不知道mingjava是要做进度故意这么做,还是当时也遇到chunked编码的问题才这么做的. hh )
还有网上讨论的 http/1.1 http/1.0的问题,好像也是错误的.因为用socket数据,设置http/1.1 http/1.0 结果都是一样的.
conn = (HttpConnection) Connector.open(server,Connector.READ_WRITE,true);
conn.setRequestProperty("Content-Type","application/octet-stream");
conn.setRequestProperty("Content-Length", String.valueOf(data.length));
conn.setRequestProperty("Connection","Keep-Alive");
conn.setRequestProperty("Connection","close");
//conn.setRequestProperty("User-Agent", "J2me/Client");
conn.setRequestMethod(HttpConnection.POST);
os = conn.openOutputStream();
os.write(data);
所以只好采用socket,模拟http 协议,上传文件
StringBuffer sb=new StringBuffer();
sb.append("POST ");sb.append(URL.query);sb.append(" HTTP/1.1/r/n");
sb.append("Host: ");sb.append(URL.host);sb.append("/r/n");
sb.append("Content-type: application/octet-stream/r/n");
sb.append("Content-Length: ");sb.append(data.length);sb.append("/r/n");
sb.append("Connection: close/r/n/r/n");
sc = (SocketConnection)Connector.open("socket://"+URL.host+":"+URL.port);
is = sc.openInputStream();
os = sc.openOutputStream();
os.write(sb.toString().getBytes());
os.write(data);
经过测试成功,构建文件上传数据流格式也没有问题.... 这样服务端的程序就和web通常的写法一样了.不需要做特殊处理了