for (FormFile uploadFile : files) {// 得到文件类型数据的总长度
StringBuilder fileExplain = new StringBuilder();
fileExplain.append(“–”);
fileExplain.append(BOUNDARY);
fileExplain.append(“\r\n”);
name = DateFormat.format(“yyyyMMddhhmmss”,Calendar.getInstance(Locale.CHINA))+“.”+getExtensionName(uploadFile.getFilname());
fileExplain.append(“Content-Disposition: form-data;name=\”“+ uploadFile.getParameterName()+”\“;filename=\”“+ name + “\”\r\n”);
fileExplain.append(“Content-Type: “+ uploadFile.getContentType()+”\r\n\r\n”);
fileExplain.append(“\r\n”);
fileDataLength += fileExplain.length();
if(uploadFile.getInStream()!=null){
fileDataLength += uploadFile.getFile().length();
}else{
fileDataLength += uploadFile.getData().length;
}
}
StringBuilder textEntity = new StringBuilder();
for (Map.Entry<String, String> entry : params.entrySet()) {// 构造文本类型参数的实体数据
textEntity.append(“–”);
textEntity.append(BOUNDARY);
textEntity.append(“\r\n”);
textEntity.append(“Content-Disposition: form-data; name=\”“+ entry.getKey() + “\”\r\n\r\n”);
textEntity.append(URLEncoder.encode(MStringUtils.getSpecial(entry.getValue()), “UTF-8”));
textEntity.append(“\r\n”);
}
// 计算传输给服务器的实体数据总长度
int dataLength = textEntity.toString().getBytes().length + fileDataLength + endline.getBytes().length;
URL url = new URL(path);
int port = 443;
Socket socket = (SSLSocket)((SSLSocketFactory)SSLSocketFactory.getDefault()).createSocket(InetAddress.getByName(url.getHost()), 443);
OutputStream outStream = socket.getOutputStream();
// 下面完成HTTP请求头的发送
String requestmethod = “POST " + url.getPath() + " HTTP/1.1\r\n”;
outStream.write(requestmethod.getBytes());
String accept = “Accept: image/gif, image/jpeg, image/pjpeg, image/pjpeg, application/x-shockwave-flash, application/xaml+xml, application/vnd.ms-xpsdocument, application/x-ms-xbap, application/x-ms-application, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*\r\n”;
outStream.write(accept.getBytes());
String language = “Accept-Language: zh-CN\r\n”;
outStream.write(language.getBytes());
String site = “site:”+Constant.SITE+“\r\n”;
outStream.write(site.getBytes());
String authorize = “authorize:”+Constant.AUTHORIZE+“\r\n”;
outStream.write(authorize.getBytes());
String contenttype = “Content-Type: multipart/form-data;boundary=” + BOUNDARY + “\r\n”;
outStream.write(contenttype.getBytes());
String contentlength = "Content-Length: " + dataLength + “\r\n”;
outStream.write(contentlength.getBytes());
String alive = “Connection: Keep-Alive\r\n”;
outStream.write(alive.getBytes());
String host = "Host: " + url.getHost() + “:” + port + “\r\n”;
outStream.write(host.getBytes());
// 写完HTTP请求头后根据HTTP协议再写一个回车换行
outStream.write(“\r\n”.getBytes());
// 把所有文本类型的实体数据发送出来
outStream.write(textEntity.toString().getBytes());
// 把所有文件类型的实体数据发送出来
for (FormFile uploadFile : files)
{
StringBuilder fileEntity = new StringBuilder();
fileEntity.append(“–”);
fileEntity.append(BOUNDARY);
fileEntity.append(“\r\n”);
fileEntity.append(“Content-Disposition: form-data;name=\”“+ uploadFile.getParameterName()+”\“;filename=\”“+ name + “\”\r\n”);
fileEntity.append(“Content-Type: “+ uploadFile.getContentType()+”\r\n\r\n”);
outStream.write(fileEntity.toString().getBytes());
if(uploadFile.getInStream()!=null){
byte[] buffer = new byte[1024];
int len = 0;
while((len = uploadFile.getInStream().read(buffer, 0, 1024))!=-1){
outStream.write(buffer, 0, len);
}
uploadFile.getInStream().close();
}else{
outStream.write(uploadFile.getData(), 0, uploadFile.getData().length);
}
outStream.write(“\r\n”.getBytes());
}
// 下面发送数据结束标志,表示数据已经结束
outStream.write(endline.getBytes());
BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
if (reader.readLine().indexOf(“200”) == -1) {// 读取web服务器返回的数据,判断请求码是否为200,如果不是200,代表请求失败
return false;
}
outStream.flush();
outStream.close();
reader.close();
socket.close();
return true; }
/*
* Java文件操作 获取文件扩展名 * */ public static String getExtensionName(String filename)
{
if ((filename != null) && (filename.length() > 0))
{
int dot = filename.lastIndexOf(‘.’);
if ((dot >-1) && (dot < (filename.length() - 1)))
{
return filename.substring(dot + 1);
}
}
return filename;
}
/**
* 提交数据到服务器 * * @param path
* 上传路径(注:避免使用localhost或127.0.0.1这样的路径测试,因为它会指向手机模拟器,你可以使用http://
* www.itcast.cn或http://192.168.1.10:8080这样的路径测试) * @param params
* 请求参数 key为参数名,value为参数值
* @param file
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
![](https://img-blog.csdnimg.cn/img_convert/b9c90aede3f005a1a900d36d99af0341.jpeg)
最后
今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。
最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司20年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【Android核心高级技术PDF文档,BAT大厂面试真题解析】
【算法合集】
【延伸Android必备知识点】
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
2551509485)]
【算法合集】
[外链图片转存中…(img-zIuNB6UQ-1712551509485)]
【延伸Android必备知识点】
[外链图片转存中…(img-UHAYi8tf-1712551509486)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!